Unit testing helpers
Class declared in MODPATH/unittest/classes/Unittest/Helpers.php on line 3.
array $_environment_backupBackup of the environment variables
array(0) boolean $_has_internetStatic variable used to work out whether we have an internet connection
NULL
Removes all cache files from the kohana cache dir
voidstatic public function clean_cache_dir()
{
    $cache_dir = opendir(Kohana::$cache_dir);
    while ($dir = readdir($cache_dir)) {
        // Cache files are split into directories based on first two characters of hash
        if ($dir[0] !== '.' AND strlen($dir) === 2) {
            $dir = self::dir_separator(Kohana::$cache_dir . '/' . $dir . '/');
            $cache = opendir($dir);
            while ($file = readdir($cache)) {
                if ($file[0] !== '.') {
                    unlink($dir . $file);
                }
            }
            closedir($cache);
            rmdir($dir);
        }
    }
    closedir($cache_dir);
}Helper function which replaces the "/" to OS-specific delimiter
string
                    $path
                    required                     - $path                stringstatic public function dir_separator($path)
{
    return str_replace('/', DIRECTORY_SEPARATOR, $path);
}Check for internet connectivity
boolean - Whether an internet connection is availablepublic static function has_internet()
{
    if (!isset(self::$_has_internet)) {
        // The @ operator is used here to avoid DNS errors when there is no connection.
        $sock = @fsockopen("www.google.com", 80, $errno, $errstr, 1);
        self::$_has_internet = (bool) $sock ? true : false;
    }
    return self::$_has_internet;
}Restores the environment to the original state
Kohana_Unittest_Helpers - $thispublic function restore_environment()
{
    $this->set_environment($this->_environment_backup);
}Allows easy setting & backing up of enviroment config
Option types are checked in the following order:
array
                    $environment
                    required                     - List of environment to set                public function set_environment(array $environment)
{
    if (!count($environment))
        return false;
    foreach ($environment as $option => $value) {
        $backup_needed = !array_key_exists($option, $this->_environment_backup);
        // Handle changing superglobals
        if (in_array($option, ['_GET', '_POST', '_SERVER', '_FILES'])) {
            // For some reason we need to do this in order to change the superglobals
            global $$option;
            if ($backup_needed) {
                $this->_environment_backup[$option] = $$option;
            }
            // PHPUnit makes a backup of superglobals automatically
            $$option = $value;
        }
        // If this is a static property i.e. Html::$windowed_urls
        elseif (strpos($option, '::$') !== false) {
            list($class, $var) = explode('::$', $option, 2);
            $class = new ReflectionClass($class);
            if ($backup_needed) {
                $this->_environment_backup[$option] = $class->getStaticPropertyValue($var);
            }
            $class->setStaticPropertyValue($var, $value);
        }
        // If this is an environment variable
        elseif (preg_match('/^[A-Z_-]+$/', $option) OR isset($_SERVER[$option])) {
            if ($backup_needed) {
                $this->_environment_backup[$option] = isset($_SERVER[$option]) ? $_SERVER[$option] : '';
            }
            $_SERVER[$option] = $value;
        }
        // Else we assume this is a config option
        else {
            if ($backup_needed) {
                $this->_environment_backup[$option] = Kohana::$config->load($option);
            }
            list($group, $var) = explode('.', $option, 2);
            Kohana::$config->load($group)->set($var, $value);
        }
    }
}