1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Tests\Integration;
use Piwik\ArchiveProcessor\Rules;
use Piwik\CronArchive;
use Piwik\Date;
use Piwik\Plugin\Manager;
use Piwik\Tests\Framework\Fixture;
use Piwik\Tests\Framework\Mock\FakeLogger;
use Piwik\Tests\Framework\TestCase\IntegrationTestCase;
use Piwik\Plugins\SegmentEditor\API as SegmentAPI;
use Piwik\Version;
/**
* @group Archiver
* @group CronArchive
*/
class CronArchiveInvalidSegmentTest extends IntegrationTestCase
{
/** @var FakeLogger */
private $logger;
public function setUp(): void
{
\Piwik\Tests\Framework\Mock\FakeCliMulti::$specifiedResults = array(
'/method=API.get/' => json_encode(array(array('nb_visits' => 1)))
);
Fixture::createWebsite('2014-12-12 00:01:02');
Manager::getInstance()->activatePlugin('UserLanguage');
Rules::setBrowserTriggerArchiving(false);
SegmentAPI::getInstance()->add('languageSegment', 'languageCode==fr', 1, true, true);
$tracker = Fixture::getTracker(1, '2019-12-12 02:03:00');
$tracker->setUrl('http://someurl.com');
Fixture::checkResponse($tracker->doTrackPageView('abcdefg'));
$tracker->setForceVisitDateTime('2019-12-11 03:04:05');
$tracker->setUrl('http://someurl.com/2');
Fixture::checkResponse($tracker->doTrackPageView('abcdefg2'));
$tracker->setForceVisitDateTime('2019-12-10 03:04:05');
$tracker->setUrl('http://someurl.com/3');
Fixture::checkResponse($tracker->doTrackPageView('abcdefg3'));
$tracker->setForceVisitDateTime('2019-12-02 03:04:05');
$tracker->setUrl('http://someurl.com/4');
Fixture::checkResponse($tracker->doTrackPageView('abcdefg4'));
$this->logger = new FakeLogger();
}
public function test_output_invalidSegment()
{
$archiver = new CronArchive($this->logger);
$archiver->init();
$archiver->run();
$this->assertStringNotContainsStringIgnoringCase('Got invalid response from API request', $this->logger->output);
$this->assertStringContainsString("Skipped Archiving website id 1", $this->logger->output);
$this->assertStringContainsString('no error', $this->logger->output);
}
public function test_output_invalidSegment_whenPluginIsNotActive()
{
Manager::getInstance()->deactivatePlugin('UserLanguage');
$archiver = new CronArchive($this->logger);
$archiver->init();
$archiver->run();
$this->assertStringNotContainsStringIgnoringCase('Got invalid response from API request', $this->logger->output);
$this->assertStringContainsString("Segment 'languageCode==fr' is not a supported segment", $this->logger->output);
$this->assertStringContainsString('no error', $this->logger->output);
}
public function provideContainerConfig()
{
Date::$now = strtotime('2020-02-03 04:05:06');
return array(
'observers.global' => \DI\add([
['API.CoreAdminHome.archiveReports', \DI\value(function (&$result) {
Manager::getInstance()->deactivatePlugin('UserLanguage');
})]
]),
);
}
protected static function configureFixture($fixture)
{
parent::configureFixture($fixture);
$fixture->createSuperUser = true;
}
}
|