abstract class Redis_Tests_Cache_AbstractFlushUnitTestCase in Redis 7.2
Hierarchy
- class \DrupalTestCase
Expanded class hierarchy of Redis_Tests_Cache_AbstractFlushUnitTestCase
File
- lib/
Redis/ Tests/ Cache/ AbstractFlushUnitTestCase.php, line 3
View source
abstract class Redis_Tests_Cache_AbstractFlushUnitTestCase extends Redis_Tests_Cache_AbstractUnitTestCase {
/**
* Test that the flush all flush mode flushes everything.
*/
public function testFlushAll() {
global $conf;
$conf['redis_flush_mode_cache'] = 2;
$backend = $this
->getBackend();
$this
->assertEqual(Redis_Cache_Base::FLUSH_ALL, $backend
->getClearMode());
$backend
->set('test1', 42, CACHE_PERMANENT);
$backend
->set('test2', 'foo', CACHE_TEMPORARY);
$backend
->set('test3', 'bar', 10);
$backend
->clear();
$this
->assertFalse($backend
->get('test1'));
$this
->assertFalse($backend
->get('test2'));
$this
->assertFalse($backend
->get('test3'));
}
/**
* Test that the flush nothing flush mode flushes nothing.
*/
public function testFlushIsNothing() {
global $conf;
$conf['redis_flush_mode_cache'] = 0;
$backend = $this
->getBackend();
$this
->assertEqual(Redis_Cache_Base::FLUSH_NOTHING, $backend
->getClearMode());
$backend
->set('test4', 42, CACHE_PERMANENT);
$backend
->set('test5', 'foo', CACHE_TEMPORARY);
$backend
->set('test6', 'bar', time() + 10);
$backend
->clear();
$cache = $backend
->get('test4');
$this
->assertNotEqual(false, $cache);
$this
->assertEqual($cache->data, 42);
$cache = $backend
->get('test5');
$this
->assertNotEqual(false, $cache);
$this
->assertEqual($cache->data, 'foo');
$cache = $backend
->get('test6');
$this
->assertNotEqual(false, $cache);
$this
->assertEqual($cache->data, 'bar');
}
/**
* Tests that with a default cache lifetime temporary non expired
* items are kept even when in temporary flush mode.
*/
public function testFlushIsTemporaryWithLifetime() {
global $conf;
$conf['redis_flush_mode_cache'] = 1;
$conf['cache_lifetime'] = 1000;
$backend = $this
->getBackend();
$this
->assertEqual(Redis_Cache_Base::FLUSH_TEMPORARY, $backend
->getClearMode());
$backend
->set('test7', 42, CACHE_PERMANENT);
$backend
->set('test8', 'foo', CACHE_TEMPORARY);
$backend
->set('test9', 'bar', time() + 1000);
$backend
->clear();
$cache = $backend
->get('test7');
$this
->assertNotEqual(false, $cache);
$this
->assertEqual($cache->data, 42);
$cache = $backend
->get('test8');
$this
->assertNotEqual(false, $cache);
$this
->assertEqual($cache->data, 'foo');
$cache = $backend
->get('test9');
$this
->assertNotEqual(false, $cache);
$this
->assertEqual($cache->data, 'bar');
}
/**
* Tests that with no default cache lifetime all temporary items are
* droppped when in temporary flush mode.
*/
public function testFlushIsTemporaryWithoutLifetime() {
global $conf;
$conf['redis_flush_mode_cache'] = 1;
$conf['cache_lifetime'] = 0;
$backend = $this
->getBackend();
$this
->assertEqual(Redis_Cache_Base::FLUSH_TEMPORARY, $backend
->getClearMode());
$backend
->set('test10', 42, CACHE_PERMANENT);
$backend
->set('test11', 'foo', CACHE_TEMPORARY);
$backend
->set('test12', 'bar', time() + 10);
$backend
->clear();
$cache = $backend
->get('test10');
$this
->assertNotEqual(false, $cache);
$this
->assertEqual($cache->data, 42);
$this
->assertFalse($backend
->get('test11'));
$this
->assertFalse($backend
->get('test12'));
}
public function testFlushALotWithEval() {
global $conf;
$conf['redis_eval_enabled'] = true;
$conf['redis_flush_mode_cache'] = 2;
$backend = $this
->getBackend();
$this
->assertTrue($backend
->canUseEval());
$cids = array();
for ($i = 0; $i < 30; ++$i) {
$cids[] = $cid = 'test' . $i;
$backend
->set($cid, 42, CACHE_PERMANENT);
}
$backend
->clear('*', true);
foreach ($cids as $cid) {
$this
->assertFalse($backend
->get($cid));
}
}
public function doTestFlushPrefix($withEval) {
global $conf;
$conf['redis_eval_enabled'] = $withEval;
$conf['redis_flush_mode_cache'] = 2;
$backend = $this
->getBackend();
$this
->assertEqual($withEval, $backend
->canUseEval());
$backend
->set('testprefix10', 'foo');
$backend
->set('testprefix11', 'foo');
$backend
->set('testprefix:12', 'bar');
$backend
->set('testprefix:13', 'baz');
$backend
->set('testnoprefix14', 'giraffe');
$backend
->set('testnoprefix:15', 'elephant');
$backend
->clear('testprefix:', true);
$this
->assertFalse($backend
->get('testprefix:12'));
$this
->assertFalse($backend
->get('testprefix:13'));
$this
->assertNotIdentical(false, $backend
->get('testprefix10'));
$this
->assertNotIdentical(false, $backend
->get('testprefix11'));
$this
->assertNotIdentical(false, $backend
->get('testnoprefix14'));
$this
->assertNotIdentical(false, $backend
->get('testnoprefix:15'));
$backend
->clear('testprefix', true);
$this
->assertFalse($backend
->get('testprefix10'));
$this
->assertFalse($backend
->get('testprefix11'));
$this
->assertNotIdentical(false, $backend
->get('testnoprefix14'));
$this
->assertNotIdentical(false, $backend
->get('testnoprefix:15'));
}
public function testFlushPrefixWithEval() {
$this
->doTestFlushPrefix(true);
}
public function testFlushPrefixWithoutEval() {
$this
->doTestFlushPrefix(false);
}
/**
* Flushing more than 20 elements should switch to a pipeline that
* sends multiple DEL batches.
*/
public function testFlushALot() {
global $conf;
$conf['redis_flush_mode_cache'] = 2;
$backend = $this
->getBackend();
$cids = array();
for ($i = 0; $i < 100; ++$i) {
$cids[] = $cid = 'test' . $i;
$backend
->set($cid, 42, CACHE_PERMANENT);
}
$backend
->clear('*', true);
foreach ($cids as $cid) {
$this
->assertFalse($backend
->get($cid));
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DrupalTestCase:: |
protected | property | Assertions thrown in that test case. | |
DrupalTestCase:: |
protected | property | The database prefix of this test run. | |
DrupalTestCase:: |
protected | property | The original file directory, before it was changed for testing purposes. | |
DrupalTestCase:: |
public | property | Current results of this test case. | |
DrupalTestCase:: |
protected | property | Flag to indicate whether the test has been set up. | |
DrupalTestCase:: |
protected | property | ||
DrupalTestCase:: |
protected | property | ||
DrupalTestCase:: |
protected | property | This class is skipped when looking for the source of an assertion. | |
DrupalTestCase:: |
protected | property | The test run ID. | |
DrupalTestCase:: |
protected | property | Time limit for the test. | |
DrupalTestCase:: |
public | property | Whether to cache the installation part of the setUp() method. | |
DrupalTestCase:: |
public | property | Whether to cache the modules installation part of the setUp() method. | |
DrupalTestCase:: |
protected | property | URL to the verbose output file directory. | |
DrupalTestCase:: |
protected | function | Internal helper: stores the assert. | |
DrupalTestCase:: |
protected | function | Check to see if two values are equal. | |
DrupalTestCase:: |
protected | function | Check to see if a value is false (an empty string, 0, NULL, or FALSE). | |
DrupalTestCase:: |
protected | function | Check to see if two values are identical. | |
DrupalTestCase:: |
protected | function | Check to see if two values are not equal. | |
DrupalTestCase:: |
protected | function | Check to see if two values are not identical. | |
DrupalTestCase:: |
protected | function | Check to see if a value is not NULL. | |
DrupalTestCase:: |
protected | function | Check to see if a value is NULL. | |
DrupalTestCase:: |
protected | function | Check to see if a value is not false (not an empty string, 0, NULL, or FALSE). | |
DrupalTestCase:: |
public static | function | Delete an assertion record by message ID. | |
DrupalTestCase:: |
protected | function | Fire an error assertion. | 1 |
DrupalTestCase:: |
public | function | Handle errors during test runs. | 1 |
DrupalTestCase:: |
protected | function | Handle exceptions. | |
DrupalTestCase:: |
protected | function | Fire an assertion that is always negative. | |
DrupalTestCase:: |
public static | function | Converts a list of possible parameters into a stack of permutations. | |
DrupalTestCase:: |
protected | function | Cycles through backtrace until the first non-assertion method is found. | |
DrupalTestCase:: |
public static | function | Returns the database connection to the site running Simpletest. | |
DrupalTestCase:: |
public static | function | Store an assertion from outside the testing context. | |
DrupalTestCase:: |
protected | function | Fire an assertion that is always positive. | |
DrupalTestCase:: |
public static | function | Generates a random string containing letters and numbers. | |
DrupalTestCase:: |
public static | function | Generates a random string of ASCII characters of codes 32 to 126. | |
DrupalTestCase:: |
public | function | Run all tests in this class. | |
DrupalTestCase:: |
protected | function | Logs a verbose message in a text file. | |
DrupalUnitTestCase:: |
function |
Constructor for DrupalUnitTestCase. Overrides DrupalTestCase:: |
||
Redis_Tests_AbstractUnitTestCase:: |
protected static | property | Is autoloader enabled (system wide) | |
Redis_Tests_AbstractUnitTestCase:: |
private | property | Drupal $conf array backup | |
Redis_Tests_AbstractUnitTestCase:: |
protected static | function | Enable the autoloader (system wide) | |
Redis_Tests_AbstractUnitTestCase:: |
abstract protected | function | Set up the Redis configuration | 9 |
Redis_Tests_AbstractUnitTestCase:: |
final private | function | Prepare client manager | |
Redis_Tests_AbstractUnitTestCase:: |
final private | function | Prepare Drupal environmment for testing | |
Redis_Tests_AbstractUnitTestCase:: |
final private | function | Restore client manager | |
Redis_Tests_AbstractUnitTestCase:: |
final private | function | Restore Drupal environment after testing. | |
Redis_Tests_Cache_AbstractFlushUnitTestCase:: |
public | function | ||
Redis_Tests_Cache_AbstractFlushUnitTestCase:: |
public | function | Test that the flush all flush mode flushes everything. | |
Redis_Tests_Cache_AbstractFlushUnitTestCase:: |
public | function | Flushing more than 20 elements should switch to a pipeline that sends multiple DEL batches. | |
Redis_Tests_Cache_AbstractFlushUnitTestCase:: |
public | function | ||
Redis_Tests_Cache_AbstractFlushUnitTestCase:: |
public | function | Test that the flush nothing flush mode flushes nothing. | |
Redis_Tests_Cache_AbstractFlushUnitTestCase:: |
public | function | Tests that with a default cache lifetime temporary non expired items are kept even when in temporary flush mode. | |
Redis_Tests_Cache_AbstractFlushUnitTestCase:: |
public | function | Tests that with no default cache lifetime all temporary items are droppped when in temporary flush mode. | |
Redis_Tests_Cache_AbstractFlushUnitTestCase:: |
public | function | ||
Redis_Tests_Cache_AbstractFlushUnitTestCase:: |
public | function | ||
Redis_Tests_Cache_AbstractUnitTestCase:: |
protected | property | ||
Redis_Tests_Cache_AbstractUnitTestCase:: |
final protected | function | Get cache backend | |
Redis_Tests_Cache_AbstractUnitTestCase:: |
public | function |
Sets up unit test environment. Overrides Redis_Tests_AbstractUnitTestCase:: |
|
Redis_Tests_Cache_AbstractUnitTestCase:: |
public | function |
Overrides Redis_Tests_AbstractUnitTestCase:: |