これは、データベースの id 列に自動インクリメントが設定されていない可能性があるためです。
自動インクリメントなしのテスト モデルでこれを試したところ、0 が返されましたが、id 列を自動インクリメントに変更すると、ID が正しく返されました。
laravel/Framework/Src/Illuminate/Database/Eloquent/Model.php でこの関数を確認してください
自動インクリメントがある場合は、id を挿入して設定すると言われています。
protected function performInsert($query)
    {
        if ($this->fireModelEvent('creating') === false) return false;
        // First we'll need to create a fresh query instance and touch the creation and
        // update timestamps on this model, which are maintained by us for developer
        // convenience. After, we will just continue saving these model instances.
        if ($this->timestamps)
        {
            $this->updateTimestamps();
        }
        // If the model has an incrementing key, we can use the "insertGetId" method on
        // the query builder, which will give us back the final inserted ID for this
        // table from the database. Not all tables have to be incrementing though.
        $attributes = $this->attributes;
        if ($this->incrementing)
        {
            $this->insertAndSetId($query, $attributes);
        }
        // If the table is not incrementing we'll simply insert this attributes as they
        // are, as this attributes arrays must contain an "id" column already placed
        // there by the developer as the manually determined key for these models.
        else
        {
            $query->insert($attributes);
        }
        // We will go ahead and set the exists property to true, so that it is set when
        // the created event is fired, just in case the developer tries to update it
        // during the event. This will allow them to do so and run an update here.
        $this->exists = true;
        $this->fireModelEvent('created', false);
        return true;
    }