summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorGeorg Ehrke <developer@georgehrke.com>2014-06-16 15:54:50 +0200
committerGeorg Ehrke <developer@georgehrke.com>2014-06-16 15:54:50 +0200
commit15c215cd031602013d982d630306314fc6c1b21c (patch)
treee7f5bea6cc6d43694cd61dfedaef4ce7723e3b52 /tests
parentb67588d35c2ebf031e4f4f46fbce73fd555d33e8 (diff)
parent86f546ff6487b9ac8b18ad14ca290b8051f0496e (diff)
downloadnextcloud-server-15c215cd031602013d982d630306314fc6c1b21c.tar.gz
nextcloud-server-15c215cd031602013d982d630306314fc6c1b21c.zip
Merge pull request #8808 from owncloud/update_shipped_apps_from_appstore
Make shipped apps updatable via appstore
Diffstat (limited to 'tests')
-rw-r--r--tests/data/testapp.zipbin0 -> 895 bytes
-rw-r--r--tests/data/testapp2.zipbin0 -> 2449 bytes
-rw-r--r--tests/lib/installer.php77
-rw-r--r--tests/preseed-config.php2
4 files changed, 78 insertions, 1 deletions
diff --git a/tests/data/testapp.zip b/tests/data/testapp.zip
new file mode 100644
index 00000000000..e76c0d18724
--- /dev/null
+++ b/tests/data/testapp.zip
Binary files differ
diff --git a/tests/data/testapp2.zip b/tests/data/testapp2.zip
new file mode 100644
index 00000000000..f46832f7a75
--- /dev/null
+++ b/tests/data/testapp2.zip
Binary files differ
diff --git a/tests/lib/installer.php b/tests/lib/installer.php
new file mode 100644
index 00000000000..5e267245200
--- /dev/null
+++ b/tests/lib/installer.php
@@ -0,0 +1,77 @@
+<?php
+/**
+ * Copyright (c) 2014 Georg Ehrke <georg@owncloud.com>
+ * This file is licensed under the Affero General Public License version 3 or
+ * later.
+ * See the COPYING-README file.
+ */
+
+class Test_Installer extends PHPUnit_Framework_TestCase {
+
+ private static $appid = 'testapp';
+ private $appstore;
+
+ public function setUp() {
+ $this->appstore = OC_Config::getValue('appstoreenabled', true);
+ OC_Config::setValue('appstoreenabled', true);
+ OC_Installer::removeApp(self::$appid);
+ }
+
+ public function tearDown() {
+ OC_Installer::removeApp(self::$appid);
+ OC_Config::setValue('appstoreenabled', $this->appstore);
+ }
+
+ public function testInstallApp() {
+ $pathOfTestApp = __DIR__;
+ $pathOfTestApp .= '/../data/';
+ $pathOfTestApp .= 'testapp.zip';
+
+ $tmp = OC_Helper::tmpFile('.zip');
+ OC_Helper::copyr($pathOfTestApp, $tmp);
+
+ $data = array(
+ 'path' => $tmp,
+ 'source' => 'path',
+ );
+
+ OC_Installer::installApp($data);
+ $isInstalled = OC_Installer::isInstalled(self::$appid);
+
+ $this->assertTrue($isInstalled);
+ }
+
+ public function testUpdateApp() {
+ $pathOfOldTestApp = __DIR__;
+ $pathOfOldTestApp .= '/../data/';
+ $pathOfOldTestApp .= 'testapp.zip';
+
+ $oldTmp = OC_Helper::tmpFile('.zip');
+ OC_Helper::copyr($pathOfOldTestApp, $oldTmp);
+
+ $oldData = array(
+ 'path' => $oldTmp,
+ 'source' => 'path',
+ );
+
+ $pathOfNewTestApp = __DIR__;
+ $pathOfNewTestApp .= '/../data/';
+ $pathOfNewTestApp .= 'testapp2.zip';
+
+ $newTmp = OC_Helper::tmpFile('.zip');
+ OC_Helper::copyr($pathOfNewTestApp, $newTmp);
+
+ $newData = array(
+ 'path' => $newTmp,
+ 'source' => 'path',
+ );
+
+ OC_Installer::installApp($oldData);
+ $oldVersionNumber = OC_App::getAppVersion(self::$appid);
+
+ OC_Installer::updateApp($newData);
+ $newVersionNumber = OC_App::getAppVersion(self::$appid);
+
+ $this->assertNotEquals($oldVersionNumber, $newVersionNumber);
+ }
+}
diff --git a/tests/preseed-config.php b/tests/preseed-config.php
index 95ffb4514bf..3fd5b3cb7fc 100644
--- a/tests/preseed-config.php
+++ b/tests/preseed-config.php
@@ -7,7 +7,7 @@ $CONFIG = array (
array (
'path' => OC::$SERVERROOT.'/apps',
'url' => '/apps',
- 'writable' => false,
+ 'writable' => true,
),
1 =>
array (