diff --git a/classes/WpMatomo/Db/WordPress.php b/classes/WpMatomo/Db/WordPress.php index ebca7f7fe..3002d5bf4 100644 --- a/classes/WpMatomo/Db/WordPress.php +++ b/classes/WpMatomo/Db/WordPress.php @@ -279,7 +279,10 @@ public function query( $sql, $bind = array() ) { $test_sql = trim( $test_sql ); } - if ( preg_match( '/^\s*(select)\s/i', $test_sql ) ) { + if ( + preg_match( '/^\s*(select)\s/i', $test_sql ) + || preg_match( '/\sfor select\s/i', $test_sql ) + ) { // WordPress does not fetch any result when doing a query w/ a select... it's only supposed to be used for things like // insert / update / drop ... $result = $this->fetchAll( $sql, $bind ); diff --git a/tests/phpunit/wpmatomo/db/test-wordpress.php b/tests/phpunit/wpmatomo/db/test-wordpress.php index a2de4d6e5..a6e708e87 100644 --- a/tests/phpunit/wpmatomo/db/test-wordpress.php +++ b/tests/phpunit/wpmatomo/db/test-wordpress.php @@ -271,6 +271,29 @@ public function test_update_sets_null_values_correctly_when_all_params_are_null( $this->assertNull( $row['message'] ); } + public function test_query_recognizes_mariadb_set_for_queries() { + \Piwik\Config::getInstance()->database['schema'] = 'Mariadb'; + \Piwik\Db\Schema::unsetInstance(); + + $params = new \Piwik\ArchiveProcessor\Parameters( + new \Piwik\Site( 1 ), + \Piwik\Period\Factory::build( 'day', 'today' ), + new \Piwik\Segment( '', [ 1 ] ) + ); + $log_aggregator = new \Piwik\DataAccess\LogAggregator( $params ); + + $sql = $log_aggregator->getQueryByDimensionSql( [], false, [], false, false, false, 120, false ); + + // make sure SQL we're testing has MariaDB specific SQL + $this->assertStringContainsString( 'SET STATEMENT max_statement_time', $sql['sql'] ); + + // test that the query works in MWP + $statement = $log_aggregator->queryVisitsByDimension( [], false, [], false, false, false, 120, false ); + $row = $statement->fetch(); + + $this->assertIsArray( $row ); + } + private function insert_many_values() { $this->insert_access( 'foo', 'view' ); $this->insert_access( 'bar', 'write' );