]> source.dussan.org Git - nextcloud-server.git/commitdiff
adding hook manager test
authorClark Tomlinson <fallen013@gmail.com>
Tue, 31 Mar 2015 18:50:23 +0000 (14:50 -0400)
committerThomas Müller <thomas.mueller@tmit.eu>
Tue, 7 Apr 2015 11:30:29 +0000 (13:30 +0200)
apps/encryption/lib/hookmanager.php
apps/encryption/tests/lib/HookManagerTest.php [new file with mode: 0644]

index 9e6d9cd855c560ba7c146887b409b47edce993f0..e2b03d91bc8c18e065b6625aecf603f247fa36cb 100644 (file)
@@ -40,7 +40,6 @@ class HookManager {
                                        return false;
                                }
                                $this->hookInstances[] = $instance;
-                               return true;
                        }
 
                }
diff --git a/apps/encryption/tests/lib/HookManagerTest.php b/apps/encryption/tests/lib/HookManagerTest.php
new file mode 100644 (file)
index 0000000..3c360ff
--- /dev/null
@@ -0,0 +1,74 @@
+<?php
+/**
+ * @author Clark Tomlinson  <clark@owncloud.com>
+ * @since 3/31/15, 1:54 PM
+ * @copyright Copyright (c) 2015, ownCloud, Inc.
+ * @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 OCA\Encryption\Tests;
+
+
+use OCA\Encryption\HookManager;
+use Test\TestCase;
+
+class HookManagerTest extends TestCase {
+
+       /**
+        * @var HookManager
+        */
+       private static $instance;
+
+       /**
+        *
+        */
+       public function testRegisterHookWithArray() {
+               self::$instance->registerHook([
+                       $this->getMockBuilder('OCA\Encryption\Hooks\Contracts\IHook')->disableOriginalConstructor()->getMock(),
+                       $this->getMockBuilder('OCA\Encryption\Hooks\Contracts\IHook')->disableOriginalConstructor()->getMock(),
+                       $this->getMock('NotIHook')
+               ]);
+
+               $hookInstances = \Test_Helper::invokePrivate(self::$instance, 'hookInstances');
+               // Make sure our type checking works
+               $this->assertCount(2, $hookInstances);
+       }
+
+
+       /**
+        *
+        */
+       public static function setUpBeforeClass() {
+               parent::setUpBeforeClass();
+               // have to make instance static to preserve data between tests
+               self::$instance = new HookManager();
+
+       }
+
+       /**
+        *
+        */
+       public function testRegisterHooksWithInstance() {
+               $mock = $this->getMockBuilder('OCA\Encryption\Hooks\Contracts\IHook')->disableOriginalConstructor()->getMock();
+               self::$instance->registerHook($mock);
+
+               $hookInstances = \Test_Helper::invokePrivate(self::$instance, 'hookInstances');
+               $this->assertCount(3, $hookInstances);
+
+       }
+
+}