The `SettingsBuilder` now accepts a PSR-16 cache interface with which to store and query settings before attempting to load from each source. By default, no cache is used, but any object that implements the `Psr\SimpleCache\CacheInterface` may be provided to the constructor. An explicit dependency on "psr/simple-cache" has been added to `composer.json`. Note that this dependency already existed in vendor albeit it as a transitive one. An APCu based `SharedMemoryCache` adapter is provided as a canonical PSR-16 compliant interface for production use. Sources are now queued by the `SettingsBuilder` when calling `load()`. If a cache interface has been provided, and the source is considered cacheable (implements `CacheableSource`), then it is wrapped as a `CachedSource` which will query the cache first before loading from the wrapped source. Cache stampedes are mitigated using probabilistic early expiry. The implementation for this was partially based on symfony/cache-contract source code but also from the Wikipedia article and paper referenced therein. See https://en.wikipedia.org/wiki/Cache_stampede#Probabilistic_early_expiration Bug: T294748 Change-Id: I52ab3899731546876ee58265bd4a1927886746dc
17 lines
333 B
PHP
17 lines
333 B
PHP
<?php
|
|
|
|
namespace MediaWiki\Tests\Unit\Settings\Cache;
|
|
|
|
use MediaWiki\Settings\Cache\ArrayCache;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
/**
|
|
* @covers \MediaWiki\Settings\Cache\ArrayCache
|
|
*/
|
|
class ArrayCacheTest extends TestCase {
|
|
use CacheInterfaceTestTrait;
|
|
|
|
protected function newCache(): ArrayCache {
|
|
return new ArrayCache();
|
|
}
|
|
}
|