tills98

tills98

Member Since 2 Weeks Ago

Experience Points
100
Total
Experience

4,900 experience to go until the next level!

In case you were wondering, you earn Laracasts experience when you:

  • Complete a lesson — 100pts
  • Create a forum thread — 50pts
  • Reply to a thread — 10pts
  • Leave a reply that is liked — 50pts
  • Receive a "Best Reply" award — 500pts
Lessons Completed
0
Lessons
Completed
Best Reply Awards
0
Best Reply
Awards
  • start your engines Created with Sketch.

    Start Your Engines

    Earned once you have completed your first Laracasts lesson.

  • first-thousand Created with Sketch.

    First Thousand

    Earned once you have earned your first 1000 experience points.

  • 1-year Created with Sketch.

    One Year Member

    Earned when you have been with Laracasts for 1 year.

  • 2-years Created with Sketch.

    Two Year Member

    Earned when you have been with Laracasts for 2 years.

  • 3-years Created with Sketch.

    Three Year Member

    Earned when you have been with Laracasts for 3 years.

  • 4-years Created with Sketch.

    Four Year Member

    Earned when you have been with Laracasts for 4 years.

  • 5-years Created with Sketch.

    Five Year Member

    Earned when you have been with Laracasts for 5 years.

  • school-in-session Created with Sketch.

    School In Session

    Earned when at least one Laracasts series has been fully completed.

  • welcome-newcomer Created with Sketch.

    Welcome To The Community

    Earned after your first post on the Laracasts forum.

  • full-time-student Created with Sketch.

    Full Time Learner

    Earned once 100 Laracasts lessons have been completed.

  • pay-it-forward Created with Sketch.

    Pay It Forward

    Earned once you receive your first "Best Reply" award on the Laracasts forum.

  • subscriber Created with Sketch.

    Subscriber

    Earned if you are a paying Laracasts subscriber.

  • lifer Created with Sketch.

    Lifer

    Earned if you have a lifetime subscription to Laracasts.

  • evangelist Created with Sketch.

    Laracasts Evangelist

    Earned if you share a link to Laracasts on social media. Please email [email protected] with your username and post URL to be awarded this badge.

  • chatty-cathy Created with Sketch.

    Chatty Cathy

    Earned once you have achieved 500 forum replies.

  • lara-veteran Created with Sketch.

    Laracasts Veteran

    Earned once your experience points passes 100,000.

  • 10k-strong Created with Sketch.

    Ten Thousand Strong

    Earned once your experience points hits 10,000.

  • lara-master Created with Sketch.

    Laracasts Master

    Earned once 1000 Laracasts lessons have been completed.

  • laracasts-tutor Created with Sketch.

    Laracasts Tutor

    Earned once your "Best Reply" award count is 100 or more.

  • laracasts-sensei Created with Sketch.

    Laracasts Sensei

    Earned once your experience points passes 1 million.

  • top-50 Created with Sketch.

    Top 50

    Earned once your experience points ranks in the top 50 of all Laracasts users.

Level 1
100 XP
Mar
26
1 week ago
Activity icon

Started a new Conversation General Error: 1 No Such Table: Main.id (SQL: Insert Into "sessions"...)

I've got a very scary exception on my unit test for a simple insert by a simple factory

Illuminate\Database\QueryException : SQLSTATE[HY000]: General error: 1 no such table: main.id (SQL: insert into "sessions" ("title", "order", "start_screen", "overview_screen", "journey_id", "updated_at", "created_at") values (vero, 8, nostrum, reiciendis, 1, 2020-03-26 19:58:35, 2020-03-26 19:58:35))

My unit test:

class SessionTest extends TestCase
{
    use DatabaseMigrations, RefreshDatabase;

    /**
     * A basic unit test example.
     *
     * @return void
     */
    public function testSession()
    {
        /** @var Journey $journey */
        $journey = factory(Journey::class)->create();
        /** @var Session $session */
        $session = factory(Session::class)->create([ 'journey_id' => $journey->id ]);

        $this->assertTrue(true);
    }
}

My Session model

class Session extends Model
{

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    public $fillable = [
        'title',
        'order',
        'start_screen',
        'overview_screen'
    ];

    /**
     * Journey of session
     *
     * @return \Illuminate\Database\Eloquent\Relations\BelongsTo
     */
    public function journey() {
        return $this->belongsTo(Journey::class, 'journeys');
    }
}

My Session factory

$factory->define(\App\Session::class, function (Faker $faker) {
    return [
        'title' => $faker->word,
        'order' => $faker->numberBetween(0, 10),
        'start_screen' => $faker->word,
        'overview_screen' => $faker->word,
    ];
});

My sessions schema:

class CreateSessionsTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('sessions', function (Blueprint $table) {
            $table->integer('id')->autoIncrement();
            $table->integer('journey_id')->unsigned();
            $table->string('title');
            $table->integer('order')->unsigned();
            $table->integer('start_screen')->nullable();
            $table->integer('overview_screen')->nullable();
            $table->timestamps();

            $table->foreign('journey_id')->references('journeys')->on('id');
        });
}

The factory for my model Journey works perfectly.

I don't know why this factory is searching for table "main". Do you know what this means?

Mar
19
2 weeks ago
Activity icon

Started a new Conversation Laravel 7 Default Database Connection Invalid

At the beginning of developing i've problems with selecting rows in database tables that are not found by larave with

DB::query('select * from mytable');

or

DB::table('mytable')->select('*')->get();

I have found out through unit tests that laravel uses sqlite as default database connection instead of mysql. My settings in .env file are not imported correctly into conf/database.php. My .env contents:

...
DB_CONNECTION=mysql
DB_HOST=172.22.0.4
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=default
DB_PASSWORD=secret
...

The connection to my mysql database works fine when i test it with MySQL Workbench or other programs.

Here is my unit test:

public function testDefaultConnectionSettings()
    {
        $this->assertEquals('mysql', DB::getDefaultConnection());
    }

Is this an known issue in laravel 7? I'm running laravel 7 in laradock on MacOS Catalina.