Skip to content
Extraits de code Groupes Projets
IntegrationTestCase.php 40,7 ko
Newer Older
  • Learn to ignore specific revisions
  •         if (isset($params['language']))
            {
                $this->changeLanguage($params['language']);
            }
    
            $testSuffix = isset($params['testSuffix']) ? $params['testSuffix'] : '';
    
    
            $requestUrls = $this->_generateApiUrls(
                        isset($params['format']) ? $params['format'] : 'xml',
                        isset($params['idSite']) ? $params['idSite'] : false,
                        isset($params['date']) ? $params['date'] : false,
                        isset($params['periods']) ? $params['periods'] : false,
                        isset($params['setDateLastN']) ? $params['setDateLastN'] : false,
                        isset($params['language']) ? $params['language'] : false,
                        isset($params['segment']) ? $params['segment'] : false,
                        isset($params['visitorId']) ? $params['visitorId'] : false,
                        isset($params['abandonedCarts']) ? $params['abandonedCarts'] : false,
                        isset($params['idGoal']) ? $params['idGoal'] : false,
                        isset($params['apiModule']) ? $params['apiModule'] : false,
                        isset($params['apiAction']) ? $params['apiAction'] : false,
    
                        isset($params['otherRequestParameters']) ? $params['otherRequestParameters'] : array(),
    
    JulienMoumne's avatar
    JulienMoumne a validé
                        isset($params['supertableApi']) ? $params['supertableApi'] : false,
                        isset($params['fileExtension']) ? $params['fileExtension'] : false);
    
            foreach($requestUrls as $apiId => $requestUrl)
    
                $this->_testApiUrl( $testName . $testSuffix, $apiId, $requestUrl);
    
            // change the language back to en
            if ($this->lastLanguage != 'en')
            {
    
        }
    
        /**
         * changing the language within one request is a bit fancy
         * in order to keep the core clean, we need a little hack here
         *
         * @param string $langId
         */
        protected function changeLanguage( $langId )
        {
    
            if ($this->lastLanguage != $langId)
    
            {
                $_GET['language'] = $langId;
                Piwik_Translate::reset();
                Piwik_Translate::getInstance()->reloadLanguage($langId);
            }
    
            $this->lastLanguage = $langId;
        }
    
        /**
         * Path where expected/processed output files are stored. Can be overridden.
         */
        public function getPathToTestDirectory()
        {
            /**
             * Use old path as long as files were not moved
             * @todo move files
             */
            //return dirname(__FILE__).DIRECTORY_SEPARATOR.'Integration';
            return dirname(dirname(__FILE__)).DIRECTORY_SEPARATOR.'integration';
        }
    
        
        /**
         * Returns an array associating table names w/ lists of row data.
         * 
         * @return array
         */
        protected static function getDbTablesWithData()
        {
        	$result = array();
        	foreach (Piwik::getTablesInstalled() as $tableName)
        	{
        		$result[$tableName] = Piwik_FetchAll("SELECT * FROM $tableName");
        	}
        	return $result;
        }
        
        /**
         * Truncates all tables then inserts the data in $tables into each
         * mapped table.
         * 
         * @param array $tables Array mapping table names with arrays of row data.
         */
        protected static function restoreDbTables( $tables )
        {
        	// truncate existing tables
        	Piwik::truncateAllTables();
        	
        	// insert data
        	$existingTables = Piwik::getTablesInstalled();
        	foreach ($tables as $table => $rows)
        	{
        		// create table if it's an archive table
        		if (strpos($table, 'archive_') !== false && !in_array($table, $existingTables))
        		{
        			$tableType = strpos($table, 'archive_numeric') !== false ? 'archive_numeric' : 'archive_blob';
        			
        			$createSql = Piwik::getTableCreateSql($tableType);
        			$createSql = str_replace(Piwik_Common::prefixTable($tableType), $table, $createSql);
        			Piwik_Query($createSql);
        		}
        		
        		if (empty($rows))
        		{
        			continue;
        		}
        		
        		$rowsSql = array();
        		foreach ($rows as $row)
        		{
        			$values = array();
        			foreach ($row as $name => $value)
        			{
        				if (is_null($value))
        				{
        					$values[] = 'NULL';
        				}
        				else if (is_numeric($value))
        				{
        					$values[] = $value;
        				}
        				else if (!ctype_print($value))
        				{
        					$values[] = "x'".bin2hex(substr($value, 1))."'";
        				}
        				else
        				{
        					$values[] = "'$value'";
        				}
        			}
        			
        			$rowsSql[] = "(".implode(',', $values).")";
        		}
        		
        		$sql = "INSERT INTO $table VALUES ".implode(',', $rowsSql);
        		Piwik_Query($sql);
        	}
        }