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:
authordiosmosis <diosmosis@users.noreply.github.com>2019-12-24 16:15:26 +0300
committerGitHub <noreply@github.com>2019-12-24 16:15:26 +0300
commitdedaf6b3e9a184937539e181c64b80c1db04a0c7 (patch)
tree13f8427ef73198714f9de7f995354c7357f3a890 /plugins
parent42454eb56e02899d2282e1eb6bf81983e666d933 (diff)
MergeDataTables does not correctly merge if table2 has more data than table1 (#15294)
* update submodules to fix build * Handle DataTable Maps in VisitFrequency API and in DataTable merger, make sure to correctly copy child datatables. * fix some tests * Copy metadata over. * Updated expected test results. * Adding unit tests.
Diffstat (limited to 'plugins')
-rw-r--r--plugins/API/DataTable/MergeDataTables.php35
m---------plugins/AnonymousPiwikUsageMeasurement0
m---------plugins/CustomDimensions0
-rw-r--r--plugins/Ecommerce/tests/System/expected/test_ecommerceOrderWithItems_schedrep_html_tables_and_graph__ScheduledReports.generateReport_week.original.html2
m---------plugins/MarketingCampaignsReporting0
-rw-r--r--plugins/VisitFrequency/API.php9
6 files changed, 35 insertions, 11 deletions
diff --git a/plugins/API/DataTable/MergeDataTables.php b/plugins/API/DataTable/MergeDataTables.php
index b26f153c53..fba6e58ba9 100644
--- a/plugins/API/DataTable/MergeDataTables.php
+++ b/plugins/API/DataTable/MergeDataTables.php
@@ -13,9 +13,8 @@ use Piwik\DataTable;
class MergeDataTables
{
-
/**
- * Merge the columns of two data tables.
+ * Merge the columns of two data tables. Only takes into consideration the first row of each table.
* Manipulates the first table.
*
* @param DataTable|DataTable\Map $table1 The table to eventually filter.
@@ -25,13 +24,14 @@ class MergeDataTables
{
// handle table arrays
if ($table1 instanceof DataTable\Map && $table2 instanceof DataTable\Map) {
- $subTables2 = $table2->getDataTables();
- foreach ($table1->getDataTables() as $index => $subTable1) {
- if (!array_key_exists($index, $subTables2)) {
- // occurs when archiving starts on dayN and continues into dayN+1, see https://github.com/piwik/piwik/issues/5168#issuecomment-50959925
- continue;
+ $subTables1 = $table1->getDataTables();
+ foreach ($table2->getDataTables() as $index => $subTable2) {
+ if (!array_key_exists($index, $subTables1)) {
+ $subTable1 = $this->makeNewDataTable($subTable2);
+ $table1->addTable($subTable1, $index);
+ } else {
+ $subTable1 = $subTables1[$index];
}
- $subTable2 = $subTables2[$index];
$this->mergeDataTables($subTable1, $subTable2);
}
return;
@@ -52,4 +52,23 @@ class MergeDataTables
}
}
+ private function makeNewDataTable(DataTable\DataTableInterface $subTable2)
+ {
+ if ($subTable2 instanceof DataTable\Map) {
+ $result = new DataTable\Map();
+ $result->setKeyName($subTable2->getKeyName());
+ return $result;
+ } else if ($subTable2 instanceof DataTable\Simple) {
+ $result = new DataTable\Simple();
+ $result->setAllTableMetadata($subTable2->getAllTableMetadata());
+ return $result;
+ } else if ($subTable2 instanceof DataTable) {
+ $result = new DataTable();
+ $result->setAllTableMetadata($subTable2->getAllTableMetadata());
+ return $result;
+ } else {
+ throw new \Exception("Unknown datatable type: " . get_class($subTable2));
+ }
+ }
+
} \ No newline at end of file
diff --git a/plugins/AnonymousPiwikUsageMeasurement b/plugins/AnonymousPiwikUsageMeasurement
-Subproject 51ee90dde9831449a1d632a5d8532d79858e555
+Subproject 49427328cc2d6e0987cedda0b122c5fad2a7bf5
diff --git a/plugins/CustomDimensions b/plugins/CustomDimensions
-Subproject 70d45d15d4a9b208b8723ee4dc7eca7b8581282
+Subproject 90717603607edfc0df076dea2878f66efdaf92c
diff --git a/plugins/Ecommerce/tests/System/expected/test_ecommerceOrderWithItems_schedrep_html_tables_and_graph__ScheduledReports.generateReport_week.original.html b/plugins/Ecommerce/tests/System/expected/test_ecommerceOrderWithItems_schedrep_html_tables_and_graph__ScheduledReports.generateReport_week.original.html
index 598d6dd399..c7af4c27f7 100644
--- a/plugins/Ecommerce/tests/System/expected/test_ecommerceOrderWithItems_schedrep_html_tables_and_graph__ScheduledReports.generateReport_week.original.html
+++ b/plugins/Ecommerce/tests/System/expected/test_ecommerceOrderWithItems_schedrep_html_tables_and_graph__ScheduledReports.generateReport_week.original.html
@@ -4780,7 +4780,7 @@
</h2>
<img alt=""
- src=""
+ src=""
height="200"
width="700"
margin="0 auto"/>
diff --git a/plugins/MarketingCampaignsReporting b/plugins/MarketingCampaignsReporting
-Subproject ea5fdafe4bf0b2a641348aff5825cd7387372af
+Subproject a51d2262899c5adde96217d5b37e38d23335234
diff --git a/plugins/VisitFrequency/API.php b/plugins/VisitFrequency/API.php
index f44d624402..854b0de5f5 100644
--- a/plugins/VisitFrequency/API.php
+++ b/plugins/VisitFrequency/API.php
@@ -9,8 +9,8 @@
namespace Piwik\Plugins\VisitFrequency;
use Piwik\API\Request;
-use Piwik\Archive;
use Piwik\DataTable;
+use Piwik\Period;
use Piwik\Piwik;
use Piwik\Plugins\API\DataTable\MergeDataTables;
use Piwik\Plugins\VisitsSummary\API as APIVisitsSummary;
@@ -49,7 +49,12 @@ class API extends \Piwik\Plugin\API
$columns = Piwik::getArrayFromApiParameter($columns);
/** @var \Piwik\DataTable\DataTableInterface $resultSet */
- $resultSet = new DataTable\Simple();
+ if (Period::isMultiplePeriod($date, $period)) {
+ $resultSet = new DataTable\Map();
+ $resultSet->setKeyName('period');
+ } else {
+ $resultSet = new DataTable\Simple();
+ }
foreach ($visitTypes as $columnSuffix => $visitorTypeSegment) {
$modifiedSegment = $this->appendVisitorTypeSegment($segment, $visitorTypeSegment);