]> source.dussan.org Git - nextcloud-server.git/commitdiff
Add a magic wrapper from hell to allow phpunit4 to run the code again 2137/head
authorJoas Schilling <coding@schilljs.com>
Tue, 15 Nov 2016 13:33:06 +0000 (14:33 +0100)
committerJoas Schilling <coding@schilljs.com>
Tue, 15 Nov 2016 13:49:14 +0000 (14:49 +0100)
Remove this once phpunit 5 is the lowest supported version, by reverting:
https://github.com/nextcloud/server/pull/2137

Signed-off-by: Joas Schilling <coding@schilljs.com>
lib/autoloader.php
tests/lib/TestCase.php
tests/lib/TestCasePhpUnit4.php [new file with mode: 0644]
tests/lib/TestCasePhpUnit5.php [new file with mode: 0644]
tests/lib/TestCasePhpUnitCompatibility.php [new file with mode: 0644]

index 08188ef8e596687ef09cc9d51b0b3aaed736a3f1..3fff025080efa3cd7925f7d096cb11588d7ed33c 100644 (file)
@@ -117,6 +117,13 @@ class Autoloader {
                        // This File is considered public API, so we make sure that the class
                        // can still be loaded, although the PSR-4 paths have not been loaded.
                        $paths[] = \OC::$SERVERROOT . '/tests/lib/TestCase.php';
+
+               } elseif ($class === 'Test\\TestCasePhpUnitCompatibility') {
+                       $paths[] = \OC::$SERVERROOT . '/tests/lib/TestCasePhpUnitCompatibility.php';
+               } elseif ($class === 'Test\\TestCasePhpUnit5') {
+                       $paths[] = \OC::$SERVERROOT . '/tests/lib/TestCasePhpUnit5.php';
+               } elseif ($class === 'Test\\TestCasePhpUnit4') {
+                       $paths[] = \OC::$SERVERROOT . '/tests/lib/TestCasePhpUnit4.php';
                }
                return $paths;
        }
index 42b2273e11929d6fa5394808bba94999bd58a5ca..f115c11938af525ba127169279d62414960a2390 100644 (file)
@@ -24,7 +24,6 @@ namespace Test;
 
 use DOMDocument;
 use DOMNode;
-use OC\Cache\CappedMemoryCache;
 use OC\Command\QueueBus;
 use OC\Files\Filesystem;
 use OC\Template\Base;
@@ -34,7 +33,7 @@ use OCP\IDBConnection;
 use OCP\IL10N;
 use OCP\Security\ISecureRandom;
 
-abstract class TestCase extends \PHPUnit_Framework_TestCase {
+abstract class TestCase extends TestCasePhpUnitCompatibility {
        /** @var \OC\Command\QueueBus */
        private $commandBus;
 
@@ -153,7 +152,7 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase {
                }
        }
 
-       protected function onNotSuccessfulTest($e) {
+       protected function realOnNotSuccessfulTest() {
                $this->restoreAllServices();
 
                // restore database connection
@@ -162,8 +161,6 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase {
                                return self::$realDatabase;
                        });
                }
-
-               parent::onNotSuccessfulTest($e);
        }
 
        protected function tearDown() {
diff --git a/tests/lib/TestCasePhpUnit4.php b/tests/lib/TestCasePhpUnit4.php
new file mode 100644 (file)
index 0000000..f49cf7d
--- /dev/null
@@ -0,0 +1,37 @@
+<?php
+/**
+ * @copyright Copyright (c) 2016 Joas Schilling <coding@schilljs.com>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * 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
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace Test;
+
+/**
+ * FIXME Remove this once phpunit 5 is the lowest supported version, by reverting:
+ * https://github.com/nextcloud/server/pull/2137
+ */
+abstract class TestCasePhpUnit4 extends \PHPUnit_Framework_TestCase {
+
+       abstract protected function realOnNotSuccessfulTest();
+
+       protected function onNotSuccessfulTest(\Exception $e) {
+               $this->realOnNotSuccessfulTest();
+
+               parent::onNotSuccessfulTest($e);
+       }
+}
diff --git a/tests/lib/TestCasePhpUnit5.php b/tests/lib/TestCasePhpUnit5.php
new file mode 100644 (file)
index 0000000..5def70e
--- /dev/null
@@ -0,0 +1,37 @@
+<?php
+/**
+ * @copyright Copyright (c) 2016 Joas Schilling <coding@schilljs.com>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * 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
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace Test;
+
+/**
+ * FIXME Remove this once phpunit 5 is the lowest supported version, by reverting:
+ * https://github.com/nextcloud/server/pull/2137
+ */
+abstract class TestCasePhpUnit5 extends \PHPUnit_Framework_TestCase {
+
+       abstract protected function realOnNotSuccessfulTest();
+
+       protected function onNotSuccessfulTest($e) {
+               $this->realOnNotSuccessfulTest();
+
+               parent::onNotSuccessfulTest($e);
+       }
+}
diff --git a/tests/lib/TestCasePhpUnitCompatibility.php b/tests/lib/TestCasePhpUnitCompatibility.php
new file mode 100644 (file)
index 0000000..cb243d1
--- /dev/null
@@ -0,0 +1,32 @@
+<?php
+/**
+ * @copyright Copyright (c) 2016 Joas Schilling <coding@schilljs.com>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * 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
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace Test;
+
+/**
+ * FIXME Remove this once phpunit 5 is the lowest supported version, by reverting:
+ * https://github.com/nextcloud/server/pull/2137
+ */
+if (version_compare(\PHPUnit_Runner_Version::id(), '5.0.0', '>=')) {
+       abstract class TestCasePhpUnitCompatibility extends TestCasePhpUnit5 {}
+} else {
+       abstract class TestCasePhpUnitCompatibility extends TestCasePhpUnit4 {}
+}