mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
Merge pull request #3000 from creative-commoners/pulls/6/phpunit11
DEP Use PHPUnit 11
This commit is contained in:
commit
b30cb3e838
@ -30,7 +30,7 @@
|
||||
"silverstripe/vendor-plugin": "^2"
|
||||
},
|
||||
"require-dev": {
|
||||
"phpunit/phpunit": "^9.6",
|
||||
"phpunit/phpunit": "^11.3",
|
||||
"squizlabs/php_codesniffer": "^3.7",
|
||||
"silverstripe/standards": "^1",
|
||||
"phpstan/extension-installer": "^1.3"
|
||||
|
@ -619,14 +619,14 @@ class CMSMainTest extends FunctionalTest
|
||||
Security::setCurrentUser($user);
|
||||
$pageClass = array_values(SiteTree::page_type_classes())[0];
|
||||
$mockPageMissesCache = $this->getMockBuilder($pageClass)
|
||||
->setMethods(['canCreate'])
|
||||
->onlyMethods(['canCreate'])
|
||||
->getMock();
|
||||
$mockPageMissesCache
|
||||
->expects($this->exactly(3))
|
||||
->method('canCreate');
|
||||
|
||||
$mockPageHitsCache = $this->getMockBuilder($pageClass)
|
||||
->setMethods(['canCreate'])
|
||||
->onlyMethods(['canCreate'])
|
||||
->getMock();
|
||||
$mockPageHitsCache
|
||||
->expects($this->never())
|
||||
|
@ -157,7 +157,6 @@ class ContentControllerTest extends FunctionalTest
|
||||
/**
|
||||
* Tests that {@link ContentController::getViewer()} chooses the correct templates.
|
||||
*
|
||||
* @covers \SilverStripe\CMS\Controllers\ContentController::getViewer()
|
||||
**/
|
||||
public function testGetViewer()
|
||||
{
|
||||
|
@ -207,7 +207,6 @@ class ModelAsControllerTest extends FunctionalTest
|
||||
/**
|
||||
*
|
||||
* NOTE: This test requires nested_urls
|
||||
*
|
||||
*/
|
||||
public function testRedirectsNestedRenamedPagesWithGetParameters()
|
||||
{
|
||||
@ -225,7 +224,6 @@ class ModelAsControllerTest extends FunctionalTest
|
||||
/**
|
||||
*
|
||||
* NOTE: This test requires nested_urls
|
||||
*
|
||||
*/
|
||||
public function testDoesntRedirectToNestedRenamedPageWhenNewExists()
|
||||
{
|
||||
@ -255,7 +253,6 @@ class ModelAsControllerTest extends FunctionalTest
|
||||
/**
|
||||
*
|
||||
* NOTE: This test requires nested_urls
|
||||
*
|
||||
*/
|
||||
public function testFindOldPage()
|
||||
{
|
||||
|
@ -5,7 +5,7 @@ namespace SilverStripe\CMS\Tests\Controllers;
|
||||
use SilverStripe\CMS\Controllers\ContentController;
|
||||
use SilverStripe\Dev\TestOnly;
|
||||
|
||||
class SiteTreeTest_NamespaceMapTestController extends ContentController implements TestOnly
|
||||
class SiteTreeTest_NamespaceMapTestNodeController extends ContentController implements TestOnly
|
||||
{
|
||||
|
||||
}
|
@ -11,6 +11,7 @@ use SilverStripe\Assets\Dev\TestAssetStore;
|
||||
use SilverStripe\Control\Controller;
|
||||
use SilverStripe\Core\Config\Config;
|
||||
use SilverStripe\Dev\FunctionalTest;
|
||||
use PHPUnit\Framework\Attributes\DataProvider;
|
||||
|
||||
class RedirectorPageTest extends FunctionalTest
|
||||
{
|
||||
@ -61,7 +62,7 @@ class RedirectorPageTest extends FunctionalTest
|
||||
);
|
||||
}
|
||||
|
||||
public function provideEmptyRedirectors()
|
||||
public static function provideEmptyRedirectors()
|
||||
{
|
||||
return [
|
||||
'use 200' => [
|
||||
@ -73,9 +74,7 @@ class RedirectorPageTest extends FunctionalTest
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider provideEmptyRedirectors
|
||||
*/
|
||||
#[DataProvider('provideEmptyRedirectors')]
|
||||
public function testEmptyRedirectors(bool $use404)
|
||||
{
|
||||
Config::modify()->set(RedirectorPageController::class, 'missing_redirect_is_404', $use404);
|
||||
@ -181,7 +180,7 @@ class RedirectorPageTest extends FunctionalTest
|
||||
$this->assertStringContainsString("FileTest.txt", $page->Link());
|
||||
}
|
||||
|
||||
public function provideUnpublishedTarget()
|
||||
public static function provideUnpublishedTarget()
|
||||
{
|
||||
return [
|
||||
'use 200 with sitetree' => [
|
||||
@ -203,9 +202,7 @@ class RedirectorPageTest extends FunctionalTest
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider provideUnpublishedTarget
|
||||
*/
|
||||
#[DataProvider('provideUnpublishedTarget')]
|
||||
public function testUnpublishedTarget(bool $use404, bool $isFile)
|
||||
{
|
||||
Config::modify()->set(RedirectorPageController::class, 'missing_redirect_is_404', $use404);
|
||||
|
@ -11,6 +11,7 @@ use SilverStripe\Security\Security;
|
||||
use SilverStripe\SiteConfig\SiteConfig;
|
||||
use SilverStripe\Subsites\Extensions\SiteTreeSubsites;
|
||||
use SilverStripe\Versioned\Versioned;
|
||||
use PHPUnit\Framework\Attributes\DataProvider;
|
||||
|
||||
class SiteTreePermissionsTest extends FunctionalTest
|
||||
{
|
||||
@ -524,8 +525,8 @@ class SiteTreePermissionsTest extends FunctionalTest
|
||||
|
||||
/**
|
||||
* Test permissions on duplicate page
|
||||
* @dataProvider groupWithPermissions
|
||||
*/
|
||||
#[DataProvider('groupWithPermissions')]
|
||||
public function testDuplicatePageWithGroupPermissions(string $userName, string $method, bool $expected)
|
||||
{
|
||||
$originalPage = $this->objFromFixture(SiteTree::class, 'originalpage');
|
||||
@ -538,7 +539,7 @@ class SiteTreePermissionsTest extends FunctionalTest
|
||||
$this->assertSame($dupe->{$method}($user), $expected);
|
||||
}
|
||||
|
||||
public function groupWithPermissions(): array
|
||||
public static function groupWithPermissions(): array
|
||||
{
|
||||
return [
|
||||
'Subadmin can view page duplicate.' => [
|
||||
|
@ -8,11 +8,11 @@ use ReflectionMethod;
|
||||
use SilverStripe\CMS\Model\RedirectorPage;
|
||||
use SilverStripe\CMS\Model\SiteTree;
|
||||
use SilverStripe\CMS\Model\VirtualPage;
|
||||
use SilverStripe\CMS\Tests\Controllers\SiteTreeTest_NamespaceMapTestController;
|
||||
use SilverStripe\CMS\Tests\Controllers\SiteTreeTest_NamespaceMapTestNodeController;
|
||||
use SilverStripe\CMS\Tests\CMSEditLinkExtensionTest\BelongsToPage;
|
||||
use SilverStripe\CMS\Tests\CMSEditLinkExtensionTest\PageWithChild;
|
||||
use SilverStripe\CMS\Tests\Model\SiteTreeBrokenLinksTest\NotPageObject;
|
||||
use SilverStripe\CMS\Tests\Page\SiteTreeTest_NamespaceMapTest;
|
||||
use SilverStripe\CMS\Tests\Page\SiteTreeTest_NamespaceMapTestNode;
|
||||
use SilverStripe\Control\ContentNegotiator;
|
||||
use SilverStripe\Control\Controller;
|
||||
use SilverStripe\Control\Director;
|
||||
@ -42,6 +42,7 @@ use Page;
|
||||
use PageController;
|
||||
|
||||
use const RESOURCES_DIR;
|
||||
use PHPUnit\Framework\Attributes\DataProvider;
|
||||
|
||||
class SiteTreeTest extends SapphireTest
|
||||
{
|
||||
@ -71,7 +72,7 @@ class SiteTreeTest extends SapphireTest
|
||||
NotPageObject::class,
|
||||
];
|
||||
|
||||
public function reservedSegmentsProvider()
|
||||
public static function reservedSegmentsProvider()
|
||||
{
|
||||
return [
|
||||
// segments reserved by rules
|
||||
@ -142,8 +143,8 @@ class SiteTreeTest extends SapphireTest
|
||||
|
||||
/**
|
||||
* Check if reserved URL's are properly appended with a number at top level
|
||||
* @dataProvider reservedSegmentsProvider
|
||||
*/
|
||||
#[DataProvider('reservedSegmentsProvider')]
|
||||
public function testDisallowedURLGeneration($title, $urlSegment)
|
||||
{
|
||||
$page = new SiteTree(['Title' => $title]);
|
||||
@ -155,8 +156,8 @@ class SiteTreeTest extends SapphireTest
|
||||
/**
|
||||
* Check if reserved URL's are not appended with a number on a child page
|
||||
* It's okay to have a URL like domain.com/my-page/admin as it won't interfere with domain.com/admin
|
||||
* @dataProvider reservedSegmentsProvider
|
||||
*/
|
||||
#[DataProvider('reservedSegmentsProvider')]
|
||||
public function testDisallowedChildURLGeneration($title, $urlSegment)
|
||||
{
|
||||
// Using the same dataprovider, strip out the -2 from the admin and dev segment
|
||||
@ -1092,9 +1093,6 @@ class SiteTreeTest extends SapphireTest
|
||||
i18n::set_locale($oldLocale);
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers \SilverStripe\CMS\Model\SiteTree::validURLSegment
|
||||
*/
|
||||
public function testValidURLSegmentURLSegmentConflicts()
|
||||
{
|
||||
$sitetree = new SiteTree();
|
||||
@ -1124,9 +1122,6 @@ class SiteTreeTest extends SapphireTest
|
||||
$this->assertTrue($sitetree->validURLSegment());
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers \SilverStripe\CMS\Model\SiteTree::validURLSegment
|
||||
*/
|
||||
public function testValidURLSegmentClassNameConflicts()
|
||||
{
|
||||
$sitetree = new SiteTree();
|
||||
@ -1135,9 +1130,6 @@ class SiteTreeTest extends SapphireTest
|
||||
$this->assertTrue($sitetree->validURLSegment(), 'Class names are no longer conflicts');
|
||||
}
|
||||
|
||||
/**
|
||||
* @covers \SilverStripe\CMS\Model\SiteTree::validURLSegment
|
||||
*/
|
||||
public function testValidURLSegmentControllerConflicts()
|
||||
{
|
||||
Config::modify()->set(SiteTree::class, 'nested_urls', true);
|
||||
@ -1273,11 +1265,11 @@ class SiteTreeTest extends SapphireTest
|
||||
|
||||
/**
|
||||
* Tests that various types of SiteTree classes will or will not be returned from the allowedChildren method
|
||||
* @dataProvider allowedChildrenProvider
|
||||
* @param string $className
|
||||
* @param array $expected
|
||||
* @param string $assertionMessage
|
||||
*/
|
||||
#[DataProvider('allowedChildrenProvider')]
|
||||
public function testAllowedChildren($className, $expected, $assertionMessage)
|
||||
{
|
||||
$class = new $className;
|
||||
@ -1287,7 +1279,7 @@ class SiteTreeTest extends SapphireTest
|
||||
/**
|
||||
* @return array
|
||||
*/
|
||||
public function allowedChildrenProvider()
|
||||
public static function allowedChildrenProvider()
|
||||
{
|
||||
return [
|
||||
[
|
||||
@ -1525,7 +1517,7 @@ class SiteTreeTest extends SapphireTest
|
||||
$charset = Config::inst()->get(ContentNegotiator::class, 'encoding');
|
||||
|
||||
$mockVersionProvider = $this->getMockBuilder(VersionProvider::class)
|
||||
->setMethods(['getModuleVersion'])
|
||||
->onlyMethods(['getModuleVersion'])
|
||||
->getMock();
|
||||
$mockVersionProvider->method('getModuleVersion')->willReturn('4.50.99');
|
||||
$page->setVersionProvider($mockVersionProvider);
|
||||
@ -1752,8 +1744,8 @@ class SiteTreeTest extends SapphireTest
|
||||
'SilverStripe\\CMS\\Tests\\Page' => 'SilverStripe\\CMS\\Tests\\Controllers',
|
||||
]);
|
||||
|
||||
$namespacedSiteTree = new SiteTreeTest_NamespaceMapTest();
|
||||
$this->assertSame(SiteTreeTest_NamespaceMapTestController::class, $namespacedSiteTree->getControllerName());
|
||||
$namespacedSiteTree = new SiteTreeTest_NamespaceMapTestNode();
|
||||
$this->assertSame(SiteTreeTest_NamespaceMapTestNodeController::class, $namespacedSiteTree->getControllerName());
|
||||
}
|
||||
|
||||
public function testTreeTitleCache()
|
||||
@ -1764,14 +1756,14 @@ class SiteTreeTest extends SapphireTest
|
||||
$pageClass = array_values(SiteTree::page_type_classes())[0];
|
||||
|
||||
$mockPageMissesCache = $this->getMockBuilder($pageClass)
|
||||
->setMethods(['canCreate'])
|
||||
->onlyMethods(['canCreate'])
|
||||
->getMock();
|
||||
$mockPageMissesCache
|
||||
->expects($this->exactly(3))
|
||||
->method('canCreate');
|
||||
|
||||
$mockPageHitsCache = $this->getMockBuilder($pageClass)
|
||||
->setMethods(['canCreate'])
|
||||
->onlyMethods(['canCreate'])
|
||||
->getMock();
|
||||
$mockPageHitsCache
|
||||
->expects($this->never())
|
||||
@ -2092,9 +2084,7 @@ class SiteTreeTest extends SapphireTest
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider provideSanitiseExtraMeta
|
||||
*/
|
||||
#[DataProvider('provideSanitiseExtraMeta')]
|
||||
public function testSanitiseExtraMeta(string $extraMeta, string $expected, string $message): void
|
||||
{
|
||||
$siteTree = new SiteTree();
|
||||
@ -2103,7 +2093,7 @@ class SiteTreeTest extends SapphireTest
|
||||
$this->assertSame($expected, $siteTree->ExtraMeta, $message);
|
||||
}
|
||||
|
||||
public function provideSanitiseExtraMeta(): array
|
||||
public static function provideSanitiseExtraMeta(): array
|
||||
{
|
||||
return [
|
||||
[
|
||||
|
@ -5,7 +5,7 @@ namespace SilverStripe\CMS\Tests\Page;
|
||||
use SilverStripe\CMS\Model\SiteTree;
|
||||
use SilverStripe\Dev\TestOnly;
|
||||
|
||||
class SiteTreeTest_NamespaceMapTest extends SiteTree implements TestOnly
|
||||
class SiteTreeTest_NamespaceMapTestNode extends SiteTree implements TestOnly
|
||||
{
|
||||
private static $table_name = 'SiteTreeTest_NamespaceMapTestNode';
|
||||
}
|
@ -287,9 +287,6 @@ class ZZZSearchFormTest extends FunctionalTest
|
||||
Security::setCurrentUser(null);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
public function testInheritedRestrictedPagesNotIncluded()
|
||||
{
|
||||
$request = new HTTPRequest('GET', 'search', ['Search'=>'inheritRestrictedView']);
|
||||
|
Loading…
Reference in New Issue
Block a user