1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-22 15:07:44 +00:00
Files
matomo/plugins/CustomDimensions/tests/Unit/Dimension/ExtractionsTest.php
Stefan Giehl d6d72d1fa7 [Coding Style] Enable rule PSR1.Methods.CamelCapsMethodName.NotCamelCaps (#22144)
* [Coding Style] Enable rule PSR1.Methods.CamelCapsMethodName.NotCamelCaps

* [Coding Style] Use camel case for method names in API plugin tests (#22145)

* [Coding Style] Use camel case for method names in Core* plugin tests (#22147)

* [Coding Style] Use camel case for method names in core Unit tests (#22149)

* [Coding Style] Use camel case for method names in Actions and BulkTracking plugin tests (#22146)

* [Coding Style] Use camel case for method names in CustomDimensions and CustomJSTracker plugin tests (#22148)

* [Coding Style] Use camel case for method names in core Integration tests (#22151)

* [Coding Style] Use camel case for method names in more core plugin tests (#22153)

* [Coding Style] Use camel case for method names in more core plugin tests (#22157)

* [Coding Style] Use camel case for method names in more core plugin tests

* Update plugins/Monolog/tests/Unit/Processor/ExceptionToTextProcessorTest.php

Co-authored-by: Michal Kleiner <michal@innocraft.com>

---------

Co-authored-by: Michal Kleiner <michal@innocraft.com>

* [Coding Style] Use camel case for method names in more core plugin tests (#22159)

* [Coding Style] Use camel case for method names in remaining tests (#22160)

* [Coding Style] Use camel case for method names in remaining tests

* rename expected test files

---------

Co-authored-by: Michal Kleiner <michal@innocraft.com>
2024-04-25 20:57:55 +02:00

85 خطوط
2.8 KiB
PHP

<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Plugins\CustomDimensions\tests\Unit\Dimension;
use Piwik\Plugins\CustomDimensions\Dimension\Extractions;
/**
* @group CustomDimensions
* @group ExtractionsTest
* @group Extractions
* @group Plugins
*/
class ExtractionsTest extends \PHPUnit\Framework\TestCase
{
public function testCheckShouldFailWhenExtractionsIsNotAnArray()
{
$this->expectException(\Exception::class);
$this->expectExceptionMessage("extractions has to be an array");
$this->buildExtractions('')->check();
}
public function testCheckShouldFailWhenExtractionsDoesNotContainArrays()
{
$this->expectException(\Exception::class);
$this->expectExceptionMessage("Each extraction within extractions has to be an array");
$this->buildExtractions(array('5'))->check();
}
/**
* @dataProvider getInvalidExtraction
*/
public function testCheckShouldFailWhenExtractionsDoesNotContainValidExtraction($extraction)
{
$this->expectException(\Exception::class);
$this->expectExceptionMessage('Each extraction within extractions must have a key "dimension" and "pattern" only');
$this->buildExtractions(array($extraction))->check();
}
public function getInvalidExtraction()
{
return array(
array(array()),
array(array('dimension' => 'url')),
array(array('pattern' => 'index(.+).html')),
array(array('dimension' => 'url', 'anything' => 'invalid')),
array(array('dimension' => 'url', 'pattern' => 'index(.+).html', 'anything' => 'invalid')),
);
}
public function testCheckShouldAlsoCheckExtractionAndFailIfValueIsInvalid()
{
$this->expectException(\Exception::class);
$this->expectExceptionMessage("Invald dimension 'invalId' used in an extraction. Available dimensions are: url, urlparam, action_name");
$extraction1 = array('dimension' => 'url', 'pattern' => 'index(.+).html');
$extraction2 = array('dimension' => 'invalId', 'pattern' => 'index');
$this->buildExtractions(array($extraction1, $extraction2))->check();
}
public function testCheckShouldNotFailWhenExtractionsDefinitionIsValid()
{
$extraction1 = array('dimension' => 'url', 'pattern' => 'index(.+).html');
$extraction2 = array('dimension' => 'urlparam', 'pattern' => 'index');
$ex = $this->buildExtractions(array($extraction1, $extraction2));
$ex->check();
self::assertInstanceOf(Extractions::class, $ex);
}
private function buildExtractions($extractions)
{
return new Extractions($extractions);
}
}