Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/matomo-org/matomo.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Steur <thomas.steur@gmail.com>2016-09-30 09:21:46 +0300
committerThomas Steur <thomas.steur@gmail.com>2016-09-30 09:21:46 +0300
commit7f3afcd4cf867413ccedad0250532c40b04b67c0 (patch)
tree47adb99663b60210534bc1927d9a6a73da3c127c /plugins/CoreVisualizations
parentb6b97cd01bd433558b8f45292a748b96a396791d (diff)
fix some tests
Diffstat (limited to 'plugins/CoreVisualizations')
-rw-r--r--plugins/CoreVisualizations/Visualizations/Sparklines/Config.php7
-rw-r--r--plugins/CoreVisualizations/tests/Integration/SparklinesConfigTest.php34
2 files changed, 37 insertions, 4 deletions
diff --git a/plugins/CoreVisualizations/Visualizations/Sparklines/Config.php b/plugins/CoreVisualizations/Visualizations/Sparklines/Config.php
index 6557abb44b..a4dae712db 100644
--- a/plugins/CoreVisualizations/Visualizations/Sparklines/Config.php
+++ b/plugins/CoreVisualizations/Visualizations/Sparklines/Config.php
@@ -205,9 +205,14 @@ class Config extends \Piwik\ViewDataTable\Config
}
if (!empty($requestParamsForSparkline['columns'])
+ && is_array($requestParamsForSparkline['columns'])
&& count($requestParamsForSparkline['columns']) === count($values)) {
$columns = array_values($requestParamsForSparkline['columns']);
- } else {
+ } elseif (!empty($requestParamsForSparkline['columns'])
+ && is_string($requestParamsForSparkline['columns'])
+ && count($values) === 1) {
+ $columns = array($requestParamsForSparkline['columns']);
+ } else{
$columns = array();
}
diff --git a/plugins/CoreVisualizations/tests/Integration/SparklinesConfigTest.php b/plugins/CoreVisualizations/tests/Integration/SparklinesConfigTest.php
index 45f4876ea4..49a116b5cc 100644
--- a/plugins/CoreVisualizations/tests/Integration/SparklinesConfigTest.php
+++ b/plugins/CoreVisualizations/tests/Integration/SparklinesConfigTest.php
@@ -54,7 +54,7 @@ class SparklinesConfigTest extends IntegrationTestCase
$expectedSparkline = array(
'url' => '?period=day&date=2012-03-06,2012-04-04&idSite=1&module=CoreHome&action=renderMe&viewDataTable=sparkline',
'metrics' => array (
- array ('value' => 10, 'description' => 'Visits'),
+ array ('column' => '', 'value' => 10, 'description' => 'Visits'),
),
'order' => 999
);
@@ -62,6 +62,18 @@ class SparklinesConfigTest extends IntegrationTestCase
$this->assertSame(array($expectedSparkline), $this->config->getSortedSparklines());
}
+ public function test_addSparkline_shouldAddAMinimalSparklineWithOneValueAndUseDefaultOrderWithColumn()
+ {
+ $params = $this->sparklineParams();
+ $params['columns'] = 'nb_visits';
+ $this->config->addSparkline($params, $value = 10, $description = 'Visits');
+
+ $expectedSparkline = array('column' => 'nb_visits', 'value' => 10, 'description' => 'Visits');
+
+ $sparklines = $this->config->getSortedSparklines();
+ $this->assertSame(array($expectedSparkline), $sparklines[0]['metrics']);
+ }
+
public function test_addSparkline_shouldAddSparklineWithMultipleValues()
{
$this->config->addSparkline($this->sparklineParams(), $values = array(10, 20), $description = array('Visits', 'Actions'));
@@ -69,11 +81,27 @@ class SparklinesConfigTest extends IntegrationTestCase
$sparklines = $this->config->getSortedSparklines();
$this->assertSame(array (
- array ('value' => 10, 'description' => 'Visits'),
- array ('value' => 20, 'description' => 'Actions'),
+ array ('column' => '', 'value' => 10, 'description' => 'Visits'),
+ array ('column' => '', 'value' => 20, 'description' => 'Actions'),
), $sparklines[0]['metrics']);
}
+ public function test_addSparkline_shouldAddSparklinesMultipleValuesWithColumns()
+ {
+ $params = $this->sparklineParams();
+ $params['columns'] = array('nb_visits', 'nb_actions');
+
+ $this->config->addSparkline($params, $values = array(10, 20), $description = array('Visits', 'Actions'));
+
+ $expectedSparkline = array(
+ array ('column' => 'nb_visits', 'value' => 10, 'description' => 'Visits'),
+ array ('column' => 'nb_actions', 'value' => 20, 'description' => 'Actions')
+ );
+
+ $sparklines = $this->config->getSortedSparklines();
+ $this->assertSame($expectedSparkline, $sparklines[0]['metrics']);
+ }
+
/**
* @expectedException \Exception
* @expectedExceptionMessage Values: 10, 20, 30 Descriptions: Visits, Actions