diff options
author | Piotr Mrówczyński <mrow4a@yahoo.com> | 2017-04-20 11:31:00 +0200 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2017-04-26 13:19:43 +0200 |
commit | 9fec4031b30f5ab56af2f8c284672fcd444e8b62 (patch) | |
tree | bbecebfaa1fa8fd376b02dec9078573478fd6864 /tests/lib/Diagnostics | |
parent | 5b5c3a1773dab4960d41aafc4150859a308311b7 (diff) | |
download | nextcloud-server-9fec4031b30f5ab56af2f8c284672fcd444e8b62.tar.gz nextcloud-server-9fec4031b30f5ab56af2f8c284672fcd444e8b62.zip |
Adjust query/event logging code in favour of more complex owncloud/diagnostics (#27643)
* Adjust query/event logging code in favour of more complex owncloud/diagnostics
* Add descriptions to IQueryLogger and IEventLogger interfaces
Diffstat (limited to 'tests/lib/Diagnostics')
-rw-r--r-- | tests/lib/Diagnostics/EventLoggerTest.php | 66 | ||||
-rw-r--r-- | tests/lib/Diagnostics/QueryLoggerTest.php | 54 |
2 files changed, 120 insertions, 0 deletions
diff --git a/tests/lib/Diagnostics/EventLoggerTest.php b/tests/lib/Diagnostics/EventLoggerTest.php new file mode 100644 index 00000000000..2d0c82ba72e --- /dev/null +++ b/tests/lib/Diagnostics/EventLoggerTest.php @@ -0,0 +1,66 @@ +<?php +/** + * @author Piotr Mrowczynski <piotr@owncloud.com> + * + * @copyright Copyright (c) 2017, ownCloud GmbH + * @license AGPL-3.0 + * + * This code is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License, version 3, + * as published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License, version 3, + * along with this program. If not, see <http://www.gnu.org/licenses/> + * + */ + +namespace Test\Diagnostics; + +use OC\Diagnostics\EventLogger; +use Test\TestCase; + +class EventLoggerTest extends TestCase { + + /** @var \OC\Diagnostics\EventLogger */ + private $logger; + + public function setUp() { + parent::setUp(); + + $this->logger = new EventLogger(); + } + + public function testQueryLogger() { + // Module is not activated and this should not be logged + $this->logger->start("test1", "testevent1"); + $this->logger->end("test1"); + $this->logger->log("test2", "testevent2", microtime(true), microtime(true)); + $events = $this->logger->getEvents(); + $this->assertSame(0, sizeof($events)); + + // Activate module and log some query + $this->logger->activate(); + + // start one event + $this->logger->start("test3", "testevent3"); + + // force log of another event + $this->logger->log("test4", "testevent4", microtime(true), microtime(true)); + + // log started event + $this->logger->end("test3"); + + $events = $this->logger->getEvents(); + $this->assertSame("test4", $events['test4']->getId()); + $this->assertSame("testevent4", $events['test4']->getDescription()); + $this->assertSame("test3", $events['test3']->getId()); + $this->assertSame("testevent3", $events['test3']->getDescription()); + $this->assertSame(2, sizeof($events)); + + } +} diff --git a/tests/lib/Diagnostics/QueryLoggerTest.php b/tests/lib/Diagnostics/QueryLoggerTest.php new file mode 100644 index 00000000000..99de60ed8e4 --- /dev/null +++ b/tests/lib/Diagnostics/QueryLoggerTest.php @@ -0,0 +1,54 @@ +<?php +/** + * @author Piotr Mrowczynski <piotr@owncloud.com> + * + * @copyright Copyright (c) 2017, ownCloud GmbH + * @license AGPL-3.0 + * + * This code is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License, version 3, + * as published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License, version 3, + * along with this program. If not, see <http://www.gnu.org/licenses/> + * + */ + +namespace Test\Diagnostics; + +use OC\Diagnostics\QueryLogger; +use Test\TestCase; + +class QueryLoggerTest extends TestCase { + + /** @var \OC\Diagnostics\QueryLogger */ + private $logger; + + public function setUp() { + parent::setUp(); + + $this->logger = new QueryLogger(); + } + + public function testQueryLogger() { + // Module is not activated and this should not be logged + $this->logger->startQuery("SELECT", ["testuser", "count"], ["string", "int"]); + $this->logger->stopQuery(); + $queries = $this->logger->getQueries(); + $this->assertSame(0, sizeof($queries)); + + // Activate module and log some query + $this->logger->activate(); + $this->logger->startQuery("SELECT", ["testuser", "count"], ["string", "int"]); + $this->logger->stopQuery(); + + $queries = $this->logger->getQueries(); + $this->assertSame(1, sizeof($queries)); + + } +} |