Newer
Older
/**
* Piwik - free/libre analytics platform
*
* @link http://piwik.org
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
Thomas Steur
a validé
namespace Piwik\Tests\System;
Benaka Moorthi
a validé
use Piwik\Db;
Thomas Steur
a validé
use Piwik\Tests\Framework\TestCase\SystemTestCase;
use Piwik\Tests\Fixtures\OneVisitWithAbnormalPageviewUrls;
/**
* Tests the URL normalization.
Thomas Steur
a validé
* @group Core
* @group UrlNormalizationTest
class UrlNormalizationTest extends SystemTestCase
public static $fixture = null; // initialized below class definition
/**
* @dataProvider getApiForTesting
*/
public function testApi($api, $params)
{
if(self::isMysqli()) {
$this->markTestSkipped('Sometimes fail on MYSQLI (at random)');
}
$this->runApiTests($api, $params);
}
public function getApiForTesting()
{
$idSite = self::$fixture->idSite;
$dateTime = self::$fixture->dateTime;
$return = array();
$return[] = array('Actions.getPageUrls', array(
'testSuffix' => '_urls',
diosmosis
a validé
'idSite' => $idSite,
'date' => $dateTime,
));
$return[] = array('Actions.getPageTitles', array(
'testSuffix' => '_titles',
diosmosis
a validé
'idSite' => $idSite,
'date' => $dateTime,
$return[] = array('Actions.getPageUrls', array(
'testSuffix' => '_pagesSegmented',
diosmosis
a validé
'idSite' => $idSite,
'date' => $dateTime,
'segment' => 'pageUrl==https://WWw.example.org/foo/bar2.html',
));
// Testing entryPageUrl with AND segment
$return[] = array('Actions.getPageUrls', array(
'testSuffix' => '_pagesSegmented',
diosmosis
a validé
'idSite' => $idSite,
'date' => $dateTime,
'segment' => 'entryPageUrl==http://example.org/foo/bar.html;pageUrl==https://WWw.example.org/foo/bar2.html',
));
// Testing exitPageUrl with AND segment
$return[] = array('Actions.getPageUrls', array(
'testSuffix' => '_pagesSegmented',
diosmosis
a validé
'idSite' => $idSite,
'date' => $dateTime,
'segment' => 'exitPageUrl==example.org/foo/bar4.html;pageUrl==https://WWw.example.org/foo/bar2.html',
));
$return[] = array('Actions.getPageUrls', array(
'testSuffix' => '_pagesSegmented',
diosmosis
a validé
'idSite' => $idSite,
'date' => $dateTime,
'segment' => 'pageUrl==example.org/foo/bar2.html',
));
$return[] = array('Actions.getPageUrls', array(
'testSuffix' => '_pagesSegmentedRef',
diosmosis
a validé
'idSite' => $idSite,
'date' => $dateTime,
'segment' => 'referrerUrl==http://www.google.com/search?q=piwik',
));
$return[] = array('Referrers.getKeywordsForPageUrl', array(
diosmosis
a validé
'idSite' => $idSite,
'date' => $dateTime,
'otherRequestParameters' => array(
'url' => 'http://WWW.example.org/foo/bar.html'
)
));
return $return;
}
/**
* @depends testApi
*/
public function testCheckPostConditions()
{
$sql = "SELECT count(*) FROM " . Common::prefixTable('log_action');
Benaka Moorthi
a validé
$count = Db::get()->fetchOne($sql);
$expected = 9; // 4 urls + 5 titles
$this->assertEquals($expected, $count, "only $expected actions expected");
$sql = "SELECT name, url_prefix FROM " . Common::prefixTable('log_action')
. " WHERE type = " . Action::TYPE_PAGE_URL
Benaka Moorthi
a validé
$urls = Db::get()->fetchAll($sql);
$expected = array(
array('name' => 'example.org/foo/bar.html', 'url_prefix' => 0),
array('name' => 'example.org/foo/bar2.html', 'url_prefix' => 3),
array('name' => 'example.org/foo/bar3.html', 'url_prefix' => 1),
array('name' => 'example.org/foo/bar4.html', 'url_prefix' => 2)
);
$this->assertEquals($expected, $urls, "normalization went wrong");
}
Benaka Moorthi
a validé
public static function getOutputPrefix()
{
return 'UrlNormalization';
}
}
UrlNormalizationTest::$fixture = new OneVisitWithAbnormalPageviewUrls();