2011-10-28 10:45:12 +13:00
|
|
|
<?php
|
|
|
|
|
2016-10-14 14:30:05 +13:00
|
|
|
namespace SilverStripe\Dev\Tests;
|
|
|
|
|
2022-10-31 19:00:59 +13:00
|
|
|
use PHPUnit\Framework\Error\Deprecated;
|
2023-02-21 14:41:02 +13:00
|
|
|
use ReflectionMethod;
|
2023-11-22 09:30:08 +13:00
|
|
|
use ReflectionProperty;
|
2022-10-31 19:00:59 +13:00
|
|
|
use SilverStripe\Core\Config\Config;
|
2023-02-21 14:41:02 +13:00
|
|
|
use SilverStripe\Core\Environment;
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Dev\Deprecation;
|
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2024-09-18 13:53:44 +12:00
|
|
|
use SilverStripe\Dev\Tests\DeprecationTest\DeprecationTestException;
|
2022-10-31 19:00:59 +13:00
|
|
|
use SilverStripe\Dev\Tests\DeprecationTest\DeprecationTestObject;
|
2022-11-15 18:20:54 +13:00
|
|
|
use SilverStripe\Core\Injector\Injector;
|
2023-11-22 09:30:08 +13:00
|
|
|
use SilverStripe\Core\Kernel;
|
2024-09-18 13:53:44 +12:00
|
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
|
|
|
use PHPUnit\Framework\Attributes\DoesNotPerformAssertions;
|
2011-10-28 10:45:12 +13:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
class DeprecationTest extends SapphireTest
|
|
|
|
{
|
2022-10-31 19:00:59 +13:00
|
|
|
protected static $extra_dataobjects = [
|
|
|
|
DeprecationTestObject::class,
|
|
|
|
];
|
|
|
|
|
|
|
|
private $oldHandler = null;
|
|
|
|
|
2022-11-15 18:20:54 +13:00
|
|
|
private bool $noticesWereEnabled = false;
|
|
|
|
|
2024-10-21 10:20:44 +13:00
|
|
|
private bool $showSupportedNoticesWasEnabled = false;
|
|
|
|
|
2022-10-31 19:00:59 +13:00
|
|
|
protected function setup(): void
|
|
|
|
{
|
|
|
|
// Use custom error handler for two reasons:
|
2023-02-21 14:41:02 +13:00
|
|
|
// - Filter out errors for deprecated class properties unrelated to this unit test
|
2024-09-18 13:53:44 +12:00
|
|
|
// - Allow the use of expectException(), which doesn't work with E_USER_DEPRECATION by default
|
2022-10-31 19:00:59 +13:00
|
|
|
// https://github.com/laminas/laminas-di/pull/30#issuecomment-927585210
|
|
|
|
parent::setup();
|
2022-11-15 18:20:54 +13:00
|
|
|
$this->noticesWereEnabled = Deprecation::isEnabled();
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->showSupportedNoticesWasEnabled = Deprecation::getShowNoticesCalledFromSupportedCode();
|
2022-10-31 19:00:59 +13:00
|
|
|
$this->oldHandler = set_error_handler(function (int $errno, string $errstr, string $errfile, int $errline) {
|
2022-11-02 11:40:34 +13:00
|
|
|
if ($errno === E_USER_DEPRECATED) {
|
|
|
|
if (str_contains($errstr, 'SilverStripe\\Dev\\Tests\\DeprecationTest')) {
|
2024-09-18 13:53:44 +12:00
|
|
|
throw new DeprecationTestException($errstr);
|
2022-11-02 11:40:34 +13:00
|
|
|
} else {
|
2023-02-21 14:41:02 +13:00
|
|
|
// Suppress any E_USER_DEPRECATED unrelated to this unit-test
|
2022-11-02 11:40:34 +13:00
|
|
|
return true;
|
|
|
|
}
|
2022-10-31 19:00:59 +13:00
|
|
|
}
|
|
|
|
if (is_callable($this->oldHandler)) {
|
|
|
|
return call_user_func($this->oldHandler, $errno, $errstr, $errfile, $errline);
|
|
|
|
}
|
2022-11-02 11:40:34 +13:00
|
|
|
// Fallback to default PHP error handler
|
2022-10-31 19:00:59 +13:00
|
|
|
return false;
|
|
|
|
});
|
2024-10-21 10:20:44 +13:00
|
|
|
// This is required to clear out the notice from instantiating DeprecationTestObject in TableBuilder::buildTables().
|
|
|
|
Deprecation::outputNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
}
|
|
|
|
|
2021-10-27 15:39:47 +13:00
|
|
|
protected function tearDown(): void
|
2016-12-16 17:34:21 +13:00
|
|
|
{
|
2023-02-21 14:41:02 +13:00
|
|
|
if ($this->noticesWereEnabled) {
|
|
|
|
Deprecation::enable();
|
|
|
|
} else {
|
2022-11-15 18:20:54 +13:00
|
|
|
Deprecation::disable();
|
|
|
|
}
|
2024-10-21 10:20:44 +13:00
|
|
|
Deprecation::setShowNoticesCalledFromSupportedCode($this->showSupportedNoticesWasEnabled);
|
2022-11-03 16:19:17 +13:00
|
|
|
restore_error_handler();
|
2022-10-31 19:00:59 +13:00
|
|
|
$this->oldHandler = null;
|
2016-12-16 17:34:21 +13:00
|
|
|
parent::tearDown();
|
|
|
|
}
|
2011-10-28 10:45:12 +13:00
|
|
|
|
2022-11-15 18:20:54 +13:00
|
|
|
private function myDeprecatedMethod(): string
|
|
|
|
{
|
|
|
|
Deprecation::notice('1.2.3', 'My message');
|
|
|
|
return 'abc';
|
|
|
|
}
|
|
|
|
|
2024-10-21 10:20:44 +13:00
|
|
|
private function myDeprecatedMethodNoReplacement(): string
|
|
|
|
{
|
|
|
|
Deprecation::noticeWithNoReplacment('1.2.3');
|
|
|
|
return 'abc';
|
|
|
|
}
|
|
|
|
|
|
|
|
private function enableDeprecationNotices(bool $showNoReplacementNotices = false): void
|
|
|
|
{
|
|
|
|
Deprecation::enable($showNoReplacementNotices);
|
|
|
|
Deprecation::setShowNoticesCalledFromSupportedCode(true);
|
|
|
|
}
|
|
|
|
|
2022-10-20 13:14:58 +13:00
|
|
|
public function testNotice()
|
2016-12-16 17:34:21 +13:00
|
|
|
{
|
2022-10-20 13:14:58 +13:00
|
|
|
$message = implode(' ', [
|
2022-11-15 18:20:54 +13:00
|
|
|
'SilverStripe\Dev\Tests\DeprecationTest->myDeprecatedMethod is deprecated.',
|
2022-10-20 13:14:58 +13:00
|
|
|
'My message.',
|
2022-11-15 18:20:54 +13:00
|
|
|
'Called from SilverStripe\Dev\Tests\DeprecationTest->testNotice.'
|
2022-10-20 13:14:58 +13:00
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2022-11-15 18:20:54 +13:00
|
|
|
$ret = $this->myDeprecatedMethod();
|
|
|
|
$this->assertSame('abc', $ret);
|
|
|
|
// call outputNotices() directly because the regular shutdown function that emits
|
|
|
|
// the notices within Deprecation won't be called until after this unit-test has finished
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
2024-10-21 10:20:44 +13:00
|
|
|
public function testNoticeNoReplacement()
|
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'SilverStripe\Dev\Tests\DeprecationTest->myDeprecatedMethodNoReplacement is deprecated.',
|
|
|
|
'Will be removed without equivalent functionality to replace it.',
|
|
|
|
'Called from SilverStripe\Dev\Tests\DeprecationTest->testNoticeNoReplacement.'
|
|
|
|
]);
|
2024-10-22 15:50:25 +13:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices(true);
|
|
|
|
$ret = $this->myDeprecatedMethodNoReplacement();
|
|
|
|
$this->assertSame('abc', $ret);
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testNoticeNoReplacementNoSupressed()
|
|
|
|
{
|
|
|
|
$this->enableDeprecationNotices();
|
|
|
|
$ret = $this->myDeprecatedMethodNoReplacement();
|
|
|
|
$this->assertSame('abc', $ret);
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
2022-11-15 18:20:54 +13:00
|
|
|
public function testCallUserFunc()
|
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'SilverStripe\Dev\Tests\DeprecationTest->myDeprecatedMethod is deprecated.',
|
|
|
|
'My message.',
|
|
|
|
'Called from SilverStripe\Dev\Tests\DeprecationTest->testCallUserFunc.'
|
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2022-11-15 18:20:54 +13:00
|
|
|
$ret = call_user_func([$this, 'myDeprecatedMethod']);
|
|
|
|
$this->assertSame('abc', $ret);
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testCallUserFuncArray()
|
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'SilverStripe\Dev\Tests\DeprecationTest->myDeprecatedMethod is deprecated.',
|
|
|
|
'My message.',
|
|
|
|
'Called from SilverStripe\Dev\Tests\DeprecationTest->testCallUserFuncArray.'
|
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2022-11-15 18:20:54 +13:00
|
|
|
$ret = call_user_func_array([$this, 'myDeprecatedMethod'], []);
|
|
|
|
$this->assertSame('abc', $ret);
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
2024-09-19 11:27:08 +12:00
|
|
|
public function testwithSuppressedNoticeDefault()
|
2022-11-15 18:20:54 +13:00
|
|
|
{
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2024-09-19 11:27:08 +12:00
|
|
|
$ret = Deprecation::withSuppressedNotice(function () {
|
2022-11-15 18:20:54 +13:00
|
|
|
return $this->myDeprecatedMethod();
|
|
|
|
});
|
|
|
|
$this->assertSame('abc', $ret);
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
2024-09-19 11:27:08 +12:00
|
|
|
public function testwithSuppressedNoticeTrue()
|
2022-11-15 18:20:54 +13:00
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'SilverStripe\Dev\Tests\DeprecationTest->myDeprecatedMethod is deprecated.',
|
|
|
|
'My message.',
|
2024-09-19 11:27:08 +12:00
|
|
|
'Called from SilverStripe\Dev\Tests\DeprecationTest->testwithSuppressedNoticeTrue.'
|
2022-11-15 18:20:54 +13:00
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices(true);
|
2024-09-19 11:27:08 +12:00
|
|
|
$ret = Deprecation::withSuppressedNotice(function () {
|
2022-11-15 18:20:54 +13:00
|
|
|
return $this->myDeprecatedMethod();
|
|
|
|
});
|
|
|
|
$this->assertSame('abc', $ret);
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
2024-09-19 11:27:08 +12:00
|
|
|
public function testwithSuppressedNoticeTrueCallUserFunc()
|
2022-11-15 18:20:54 +13:00
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'SilverStripe\Dev\Tests\DeprecationTest->myDeprecatedMethod is deprecated.',
|
|
|
|
'My message.',
|
2024-09-19 11:27:08 +12:00
|
|
|
'Called from SilverStripe\Dev\Tests\DeprecationTest->testwithSuppressedNoticeTrueCallUserFunc.'
|
2022-11-15 18:20:54 +13:00
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices(true);
|
2024-09-19 11:27:08 +12:00
|
|
|
$ret = Deprecation::withSuppressedNotice(function () {
|
2022-11-15 18:20:54 +13:00
|
|
|
return call_user_func([$this, 'myDeprecatedMethod']);
|
|
|
|
});
|
|
|
|
$this->assertSame('abc', $ret);
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
2024-09-19 11:27:08 +12:00
|
|
|
public function testNoticewithSuppressedNoticeTrue()
|
2023-02-27 15:25:27 +13:00
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
2024-09-19 11:27:08 +12:00
|
|
|
'SilverStripe\Dev\Tests\DeprecationTest->testNoticewithSuppressedNoticeTrue is deprecated.',
|
2023-02-27 15:25:27 +13:00
|
|
|
'My message.',
|
|
|
|
'Called from PHPUnit\Framework\TestCase->runTest.'
|
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices(true);
|
2024-09-19 11:27:08 +12:00
|
|
|
Deprecation::withSuppressedNotice(function () {
|
2023-02-27 15:25:27 +13:00
|
|
|
Deprecation::notice('123', 'My message.');
|
|
|
|
});
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
2024-09-19 11:27:08 +12:00
|
|
|
public function testClasswithSuppressedNotice()
|
2022-11-15 18:20:54 +13:00
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'SilverStripe\Dev\Tests\DeprecationTest\DeprecationTestObject is deprecated.',
|
|
|
|
'Some class message.',
|
2024-09-19 11:27:08 +12:00
|
|
|
'Called from SilverStripe\Dev\Tests\DeprecationTest->testClasswithSuppressedNotice.'
|
2022-11-15 18:20:54 +13:00
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices(true);
|
2022-11-15 18:20:54 +13:00
|
|
|
// using this syntax because my IDE was complaining about DeprecationTestObject not existing
|
|
|
|
// when trying to use `new DeprecationTestObject();`
|
|
|
|
$class = DeprecationTestObject::class;
|
|
|
|
new $class();
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
2024-09-19 11:27:08 +12:00
|
|
|
public function testClassWithInjectorwithSuppressedNotice()
|
2022-11-15 18:20:54 +13:00
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'SilverStripe\Dev\Tests\DeprecationTest\DeprecationTestObject is deprecated.',
|
|
|
|
'Some class message.',
|
2024-09-19 11:27:08 +12:00
|
|
|
'Called from SilverStripe\Dev\Tests\DeprecationTest->testClassWithInjectorwithSuppressedNotice.'
|
2022-11-15 18:20:54 +13:00
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices(true);
|
2022-11-15 18:20:54 +13:00
|
|
|
Injector::inst()->get(DeprecationTestObject::class);
|
|
|
|
Deprecation::outputNotices();
|
2016-12-16 17:34:21 +13:00
|
|
|
}
|
|
|
|
|
2024-09-18 13:53:44 +12:00
|
|
|
#[DoesNotPerformAssertions]
|
2022-10-20 13:14:58 +13:00
|
|
|
public function testDisabled()
|
2016-12-16 17:34:21 +13:00
|
|
|
{
|
2022-11-15 18:20:54 +13:00
|
|
|
if ($this->noticesWereEnabled) {
|
|
|
|
$this->markTestSkipped('Notices are enabled for this project outside of this unit test');
|
|
|
|
}
|
2022-10-20 13:14:58 +13:00
|
|
|
// test that no error error is raised because by default Deprecation is disabled
|
2022-11-15 18:20:54 +13:00
|
|
|
$this->myDeprecatedMethod();
|
|
|
|
Deprecation::outputNotices();
|
2016-12-16 17:34:21 +13:00
|
|
|
}
|
2022-10-31 19:00:59 +13:00
|
|
|
|
2024-10-21 10:20:44 +13:00
|
|
|
public function testshowNoticesCalledFromSupportedCode()
|
|
|
|
{
|
|
|
|
$this->expectNotToPerformAssertions();
|
|
|
|
$this->enableDeprecationNotices(true);
|
|
|
|
// showNoticesCalledFromSupportedCode is set to true by default for these unit tests
|
|
|
|
// as it is testing code within vendor/silverstripe
|
|
|
|
// This test is to ensure that the method works as expected when we disable this
|
|
|
|
// and we should expect no exceptions to be thrown
|
|
|
|
//
|
|
|
|
// Note specifically NOT testing the following because it's counted as being called
|
|
|
|
// from phpunit itself, which is not considered supported code
|
|
|
|
// Deprecation::withSuppressedNotice(function () {
|
|
|
|
// Deprecation::notice('123', 'My message.');
|
|
|
|
// });
|
|
|
|
Deprecation::setShowNoticesCalledFromSupportedCode(false);
|
|
|
|
// notice()
|
|
|
|
$this->myDeprecatedMethod();
|
|
|
|
// noticeNoReplacement()
|
|
|
|
$this->myDeprecatedMethodNoReplacement();
|
|
|
|
// callUserFunc()
|
|
|
|
call_user_func([$this, 'myDeprecatedMethod']);
|
|
|
|
// callUserFuncArray()
|
|
|
|
call_user_func_array([$this, 'myDeprecatedMethod'], []);
|
|
|
|
// withSuppressedNotice()
|
|
|
|
Deprecation::withSuppressedNotice(
|
|
|
|
fn() => $this->myDeprecatedMethod()
|
|
|
|
);
|
|
|
|
// withSuppressedNoticeTrue()
|
|
|
|
Deprecation::withSuppressedNotice(function () {
|
|
|
|
$this->myDeprecatedMethod();
|
|
|
|
});
|
|
|
|
// withSuppressedNoticeTrueCallUserFunc()
|
|
|
|
Deprecation::withSuppressedNotice(function () {
|
|
|
|
call_user_func([$this, 'myDeprecatedMethod']);
|
|
|
|
});
|
|
|
|
// classWithSuppressedNotice()
|
|
|
|
$class = DeprecationTestObject::class;
|
|
|
|
new $class();
|
|
|
|
// classWithInjectorwithSuppressedNotice()
|
|
|
|
Injector::inst()->get(DeprecationTestObject::class);
|
|
|
|
// Output notices - there should be none
|
|
|
|
Deprecation::outputNotices();
|
|
|
|
}
|
|
|
|
|
2022-10-31 19:00:59 +13:00
|
|
|
// The following tests would be better to put in the silverstripe/config module, however this is not
|
|
|
|
// possible to do in a clean way as the config for the DeprecationTestObject will not load if it
|
|
|
|
// is inside the silverstripe/config directory, as there is no _config.php file or _config folder.
|
|
|
|
// Adding a _config.php file will break existing unit-tests within silverstripe/config
|
|
|
|
// It is possible to put DeprecationTestObject in framework and the unit tests in config, however
|
|
|
|
// that's probably messier then just having everything within framework
|
|
|
|
public function testConfigGetFirst()
|
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'Config SilverStripe\Dev\Tests\DeprecationTest\DeprecationTestObject.first_config is deprecated.',
|
|
|
|
'My first config message.'
|
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
Config::inst()->get(DeprecationTestObject::class, 'first_config');
|
2022-11-15 18:20:54 +13:00
|
|
|
Deprecation::outputNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testConfigGetSecond()
|
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'Config SilverStripe\Dev\Tests\DeprecationTest\DeprecationTestObject.second_config is deprecated.',
|
|
|
|
'My second config message.'
|
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
Config::inst()->get(DeprecationTestObject::class, 'second_config');
|
2022-11-15 18:20:54 +13:00
|
|
|
Deprecation::outputNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testConfigGetThird()
|
|
|
|
{
|
|
|
|
$message = 'Config SilverStripe\Dev\Tests\DeprecationTest\DeprecationTestObject.third_config is deprecated.';
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
Config::inst()->get(DeprecationTestObject::class, 'third_config');
|
2022-11-15 18:20:54 +13:00
|
|
|
Deprecation::outputNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testConfigSet()
|
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'Config SilverStripe\Dev\Tests\DeprecationTest\DeprecationTestObject.first_config is deprecated.',
|
|
|
|
'My first config message.'
|
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
Config::modify()->set(DeprecationTestObject::class, 'first_config', 'abc');
|
2022-11-15 18:20:54 +13:00
|
|
|
Deprecation::outputNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testConfigMerge()
|
|
|
|
{
|
|
|
|
$message = implode(' ', [
|
|
|
|
'Config SilverStripe\Dev\Tests\DeprecationTest\DeprecationTestObject.array_config is deprecated.',
|
|
|
|
'My array config message.'
|
|
|
|
]);
|
2024-09-18 13:53:44 +12:00
|
|
|
$this->expectException(DeprecationTestException::class);
|
|
|
|
$this->expectExceptionMessage($message);
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
Config::modify()->merge(DeprecationTestObject::class, 'array_config', ['abc']);
|
2022-11-15 18:20:54 +13:00
|
|
|
Deprecation::outputNotices();
|
2022-10-31 19:00:59 +13:00
|
|
|
}
|
2023-02-21 14:41:02 +13:00
|
|
|
|
2024-09-18 13:53:44 +12:00
|
|
|
public static function provideConfigVsEnv()
|
2023-02-21 14:41:02 +13:00
|
|
|
{
|
|
|
|
return [
|
|
|
|
// env var not set - config setting is respected
|
|
|
|
[
|
|
|
|
// false is returned when the env isn't set, so this simulates simply not having
|
|
|
|
// set the variable in the first place
|
|
|
|
'envVal' => 'notset',
|
|
|
|
'configVal' => false,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'envVal' => 'notset',
|
|
|
|
'configVal' => true,
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
// env var is set and truthy, config setting is ignored
|
|
|
|
[
|
|
|
|
'envVal' => true,
|
|
|
|
'configVal' => false,
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'envVal' => true,
|
|
|
|
'configVal' => true,
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
// env var is set and falsy, config setting is ignored
|
|
|
|
[
|
|
|
|
'envVal' => false,
|
|
|
|
'configVal' => false,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'envVal' => false,
|
|
|
|
'configVal' => true,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2024-09-18 13:53:44 +12:00
|
|
|
#[DataProvider('provideConfigVsEnv')]
|
2023-02-21 14:41:02 +13:00
|
|
|
public function testEnabledConfigVsEnv($envVal, bool $configVal, bool $expected)
|
|
|
|
{
|
|
|
|
$this->runConfigVsEnvTest('SS_DEPRECATION_ENABLED', $envVal, $configVal, $expected);
|
|
|
|
}
|
|
|
|
|
2024-09-18 13:53:44 +12:00
|
|
|
#[DataProvider('provideConfigVsEnv')]
|
2023-02-21 14:41:02 +13:00
|
|
|
public function testShowHttpConfigVsEnv($envVal, bool $configVal, bool $expected)
|
|
|
|
{
|
|
|
|
$this->runConfigVsEnvTest('SS_DEPRECATION_SHOW_HTTP', $envVal, $configVal, $expected);
|
|
|
|
}
|
|
|
|
|
2024-09-18 13:53:44 +12:00
|
|
|
#[DataProvider('provideConfigVsEnv')]
|
2023-02-21 14:41:02 +13:00
|
|
|
public function testShowCliConfigVsEnv($envVal, bool $configVal, bool $expected)
|
|
|
|
{
|
|
|
|
$this->runConfigVsEnvTest('SS_DEPRECATION_SHOW_CLI', $envVal, $configVal, $expected);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function runConfigVsEnvTest(string $varName, $envVal, bool $configVal, bool $expected)
|
|
|
|
{
|
|
|
|
$oldVars = Environment::getVariables();
|
|
|
|
|
|
|
|
if ($envVal === 'notset') {
|
|
|
|
if (Environment::hasEnv($varName)) {
|
|
|
|
$this->markTestSkipped("$varName is set, so we can't test behaviour when it's not");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
Environment::setEnv($varName, $envVal);
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ($varName) {
|
|
|
|
case 'SS_DEPRECATION_ENABLED':
|
|
|
|
if ($configVal) {
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2023-02-21 14:41:02 +13:00
|
|
|
} else {
|
|
|
|
Deprecation::disable();
|
|
|
|
}
|
|
|
|
$result = Deprecation::isEnabled();
|
|
|
|
break;
|
|
|
|
case 'SS_DEPRECATION_SHOW_HTTP':
|
|
|
|
$oldShouldShow = Deprecation::shouldShowForHttp();
|
|
|
|
Deprecation::setShouldShowForHttp($configVal);
|
|
|
|
$result = Deprecation::shouldShowForHttp();
|
|
|
|
Deprecation::setShouldShowForHttp($oldShouldShow);
|
|
|
|
break;
|
|
|
|
case 'SS_DEPRECATION_SHOW_CLI':
|
|
|
|
$oldShouldShow = Deprecation::shouldShowForCli();
|
|
|
|
Deprecation::setShouldShowForCli($configVal);
|
|
|
|
$result = Deprecation::shouldShowForCli();
|
|
|
|
Deprecation::setShouldShowForCli($oldShouldShow);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
Environment::setVariables($oldVars);
|
|
|
|
|
|
|
|
$this->assertSame($expected, $result);
|
|
|
|
}
|
|
|
|
|
2024-09-18 13:53:44 +12:00
|
|
|
public static function provideVarAsBoolean()
|
2023-02-21 14:41:02 +13:00
|
|
|
{
|
|
|
|
return [
|
|
|
|
[
|
|
|
|
'rawValue' => true,
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'rawValue' => 'true',
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'rawValue' => 1,
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'rawValue' => '1',
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'rawValue' => 'on',
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'rawValue' => false,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'rawValue' => 'false',
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'rawValue' => 0,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'rawValue' => '0',
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'rawValue' => 'off',
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2024-09-18 13:53:44 +12:00
|
|
|
#[DataProvider('provideVarAsBoolean')]
|
2023-02-21 14:41:02 +13:00
|
|
|
public function testVarAsBoolean($rawValue, bool $expected)
|
|
|
|
{
|
|
|
|
$reflectionVarAsBoolean = new ReflectionMethod(Deprecation::class, 'varAsBoolean');
|
|
|
|
$reflectionVarAsBoolean->setAccessible(true);
|
|
|
|
|
|
|
|
$this->assertSame($expected, $reflectionVarAsBoolean->invoke(null, $rawValue));
|
|
|
|
}
|
2023-11-22 09:30:08 +13:00
|
|
|
|
2024-09-18 13:53:44 +12:00
|
|
|
public static function provideIsEnabled()
|
2023-11-22 09:30:08 +13:00
|
|
|
{
|
|
|
|
return [
|
|
|
|
'dev, explicitly enabled' => [
|
|
|
|
'envMode' => 'dev',
|
|
|
|
'envEnabled' => true,
|
|
|
|
'staticEnabled' => true,
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
'dev, explicitly enabled override static' => [
|
|
|
|
'envMode' => 'dev',
|
|
|
|
'envEnabled' => true,
|
|
|
|
'staticEnabled' => false,
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
'dev, explicitly disabled override static' => [
|
|
|
|
'envMode' => 'dev',
|
|
|
|
'envEnabled' => false,
|
|
|
|
'staticEnabled' => true,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
'dev, explicitly disabled' => [
|
|
|
|
'envMode' => 'dev',
|
|
|
|
'envEnabled' => false,
|
|
|
|
'staticEnabled' => false,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
'dev, statically disabled' => [
|
|
|
|
'envMode' => 'dev',
|
|
|
|
'envEnabled' => null,
|
|
|
|
'staticEnabled' => true,
|
|
|
|
'expected' => true,
|
|
|
|
],
|
|
|
|
'dev, statically disabled' => [
|
|
|
|
'envMode' => 'dev',
|
|
|
|
'envEnabled' => null,
|
|
|
|
'staticEnabled' => false,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
'live, explicitly enabled' => [
|
|
|
|
'envMode' => 'live',
|
|
|
|
'envEnabled' => true,
|
|
|
|
'staticEnabled' => true,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
'live, explicitly disabled' => [
|
|
|
|
'envMode' => 'live',
|
|
|
|
'envEnabled' => false,
|
|
|
|
'staticEnabled' => false,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
'live, statically disabled' => [
|
|
|
|
'envMode' => 'live',
|
|
|
|
'envEnabled' => null,
|
|
|
|
'staticEnabled' => true,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
'live, statically disabled' => [
|
|
|
|
'envMode' => 'live',
|
|
|
|
'envEnabled' => null,
|
|
|
|
'staticEnabled' => false,
|
|
|
|
'expected' => false,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2024-09-18 13:53:44 +12:00
|
|
|
#[DataProvider('provideIsEnabled')]
|
2023-11-22 09:30:08 +13:00
|
|
|
public function testIsEnabled(string $envMode, ?bool $envEnabled, bool $staticEnabled, bool $expected)
|
|
|
|
{
|
|
|
|
/** @var Kernel $kernel */
|
|
|
|
$kernel = Injector::inst()->get(Kernel::class);
|
|
|
|
$origMode = $kernel->getEnvironment();
|
|
|
|
$origEnvEnabled = Environment::getEnv('SS_DEPRECATION_ENABLED');
|
|
|
|
$reflectionEnabled = new ReflectionProperty(Deprecation::class, 'currentlyEnabled');
|
|
|
|
$reflectionEnabled->setAccessible(true);
|
|
|
|
$origStaticEnabled = $reflectionEnabled->getValue();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$kernel->setEnvironment($envMode);
|
|
|
|
Environment::setEnv('SS_DEPRECATION_ENABLED', $envEnabled);
|
|
|
|
$this->setEnabledViaStatic($staticEnabled);
|
|
|
|
$this->assertSame($expected, Deprecation::isEnabled());
|
|
|
|
} finally {
|
|
|
|
$kernel->setEnvironment($origMode);
|
|
|
|
Environment::setEnv('SS_DEPRECATION_ENABLED', $origEnvEnabled);
|
|
|
|
$this->setEnabledViaStatic($origStaticEnabled);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private function setEnabledViaStatic(bool $enabled): void
|
|
|
|
{
|
|
|
|
if ($enabled) {
|
2024-10-21 10:20:44 +13:00
|
|
|
$this->enableDeprecationNotices();
|
2023-11-22 09:30:08 +13:00
|
|
|
} else {
|
|
|
|
Deprecation::disable();
|
|
|
|
}
|
|
|
|
}
|
2011-10-28 10:45:12 +13:00
|
|
|
}
|