Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[5.5] Reset RefreshDatabaseState after DatabaseMigrations rolls back #21325

Merged
merged 2 commits into from
Sep 25, 2017

Conversation

inxilpro
Copy link
Contributor

If you mix DatabaseMigrations and RefreshDatabase (for example if you're running some Dusk tests and some regular tests), you may run into a state where RefreshDatabaseState::$migrated is set to true but the database has been rolled back (eg. if you run a refresh test, followed by a migration test, followed by another refresh test). This addresses that edge case.

@inxilpro
Copy link
Contributor Author

In the interim, if anyone else runs into this, you can add the following to your TestCase class:

<?php

namespace Tests;

use Illuminate\Foundation\Testing\DatabaseMigrations;
use Illuminate\Foundation\Testing\RefreshDatabaseState;
use Illuminate\Foundation\Testing\TestCase as BaseTestCase;
use Tests\Traits\CreatesApplication;

abstract class TestCase extends BaseTestCase
{
    use CreatesApplication;

    protected function setUpTraits()
    {
        $uses = parent::setUpTraits();

        if (isset($uses[DatabaseMigrations::class])) {
            $this->beforeApplicationDestroyed(function () {
                RefreshDatabaseState::$migrated = false;
            });
        }

        return $uses;
    }
}

@GrahamCampbell GrahamCampbell changed the title Reset RefreshDatabaseState after DatabaseMigrations rolls back [5.5] Reset RefreshDatabaseState after DatabaseMigrations rolls back Sep 21, 2017
@taylorotwell
Copy link
Member

Hmm, can you provide more info as to why you would ever combine the two on one test class?

@inxilpro
Copy link
Contributor Author

That static migrated flag persists across test cases. So if you have three files, two that use the refresh trait and one that uses the migration trait, you can run into this issue.

@inxilpro
Copy link
Contributor Author

The issue turns up when you have at least three separate TestCases: two that use the RefreshDatabase trait and one that uses DatabaseMigrations. For example:

ATest.php

class ATest extends TestCase
{
  use Illuminate\Foundation\Testing\RefreshDatabase;
  // ...
}

BTest.php

class BTest extends DuskTestCase
{
  // Since Dusk test cases run in a separate process from the application
  // under test, you usually can't use RefreshDatabase (since none of the data
  // in the DB transaction will be visible to the app process).
  use Illuminate\Foundation\Testing\DatabaseMigrations;
  // ...
}

CTest.php

class CTest extends TestCase
{
  use Illuminate\Foundation\Testing\RefreshDatabase;
  // ...
}

When I run my tests:

  1. ATest will call migrate:fresh and set RefreshDatabaseState::$migrated to true.
  2. BTest will call migrate:fresh and then migrate:rollback.
  3. CTest will skip migrate:fresh because RefreshDatabaseState::$migrated will still be set to true from ATest, and it will fail because the database will have been rolled back by BTest.

@deleugpn
Copy link
Contributor

Why are you runing BTest in the same process as ATest and CTest? php artisan dusk is suppose to be separated from ./vendor/bin/phpunit

@inxilpro
Copy link
Contributor Author

OK, maybe that’s not the best example. In our case we have legacy systems that use MyISAM tables (which don’t support transactions). A few tests still run DatabaseMigrations because of this, but most work/we’ve made work with RefreshDatabase. It’s definitely an edge case, but the fix is a single line and breaks nothing.

@taylorotwell taylorotwell merged commit 4f81a2f into laravel:5.5 Sep 25, 2017
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants