summaryrefslogtreecommitdiffstats
path: root/tests/lib/Diagnostics
diff options
context:
space:
mode:
authorPiotr Mrówczyński <mrow4a@yahoo.com>2017-04-20 11:31:00 +0200
committerJoas Schilling <coding@schilljs.com>2017-04-26 13:19:43 +0200
commit9fec4031b30f5ab56af2f8c284672fcd444e8b62 (patch)
treebbecebfaa1fa8fd376b02dec9078573478fd6864 /tests/lib/Diagnostics
parent5b5c3a1773dab4960d41aafc4150859a308311b7 (diff)
downloadnextcloud-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.php66
-rw-r--r--tests/lib/Diagnostics/QueryLoggerTest.php54
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));
+
+ }
+}