From 422857f3812393d59594cd5d426271f062b57ae4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Werner=20M=2E=20Krau=C3=9F?= Date: Tue, 17 Oct 2017 09:22:11 +0200 Subject: [PATCH] SapphireTestTest: use named data providers and more error messages * use keys for naming each data set * adding error messages * clean up a bit --- tests/php/Dev/SapphireTestTest.php | 93 +++++++---- .../php/Dev/SapphireTestTest/DataProvider.php | 158 +++++++++--------- 2 files changed, 137 insertions(+), 114 deletions(-) diff --git a/tests/php/Dev/SapphireTestTest.php b/tests/php/Dev/SapphireTestTest.php index 09043fa79..a29e75821 100644 --- a/tests/php/Dev/SapphireTestTest.php +++ b/tests/php/Dev/SapphireTestTest.php @@ -16,25 +16,38 @@ class SapphireTestTest extends SapphireTest public function provideResolveFixturePath() { return [ - [__DIR__ . '/CsvBulkLoaderTest.yml', './CsvBulkLoaderTest.yml'], - //same dir - [__DIR__ . '/CsvBulkLoaderTest.yml', 'CsvBulkLoaderTest.yml'], - // Filename only - [dirname(__DIR__) . '/ORM/DataObjectTest.yml', '../ORM/DataObjectTest.yml'], - // Parent path - [dirname(__DIR__) . '/ORM/DataObjectTest.yml', dirname(__DIR__) . '/ORM/DataObjectTest.yml'], - // Absolute path + 'sameDirectory' => [ + __DIR__ . '/CsvBulkLoaderTest.yml', + './CsvBulkLoaderTest.yml', + 'Could not resolve fixture path relative from same directory', + ], + 'filenameOnly' => [ + __DIR__ . '/CsvBulkLoaderTest.yml', + 'CsvBulkLoaderTest.yml', + 'Could not resolve fixture path from filename only', + ], + 'parentPath' => [ + dirname(__DIR__) . '/ORM/DataObjectTest.yml', + '../ORM/DataObjectTest.yml', + 'Could not resolve fixture path from parent path', + ], + 'absolutePath' => [ + dirname(__DIR__) . '/ORM/DataObjectTest.yml', + dirname(__DIR__) . '/ORM/DataObjectTest.yml', + 'Could not relsolve fixture path from absolute path', + ], ]; } /** * @dataProvider provideResolveFixturePath */ - public function testResolveFixturePath($expected, $path) + public function testResolveFixturePath($expected, $path, $message) { $this->assertEquals( $expected, - $this->resolveFixturePath($path) + $this->resolveFixturePath($path), + $message ); } @@ -46,10 +59,10 @@ class SapphireTestTest extends SapphireTest $this->logOut(); $this->assertFalse(Permission::check('ADMIN')); $this->actWithPermission('ADMIN', function () { - $this->assertTrue(Permission::check('ADMIN')); + $this->assertTrue(Permission::check('ADMIN'), 'Member should now have ADMIN role'); // check nested actAs calls work as expected Member::actAs(null, function () { - $this->assertFalse(Permission::check('ADMIN')); + $this->assertFalse(Permission::check('ADMIN'), 'Member should not act as ADMIN any more after reset'); }); }); } @@ -59,9 +72,16 @@ class SapphireTestTest extends SapphireTest */ public function testCreateMemberWithPermission() { - $this->assertCount(0, Member::get()->filter(['Email' => 'TESTPERM@example.org'])); + $this->assertEmpty( + Member::get()->filter(['Email' => 'TESTPERM@example.org']), + 'DB should not have the test member created when the test starts' + ); $this->createMemberWithPermission('TESTPERM'); - $this->assertCount(1, Member::get()->filter(['Email' => 'TESTPERM@example.org'])); + $this->assertCount( + 1, + Member::get()->filter(['Email' => 'TESTPERM@example.org']), + 'Database should now contain the test member' + ); } /** @@ -69,13 +89,30 @@ class SapphireTestTest extends SapphireTest * * @param $match * @param $itemsForList + * * @testdox Has assertion assertListAllMatch */ - public function testAssertListAllMatch($match, $itemsForList) + public function testAssertListAllMatch($match, $itemsForList, $message) { $list = $this->generateArrayListFromItems($itemsForList); - $this->assertListAllMatch($match, $list); + $this->assertListAllMatch($match, $list, $message); + } + + /** + * generate SS_List as this is not possible in dataProvider + * + * @param array $itemsForList + * + * @return ArrayList + */ + private function generateArrayListFromItems($itemsForList) + { + $list = ArrayList::create(); + foreach ($itemsForList as $data) { + $list->push(Member::create($data)); + } + return $list; } /** @@ -100,6 +137,7 @@ class SapphireTestTest extends SapphireTest * * @param $matches * @param $itemsForList + * * @testdox Has assertion assertListContains */ public function testAssertListContains($matches, $itemsForList) @@ -109,7 +147,7 @@ class SapphireTestTest extends SapphireTest $list->push(Member::create(['FirstName' => 'Bar', 'Surname' => 'Bar'])); $list->push(Member::create(['FirstName' => 'Baz', 'Surname' => 'Baz'])); - $this->assertListContains($matches, $list); + $this->assertListContains($matches, $list, 'The list does not contain the expected items'); } /** @@ -143,7 +181,7 @@ class SapphireTestTest extends SapphireTest { $list = $this->generateArrayListFromItems($itemsForList); - $this->assertListNotContains($matches, $list); + $this->assertListNotContains($matches, $list, 'List contains forbidden items'); } /** @@ -151,6 +189,7 @@ class SapphireTestTest extends SapphireTest * * @param $matches * @param $itemsForList + * * @testdox assertion assertListNotContains throws a exception when a matching item is found in the list * * @expectedException \PHPUnit_Framework_ExpectationFailedException @@ -165,7 +204,6 @@ class SapphireTestTest extends SapphireTest $this->assertListNotContains($matches, $list); } - /** * @dataProvider \SilverStripe\Dev\Tests\SapphireTestTest\DataProvider::provideEqualListsWithEmptyList() * @testdox Has assertion assertListEquals @@ -177,7 +215,7 @@ class SapphireTestTest extends SapphireTest { $list = $this->generateArrayListFromItems($itemsForList); - $this->assertListEquals($matches, $list); + $this->assertListEquals($matches, $list, 'Lists do not equal'); } /** @@ -195,19 +233,4 @@ class SapphireTestTest extends SapphireTest $this->assertListEquals($matches, $list); } - - /** - * generate SS_List as this is not possible in dataProvider - * - * @param $itemsForList array - * @return ArrayList - */ - private function generateArrayListFromItems($itemsForList) - { - $list = ArrayList::create(); - foreach ($itemsForList as $data) { - $list->push(Member::create($data)); - } - return $list; - } } diff --git a/tests/php/Dev/SapphireTestTest/DataProvider.php b/tests/php/Dev/SapphireTestTest/DataProvider.php index 575808654..c54ea33ea 100644 --- a/tests/php/Dev/SapphireTestTest/DataProvider.php +++ b/tests/php/Dev/SapphireTestTest/DataProvider.php @@ -7,12 +7,17 @@ use SilverStripe\Dev\TestOnly; class DataProvider implements TestOnly { protected static $oneItemList = [ - ['FirstName' => 'Ingo', 'Surname' => 'Schommer'] + ['FirstName' => 'Ingo', 'Surname' => 'Schommer'], ]; protected static $twoItemList = [ ['FirstName' => 'Ingo', 'Surname' => 'Schommer'], - ['FirstName' => 'Sam', 'Surname' => 'Minnee'] + ['FirstName' => 'Sam', 'Surname' => 'Minnee'], + ]; + + protected static $memberList = [ + ['FirstName' => 'Ingo', 'Surname' => 'Schommer', 'Locale' => 'en_US'], + ['FirstName' => 'Sam', 'Surname' => 'Minnee', 'Locale' => 'en_US'], ]; /** @@ -21,11 +26,11 @@ class DataProvider implements TestOnly public static function provideEqualListsWithEmptyList() { return array_merge( - [ //empty list - [ + [ + 'emptyLists' => [ [], - [] - ] + [], + ], ], self::provideEqualLists() ); @@ -38,37 +43,37 @@ class DataProvider implements TestOnly { return [ [ - [ //one param - ['FirstName' => 'Ingo'] - ], - self::$oneItemList - ], - [ - [ //two params - ['FirstName' => 'Ingo', 'Surname' => 'Schommer'] - ], - self::$oneItemList - ], - [ //only one param - [ + 'oneParameterOneItem' => [ ['FirstName' => 'Ingo'], - ['FirstName' => 'Sam'] ], - self::$twoItemList + self::$oneItemList, ], [ - [ //two params + 'twoParametersOneItem' => [ ['FirstName' => 'Ingo', 'Surname' => 'Schommer'], - ['FirstName' => 'Sam', 'Surname' => 'Minnee'] ], - self::$twoItemList + self::$oneItemList, ], [ - [ //mixed - ['FirstName' => 'Ingo', 'Surname' => 'Schommer'], - ['FirstName' => 'Sam'] + 'oneParameterTwoItems' => [ + ['FirstName' => 'Ingo'], + ['FirstName' => 'Sam'], ], - self::$twoItemList + self::$twoItemList, + ], + [ + 'twoParametersTwoItems' => [ + ['FirstName' => 'Ingo', 'Surname' => 'Schommer'], + ['FirstName' => 'Sam', 'Surname' => 'Minnee'], + ], + self::$twoItemList, + ], + [ + 'mixedParametersTwoItems' => [ + ['FirstName' => 'Ingo', 'Surname' => 'Schommer'], + ['FirstName' => 'Sam'], + ], + self::$twoItemList, ], ]; } @@ -80,40 +85,38 @@ class DataProvider implements TestOnly { return [ - [ //empty list - [ - ['FirstName' => 'Ingo'] + [ + 'checkAgainstEmptyList' => [ + ['FirstName' => 'Ingo'], ], - [] + [], ], [ - [ //one item expected - ['FirstName' => 'Ingo'] - ] - , - self::$twoItemList + 'oneItemExpectedListContainsMore' => [ + ['FirstName' => 'Ingo'], + ], + self::$twoItemList, ], - [ //one item with wrong param - [ + [ + 'oneExpectationHasWrontParamter' => [ ['FirstName' => 'IngoXX'], - ['FirstName' => 'Sam'] - ] - , - self::$twoItemList + ['FirstName' => 'Sam'], + ], + self::$twoItemList, ], [ - [ //two params wrong + 'differentParametersInDifferentItemsAreWrong' => [ ['FirstName' => 'IngoXXX', 'Surname' => 'Schommer'], - ['FirstName' => 'Sam', 'Surname' => 'MinneeXXX'] + ['FirstName' => 'Sam', 'Surname' => 'MinneeXXX'], ], - self::$twoItemList + self::$twoItemList, ], [ - [ //mixed + 'differentParametersNotMatching' => [ ['FirstName' => 'Daniel', 'Surname' => 'Foo'], - ['FirstName' => 'Dan'] + ['FirstName' => 'Dan'], ], - self::$twoItemList + self::$twoItemList, ], ]; } @@ -124,32 +127,31 @@ class DataProvider implements TestOnly public static function provideNotContainingList() { return [ - [ //empty list + 'listIsEmpty' => [ [ - ['FirstName' => 'Ingo'] + ['FirstName' => 'Ingo'], ], - [] + [], ], - [ - [ //one item expected - ['FirstName' => 'Sam'] - ] - , - self::$oneItemList + 'oneItemIsExpected' => [ + [ + ['FirstName' => 'Sam'], + ], + self::$oneItemList, ], - [ - [ //two params wrong + 'twoParametersAreWrong' => [ + [ ['FirstName' => 'IngoXXX', 'Surname' => 'Schommer'], - ['FirstName' => 'Sam', 'Surname' => 'MinneeXXX'] + ['FirstName' => 'Sam', 'Surname' => 'MinneeXXX'], ], - self::$twoItemList + self::$twoItemList, ], - [ - [ //mixed + 'mixedList' => [ + [ ['FirstName' => 'Daniel', 'Surname' => 'Foo'], - ['FirstName' => 'Dan'] + ['FirstName' => 'Dan'], ], - self::$twoItemList + self::$twoItemList, ], ]; } @@ -159,14 +161,17 @@ class DataProvider implements TestOnly */ public static function provideAllMatchingList() { - $list = [ - ['FirstName' => 'Ingo', 'Surname' => 'Schommer', 'Locale' => 'en_US'], - ['FirstName' => 'Sam', 'Surname' => 'Minnee', 'Locale' => 'en_US'] - ]; - return [ - [[], $list], //empty match - [['Locale' => 'en_US'], $list] //all items have this field set + 'emptyMatch' => [ + [], + self::$memberList, + 'empty list did not match', + ], + 'allItemsWithLocaleSet' => [ + ['Locale' => 'en_US'], + self::$memberList, + 'list with Locale set in all items did not match', + ], ]; } @@ -175,13 +180,8 @@ class DataProvider implements TestOnly */ public static function provideNotMatchingList() { - $list = [ - ['FirstName' => 'Ingo', 'Surname' => 'Schommer', 'Locale' => 'en_US'], - ['FirstName' => 'Sam', 'Surname' => 'Minnee', 'Locale' => 'en_US'] - ]; - return [ - [['FirstName' => 'Ingo'], $list] //not all items have this field set + 'notAllItemsHaveLocaleSet' => [['FirstName' => 'Ingo'], self::$memberList], ]; } }