wiki.techinc.nl/tests/phpunit/includes/parser/CacheTimeTest.php
Petr Pchelko 017cfcf016 Forward-compat for merging CacheTime and ParserOutput mOptions
CacheTime::mUsedOptions and ParserOutput::mAccessedOptions
do exactly the same thing and has to be merged into a single property.
This patch adds forward-compatibility and needs to be deployed
at least one train before the patch which actually merges the properties.

Change-Id: Ic9d71a443994e2545ebf2a826b9155c82961cb88
2020-11-10 07:09:41 -07:00

121 lines
3.1 KiB
PHP

<?php
namespace MediaWiki\Tests\Parser;
use CacheTime;
use MediaWikiIntegrationTestCase;
use MWTimestamp;
use Wikimedia\Tests\SerializationTestTrait;
/**
* @covers CacheTime
* @package MediaWiki\Tests\Parser
*/
class CacheTimeTest extends MediaWikiIntegrationTestCase {
use SerializationTestTrait;
protected function setUp(): void {
parent::setUp();
MWTimestamp::setFakeTime( ParserCacheSerializationTestCases::FAKE_TIME );
$this->setMwGlobals( [
'wgParserCacheExpireTime' => ParserCacheSerializationTestCases::FAKE_CACHE_EXPIRY
] );
}
protected function tearDown() : void {
MWTimestamp::setFakeTime( null );
parent::tearDown();
}
/**
* Overrides SerializationTestTrait::getClassToTest
* @return string
*/
protected function getClassToTest() {
return CacheTime::class;
}
/**
* Overrides SerializationTestTrait::getSerializedDataPath
* @return string
*/
protected function getSerializedDataPath(): string {
return __DIR__ . '/../../data/ParserCache';
}
/**
* Overrides SerializationTestTrait::getTestInstancesAndAssertions
* @return array
*/
protected function getTestInstancesAndAssertions(): array {
return ParserCacheSerializationTestCases::getCacheTimeTestCases();
}
/**
* Overrides SerializationTestTrait::getSupportedSerializationFormats
* @return array
*/
protected function getSupportedSerializationFormats(): array {
return ParserCacheSerializationTestCases::getSupportedSerializationFormats(
$this->getClassToTest()
);
}
public function testCacheExpiryDoesNotIncrease() {
$cacheTime = new CacheTime();
$this->assertSame(
ParserCacheSerializationTestCases::FAKE_CACHE_EXPIRY,
$cacheTime->getCacheExpiry()
);
$cacheTime->updateCacheExpiry( 10 );
$this->assertSame( 10, $cacheTime->getCacheExpiry() );
$cacheTime->updateCacheExpiry( 5 );
$this->assertSame( 5, $cacheTime->getCacheExpiry() );
$cacheTime->updateCacheExpiry( 100500 );
$this->assertSame( 5, $cacheTime->getCacheExpiry() );
}
public function testCacheExpiryDoesNotIncreaseNotNegative() {
$cacheTime = new CacheTime();
$cacheTime->updateCacheExpiry( -10 );
$this->assertSame( 0, $cacheTime->getCacheExpiry() );
}
public function testCacheExpiryNotMoreThenGlobal() {
$cacheTime = new CacheTime();
$cacheTime->updateCacheExpiry(
ParserCacheSerializationTestCases::FAKE_CACHE_EXPIRY + 1
);
$this->assertSame(
ParserCacheSerializationTestCases::FAKE_CACHE_EXPIRY,
$cacheTime->getCacheExpiry()
);
}
public function testExpired() {
$cacheTime = new CacheTime();
$cacheTime->updateCacheExpiry( 0 );
$this->assertTrue( $cacheTime->expired( MWTimestamp::now() ) );
$cacheTime = new CacheTime();
$cacheTime->setCacheTime( MWTimestamp::now() );
$this->assertTrue(
$cacheTime->expired(
MWTimestamp::convert( TS_MW, MWTimestamp::now( TS_UNIX ) + 10 )
)
);
$cacheTime = new CacheTime();
$cacheTime->updateCacheExpiry( 10 );
$cacheTime->setCacheTime( MWTimestamp::now() );
$this->assertTrue(
$cacheTime->expired(
MWTimestamp::convert( TS_MW, MWTimestamp::now( TS_UNIX ) + 15 )
)
);
}
}