mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge pull request #8177 from creative-commoners/pulls/4.2/relative-fixture-fix
FIX SapphireTest can load relative fixtures in subfolders, switch "needs db" priority check order
This commit is contained in:
commit
9139db2a9d
@ -1191,16 +1191,10 @@ class SapphireTest extends PHPUnit_Framework_TestCase implements TestOnly
|
||||
|
||||
// Support fixture paths relative to the test class, rather than relative to webroot
|
||||
// String checking is faster than file_exists() calls.
|
||||
$isRelativeToFile
|
||||
= (strpos('/', $fixtureFilePath) === false)
|
||||
|| preg_match('/^(\.){1,2}/', $fixtureFilePath);
|
||||
|
||||
if ($isRelativeToFile) {
|
||||
$resolvedPath = realpath($this->getCurrentAbsolutePath() . '/' . $fixtureFilePath);
|
||||
if ($resolvedPath) {
|
||||
return $resolvedPath;
|
||||
}
|
||||
}
|
||||
|
||||
// Check if file exists relative to base dir
|
||||
$resolvedPath = realpath(Director::baseFolder() . '/' . $fixtureFilePath);
|
||||
|
@ -155,16 +155,10 @@ class FixtureTestState implements TestState
|
||||
{
|
||||
// Support fixture paths relative to the test class, rather than relative to webroot
|
||||
// String checking is faster than file_exists() calls.
|
||||
$isRelativeToFile
|
||||
= (strpos($fixtureFilePath, '/') === false)
|
||||
|| preg_match('/^(\.){1,2}/', $fixtureFilePath);
|
||||
|
||||
if ($isRelativeToFile) {
|
||||
$resolvedPath = realpath($this->getTestAbsolutePath($test) . '/' . $fixtureFilePath);
|
||||
if ($resolvedPath) {
|
||||
return $resolvedPath;
|
||||
}
|
||||
}
|
||||
|
||||
// Check if file exists relative to base dir
|
||||
$resolvedPath = realpath(Director::baseFolder() . '/' . $fixtureFilePath);
|
||||
@ -199,6 +193,17 @@ class FixtureTestState implements TestState
|
||||
*/
|
||||
protected function testNeedsDB(SapphireTest $test)
|
||||
{
|
||||
// test class explicitly enables DB
|
||||
if ($test->getUsesDatabase()) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// presence of fixture file implicitly enables DB
|
||||
$fixtures = $test::get_fixture_file();
|
||||
if (!empty($fixtures)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
$annotations = $test->getAnnotations();
|
||||
|
||||
// annotation explicitly disables the DB
|
||||
@ -213,17 +218,6 @@ class FixtureTestState implements TestState
|
||||
return true;
|
||||
}
|
||||
|
||||
// test class explicitly enables DB
|
||||
if ($test->getUsesDatabase()) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// presence of fixture file implicitly enables DB
|
||||
$fixtures = $test::get_fixture_file();
|
||||
if (!empty($fixtures)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user