質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

Q&A

解決済

1回答

5262閲覧

Laravelのartisan db:seed実行時にエラー(Unable to locate factory with name [default] [App\Post].)

Ms.yy

総合スコア83

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

0グッド

0クリップ

投稿2019/08/10 01:43

編集2019/08/10 09:37

Laraelのphp artisan db:seed実行時に発生するエラーの意味と、解決策を教えてください。

2日ほど粘ってるんですが、まったく解決方法がわかりません。

参考にしているサイトはこちらで、コードはそのままコピぺしております。

[環境]
homestead上で実行
PHP 7.3.7
mac os
[困ってる事]

laravelで php artisan db:seedを行うとエラーが発生して先に進めない状況です。

[試したこと]
同じエラーである下記のサイトを参考にしました。
具体的にエラー内容であるApp\Postをuserfactry.phpのApp\Commentの部分に書き換えましたが変わらず。

URL:https://teratail.com/questions/182063

エラー内容

vagrant@homestead:~/code/laravel$ php artisan db:seed Seeding: PostsTableSeeder InvalidArgumentException : Unable to locate factory with name [default] [App\Post]. at /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php:269 265| */ 266| protected function getRawAttributes(array $attributes = []) 267| { 268| if (! isset($this->definitions[$this->class][$this->name])) { > 269| throw new InvalidArgumentException("Unable to locate factory with name [{$this->name}] [{$this->class}]."); 270| } 271| 272| $definition = call_user_func( 273| $this->definitions[$this->class][$this->name], Exception trace: 1 Illuminate\Database\Eloquent\FactoryBuilder::getRawAttributes([]) /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php:292 2 Illuminate\Database\Eloquent\FactoryBuilder::Illuminate\Database\Eloquent\{closure}() /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/GuardsAttributes.php:116 Please use the argument -v to see more details.

 

databaseSeeder

<?php use Illuminate\Database\Seeder; class DatabaseSeeder extends Seeder { /** * Seed the application's database. * * @return void */ public function run() { $this->call(PostsTableSeeder::class); } }

postTableSeeder

<?php use Illuminate\Database\Seeder; use App\Post; use App\Comment; class PostsTableSeeder extends Seeder { /** * Run the database seeds. * * @return void */ public function run() { factory(Post::class, 50) ->create() ->each(function ($post) { $comments = factory(App\Comment::class, 2)->make(); $post->comments()->saveMany($comments); }); } }

userfactory.php

<?php use Faker\Generator as Faker; $factory->define(App\Comment::class, function (Faker $faker) { return [ 'body' => "コメントです。テキストテキストテキストテキストテキストテキスト。\nテキストテキストテキストテキストテキストテキストテキストテキストテキストテキストテキストテキスト。", ]; });

postfactory.php

<?php use Faker\Generator as Faker; $factory->define(App\Post::class, function (Faker $faker) { return [ 'title' => '投稿のタイトル', 'body' => "本文です。テキストテキストテキストテキストテキストテキストテキストテキストテキストテキスト。\nテキストテキストテキストテキストテキストテキストテキストテキストテキストテキスト。テキストテキストテキストテキストテキストテキストテキストテキストテキストテキスト。", ]; });

__ ここから回答後の追記__

app/Post.php

<?php namespace App; use Illuminate\Database\Eloquent\Model; class Post extends Model { protected $fillable = [ 'title', 'body', ]; public function comments() { return $this->hasMany('App\Comment'); } }

###ディレクトリ構造

vagrant@homestead:~/code/laravel$ pwd /home/vagrant/code/laravel

###php artisan db:seed -v

vagrant@homestead:~/code/laravel$ php artisan db:seed -v Seeding: PostsTableSeeder InvalidArgumentException : Unable to locate factory with name [default] [App\Post]. at /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php:269 265| */ 266| protected function getRawAttributes(array $attributes = []) 267| { 268| if (! isset($this->definitions[$this->class][$this->name])) { > 269| throw new InvalidArgumentException("Unable to locate factory with name [{$this->name}] [{$this->class}]."); 270| } 271| 272| $definition = call_user_func( 273| $this->definitions[$this->class][$this->name], Exception trace: 1 Illuminate\Database\Eloquent\FactoryBuilder::getRawAttributes([]) /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php:292 2 Illuminate\Database\Eloquent\FactoryBuilder::Illuminate\Database\Eloquent\{closure}() /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/GuardsAttributes.php:116 3 Illuminate\Database\Eloquent\Model::unguarded(Object(Closure)) /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php:300 4 Illuminate\Database\Eloquent\FactoryBuilder::makeInstance([]) /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php:229 5 Illuminate\Database\Eloquent\FactoryBuilder::Illuminate\Database\Eloquent\{closure}() [internal]:0 6 array_map(Object(Closure)) /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php:230 7 Illuminate\Database\Eloquent\FactoryBuilder::make([]) /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php:178 8 Illuminate\Database\Eloquent\FactoryBuilder::create() /home/vagrant/code/laravel/database/seeds/PostsTableSeeder.php:17 9 PostsTableSeeder::run() /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php:32 10 call_user_func_array([]) /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php:32 11 Illuminate\Container\BoundMethod::Illuminate\Container\{closure}() /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php:90 12 Illuminate\Container\BoundMethod::callBoundMethod(Object(Illuminate\Foundation\Application), Object(Closure)) /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php:34 13 Illuminate\Container\BoundMethod::call(Object(Illuminate\Foundation\Application), []) /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Container/Container.php:576 14 Illuminate\Container\Container::call() /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Seeder.php:122 15 Illuminate\Database\Seeder::__invoke() /home/vagrant/code/laravel/vendor/laravel/framework/src/Illuminate/Database/Seeder.php:42

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2019/08/10 03:46 編集

とりあえずスペルが滅茶苦茶なので直してください ☓factry ☓psot ☓larael
Ms.yy

2019/08/10 03:52

失礼しました。 修正いたしました。
mikkame

2019/08/10 09:10

とりあえず Please use the argument -v to see more details. って書いてあるので書いてある通りにして結果を追記してください
Ms.yy

2019/08/10 09:30

下記のlaravelプロジェクトで実行しましたが、-bash: Please: command not foundと表示されてしまいました。???? vagrant@homestead:~/code/laravel$ pwd /home/vagrant/code/laravel
mikkame

2019/08/10 09:33

php artisan db:seedに-vをつけて実行したらさらに詳細なエラーが出てくるよ って書いてあるんですよ。
Ms.yy

2019/08/10 09:39

そういうことでしたか、失礼しました汗 エラー内容貼らせて頂きましたが、文字数が多くここでは全て記載することが無理でした。 残りのエラーは後16〜39までありました。
guest

回答1

0

ベストアンサー

composer dump-autoload は実行したでしょうか。

投稿2019/08/10 03:47

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Ms.yy

2019/08/10 03:52

はい、そちらを行いましたが変わらずエラーです。
退会済みユーザー

退会済みユーザー

2019/08/10 06:30

App/Postというモデルは確実に存在しているでしょうか? 存在する場合はモデルの内容も追記して下さい。
Ms.yy

2019/08/10 07:05

app/Post.php はい、存在しております。 追記させていただきました。 よろしくお願いいたします
退会済みユーザー

退会済みユーザー

2019/08/10 08:21

うーん、問題なさそうに見えますね。 composer dump-autoloadはエラー出ずに成功していますか? また、実行後のエラーは先ほどと全く同じですか?
退会済みユーザー

退会済みユーザー

2019/08/10 08:23

あと、未保存のファイルがないか確認して下さい。
Ms.yy

2019/08/10 08:31

composer dump-autoloadはエラー出ずに実行されております。 vagrant@homestead:~/code/laravel$ composer dump-autoload Generating optimized autoload files> Illuminate\Foundation\ComposerScripts::postAutoloadDump > @php artisan package:discover --ansi Discovered Package: beyondcode/laravel-dump-server Discovered Package: fideloper/proxy Discovered Package: laravel/tinker Discovered Package: nesbot/carbon Discovered Package: nunomaduro/collision Package manifest generated successfully. Generated optimized autoload files containing 3633 classes
Ms.yy

2019/08/10 08:32

その後artisan db:seed実行後も全く同じエラーです???? 未保存ファイルもございません・・・
退会済みユーザー

退会済みユーザー

2019/08/10 08:45

あと思いつくのは下記のキャッシュクリアを一通り試して頂くくらいですかね。 https://qiita.com/Ping/items/10ada8d069e13d729701 何か見落としているのかもしれませんがこれ以上わからなさそうです。
Ms.yy

2019/08/10 09:31

クリア後、もう一度見直してみます。 dyoshikawaさんいつもありがとうございます^^
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問