You are here

abstract class Redis_Tests_Cache_AbstractFlushUnitTestCase in Redis 7.2

Hierarchy

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

Namesort descending Modifiers Type Description Overrides
DrupalTestCase::$assertions protected property Assertions thrown in that test case.
DrupalTestCase::$databasePrefix protected property The database prefix of this test run.
DrupalTestCase::$originalFileDirectory protected property The original file directory, before it was changed for testing purposes.
DrupalTestCase::$results public property Current results of this test case.
DrupalTestCase::$setup protected property Flag to indicate whether the test has been set up.
DrupalTestCase::$setupDatabasePrefix protected property
DrupalTestCase::$setupEnvironment protected property
DrupalTestCase::$skipClasses protected property This class is skipped when looking for the source of an assertion.
DrupalTestCase::$testId protected property The test run ID.
DrupalTestCase::$timeLimit protected property Time limit for the test.
DrupalTestCase::$useSetupInstallationCache public property Whether to cache the installation part of the setUp() method.
DrupalTestCase::$useSetupModulesCache public property Whether to cache the modules installation part of the setUp() method.
DrupalTestCase::$verboseDirectoryUrl protected property URL to the verbose output file directory.
DrupalTestCase::assert protected function Internal helper: stores the assert.
DrupalTestCase::assertEqual protected function Check to see if two values are equal.
DrupalTestCase::assertFalse protected function Check to see if a value is false (an empty string, 0, NULL, or FALSE).
DrupalTestCase::assertIdentical protected function Check to see if two values are identical.
DrupalTestCase::assertNotEqual protected function Check to see if two values are not equal.
DrupalTestCase::assertNotIdentical protected function Check to see if two values are not identical.
DrupalTestCase::assertNotNull protected function Check to see if a value is not NULL.
DrupalTestCase::assertNull protected function Check to see if a value is NULL.
DrupalTestCase::assertTrue protected function Check to see if a value is not false (not an empty string, 0, NULL, or FALSE).
DrupalTestCase::deleteAssert public static function Delete an assertion record by message ID.
DrupalTestCase::error protected function Fire an error assertion. 1
DrupalTestCase::errorHandler public function Handle errors during test runs. 1
DrupalTestCase::exceptionHandler protected function Handle exceptions.
DrupalTestCase::fail protected function Fire an assertion that is always negative.
DrupalTestCase::generatePermutations public static function Converts a list of possible parameters into a stack of permutations.
DrupalTestCase::getAssertionCall protected function Cycles through backtrace until the first non-assertion method is found.
DrupalTestCase::getDatabaseConnection public static function Returns the database connection to the site running Simpletest.
DrupalTestCase::insertAssert public static function Store an assertion from outside the testing context.
DrupalTestCase::pass protected function Fire an assertion that is always positive.
DrupalTestCase::randomName public static function Generates a random string containing letters and numbers.
DrupalTestCase::randomString public static function Generates a random string of ASCII characters of codes 32 to 126.
DrupalTestCase::run public function Run all tests in this class.
DrupalTestCase::verbose protected function Logs a verbose message in a text file.
DrupalUnitTestCase::__construct function Constructor for DrupalUnitTestCase. Overrides DrupalTestCase::__construct
Redis_Tests_AbstractUnitTestCase::$loaderEnabled protected static property Is autoloader enabled (system wide)
Redis_Tests_AbstractUnitTestCase::$originalConf private property Drupal $conf array backup
Redis_Tests_AbstractUnitTestCase::enableAutoload protected static function Enable the autoloader (system wide)
Redis_Tests_AbstractUnitTestCase::getClientInterface abstract protected function Set up the Redis configuration 9
Redis_Tests_AbstractUnitTestCase::prepareClientManager final private function Prepare client manager
Redis_Tests_AbstractUnitTestCase::prepareDrupalEnvironment final private function Prepare Drupal environmment for testing
Redis_Tests_AbstractUnitTestCase::restoreClientManager final private function Restore client manager
Redis_Tests_AbstractUnitTestCase::restoreDrupalEnvironment final private function Restore Drupal environment after testing.
Redis_Tests_Cache_AbstractFlushUnitTestCase::doTestFlushPrefix public function
Redis_Tests_Cache_AbstractFlushUnitTestCase::testFlushAll public function Test that the flush all flush mode flushes everything.
Redis_Tests_Cache_AbstractFlushUnitTestCase::testFlushALot public function Flushing more than 20 elements should switch to a pipeline that sends multiple DEL batches.
Redis_Tests_Cache_AbstractFlushUnitTestCase::testFlushALotWithEval public function
Redis_Tests_Cache_AbstractFlushUnitTestCase::testFlushIsNothing public function Test that the flush nothing flush mode flushes nothing.
Redis_Tests_Cache_AbstractFlushUnitTestCase::testFlushIsTemporaryWithLifetime 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::testFlushIsTemporaryWithoutLifetime public function Tests that with no default cache lifetime all temporary items are droppped when in temporary flush mode.
Redis_Tests_Cache_AbstractFlushUnitTestCase::testFlushPrefixWithEval public function
Redis_Tests_Cache_AbstractFlushUnitTestCase::testFlushPrefixWithoutEval public function
Redis_Tests_Cache_AbstractUnitTestCase::$backend protected property
Redis_Tests_Cache_AbstractUnitTestCase::getBackend final protected function Get cache backend
Redis_Tests_Cache_AbstractUnitTestCase::setUp public function Sets up unit test environment. Overrides Redis_Tests_AbstractUnitTestCase::setUp
Redis_Tests_Cache_AbstractUnitTestCase::tearDown public function Overrides Redis_Tests_AbstractUnitTestCase::tearDown