Skip to content
Extraits de code Groupes Projets
ImportLogsTest.php 6,91 ko
Newer Older
  • Learn to ignore specific revisions
  •  * Piwik - free/libre analytics platform
    
     *
     * @link    http://piwik.org
     * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
     */
    
    use Piwik\Tests\Framework\TestCase\SystemTestCase;
    
    Thomas Steur's avatar
    Thomas Steur a validé
    use Piwik\Tests\Fixtures\ManySitesImportedLogs;
    
    use Piwik\Tests\Framework\TestingEnvironmentVariables;
    
    class ImportLogsTest extends SystemTestCase
    
        /** @var ManySitesImportedLogs */
    
        public static $fixture = null; // initialized below class definition
    
            $this->resetTestingEnvironmentChanges();
    
        /**
         * @dataProvider getApiForTesting
         */
        public function testApi($api, $params)
        {
            $this->runApiTests($api, $params);
        }
    
        public function getApiForTesting()
        {
    
    mattab's avatar
    mattab a validé
            $apis = array(
    
                array('all', array('idSite'  => self::$fixture->idSite,
                                   'date'    => '2012-08-09',
                                   'periods' => 'month')),
    
                array('Referrers.getNumberOfDistinctWebsites', array('idSite'  => self::$fixture->idSite,
                                                                     'date'    => '2012-08-09',
                                                                     'setDateLastN' => true,
                                                                     'periods' => 'day')),
    
    
                array('MultiSites.getAll', array('idSite'   => self::$fixture->idSite,
                                                 'date'     => '2012-08-09',
                                                 'periods'  => array('month'),
                                                 'setDateLastN' => true,
                                                 'otherRequestParameters' => array('enhanced' => 1),
                                                 'testSuffix' => '_withEnhancedAndLast7')),
    
    
                // report generated from custom log format including generation time
                array('Actions.getPageUrls', array('idSite'  => self::$fixture->idSite,
                                                   'date'    => '2012-09-30',
                                                   'periods' => 'day')),
    
                array('VisitsSummary.get', array('idSite'     => self::$fixture->idSite2,
                                                 'date'       => '2012-08-09',
                                                 'periods'    => 'month',
                                                 'testSuffix' => '_siteIdTwo_TrackedUsingLogReplay')),
            );
    
    mattab's avatar
    mattab a validé
    
    
    mattab's avatar
    mattab a validé
            // Running a few interesting tests for Log Replay use case
    
    mattab's avatar
    mattab a validé
            $apiMethods = array();
            if (getenv('MYSQL_ADAPTER') != 'MYSQLI') {
                // Mysqli rounds latitude/longitude
                $apiMethods = array('Live.getLastVisitsDetails');
    
    mattab's avatar
    mattab a validé
            }
    
    mattab's avatar
    mattab a validé
            $apiMethods[] = 'Actions';
            $apiMethods[] = 'VisitorInterest';
            $apiMethods[] = 'VisitFrequency';
            $apis[] = array($apiMethods, array(
                'idSite'  => self::$fixture->idSite,
                'date'    => '2012-08-09,2014-04-01',
                'periods' => 'range',
                'otherRequestParameters' => array(
                    'filter_limit' => 1000
            )));
    
    
            // imported via --replay-tracking --idsite=3  should ignore idSite from logs and use fixed idSite instead
            $apis[] = array($apiMethods, array(
                'idSite'  => 3,
                'date'    => '2012-08-09,2014-04-01',
                'periods' => 'range',
                'otherRequestParameters' => array(
                    'filter_limit' => 1000
                ),
                'testSuffix' => '_siteIdThree_TrackedUsingLogReplayWithFixedSiteId'));
    
    
    mattab's avatar
    mattab a validé
            return $apis;
    
         * NOTE: This test must be last since the new sites that get added are added in
         *       random order.
    
         */
        public function testDynamicResolverSitesCreated()
        {
    
            self::$fixture->logVisitsWithDynamicResolver();
    
            // reload access so new sites are viewable
    
    
            // make sure sites aren't created twice
    
            $piwikDotNet = API::getInstance()->getSitesIdFromSiteUrl('http://piwik.net');
    
            $this->assertEquals(1, count($piwikDotNet));
    
    
            $anothersiteDotCom = API::getInstance()->getSitesIdFromSiteUrl('http://anothersite.com');
    
            $this->assertEquals(1, count($anothersiteDotCom));
    
            $whateverDotCom = API::getInstance()->getSitesIdFromSiteUrl('http://whatever.com');
    
            $this->assertEquals(1, count($whateverDotCom));
        }
    
    
        public function test_LogImporter_RetriesWhenServerFails()
        {
            $this->simulateTrackerFailure();
    
            $logFile = PIWIK_INCLUDE_PATH . '/tests/resources/access-logs/fake_logs_enable_all.log';
    
            $options = array(
                '--idsite'                    => self::$fixture->idSite,
    
                '--token-auth'                => Fixture::getTokenAuth(),
    
                '--retry-max-attempts'        => 5,
                '--retry-delay'               => 1
            );
    
            $output = Fixture::executeLogImporter($logFile, $options, $allowFailure = true);
            $output = implode("\n", $output);
    
            for ($i = 2; $i != 6; ++$i) {
                $this->assertContains("Retrying request, attempt number $i", $output);
            }
    
            $this->assertNotContains("Retrying request, attempt number 6", $output);
    
            $this->assertContains("Max number of attempts reached, server is unreachable!", $output);
        }
    
        private function simulateTrackerFailure()
        {
    
            $testingEnvironment = new TestingEnvironmentVariables();
    
            $testingEnvironment->_triggerTrackerFailure = true;
    
    
        private function resetTestingEnvironmentChanges()
        {
    
            $testingEnvironment = new TestingEnvironmentVariables();
    
            $testingEnvironment->_triggerTrackerFailure = null;
    
            $testingEnvironment->save();
        }
    
    
        public static function provideContainerConfigBeforeClass()
        {
            $result = array();
    
    
            $testingEnvironment = new TestingEnvironmentVariables();
    
            if ($testingEnvironment->_triggerTrackerFailure) {
                $result['observers.global'] = \DI\add(array(
                    array('Tracker.newHandler', function () {
                        @http_response_code(500);
    
                        throw new \Exception("injected exception");
                    })
                ));
            }
            return $result;
        }
    
    ImportLogsTest::$fixture = new ManySitesImportedLogs();
    
    ImportLogsTest::$fixture->includeIisWithCustom = true;
    
    ImportLogsTest::$fixture->includeNetscaler = true;
    ImportLogsTest::$fixture->includeCloudfront = true;
    
    ImportLogsTest::$fixture->includeCloudfrontRtmp = true;
    
    ImportLogsTest::$fixture->includeNginxJson = true;
    ImportLogsTest::$fixture->includeApiCustomVarMapping = true;