]> source.dussan.org Git - nextcloud-server.git/commitdiff
added test for share folder
authorFlorin Peter <github@florin-peter.de>
Tue, 7 May 2013 20:56:59 +0000 (22:56 +0200)
committerFlorin Peter <github@florin-peter.de>
Tue, 7 May 2013 20:56:59 +0000 (22:56 +0200)
apps/files_encryption/tests/share.php

index 11a3864540511e63a5de3bc607751f03c0336db2..eba5dd5195a203326221f23e423baa9e426b64ca 100755 (executable)
@@ -166,8 +166,81 @@ class Test_Encryption_Share extends \PHPUnit_Framework_TestCase {
             // check if share key not exists
             $this->assertFalse($this->view->file_exists('/admin/files_encryption/share-keys/'.$filename.'.user2.shareKey'));
 
+            // share the file
+            \OCP\Share::unshare('file', $fileInfo['fileid'], \OCP\Share::SHARE_TYPE_USER, 'user1');
+
+            // check if share key not exists
+            $this->assertFalse($this->view->file_exists('/admin/files_encryption/share-keys/'.$filename.'.user1.shareKey'));
+
             // tear down
             \OC_User::deleteUser('user2');
+            \OC_User::deleteUser('user1');
+        }
+    }
+
+    function testShareFolder($withTeardown = true) {
+        // create user1
+        $this->loginHelper('user1', true);
+
+        // login as admin
+        $this->loginHelper('admin');
+
+        $folder1 = '/folder1';
+        $subfolder = '/subfolder1';
+        $subsubfolder = '/subsubfolder1';
+
+        $filename = 'share-tmp.test';
+
+        $this->view->mkdir('/admin/files'.$folder1);
+        $this->view->mkdir('/admin/files'.$folder1.$subfolder);
+        $this->view->mkdir('/admin/files'.$folder1.$subfolder.$subsubfolder);
+
+        $cryptedFile = file_put_contents( 'crypt://' . $folder1.$subfolder.$subsubfolder.'/'.$filename, $this->dataShort );
+
+        // Test that data was successfully written
+        $this->assertTrue( is_int( $cryptedFile ) );
+
+        // Disable encryption proxy to prevent recursive calls
+        $proxyStatus = \OC_FileProxy::$enabled;
+        \OC_FileProxy::$enabled = false;
+
+        // get the file infos
+        $fileInfo = $this->view->getFileInfo('/admin/files/folder1/');
+
+        // check if we have fileInfos
+        $this->assertTrue(is_array($fileInfo));
+
+        \OC_FileProxy::$enabled = $proxyStatus;
+
+        // share the file
+        \OCP\Share::shareItem('folder', $fileInfo['fileid'], \OCP\Share::SHARE_TYPE_USER, 'user1', OCP\PERMISSION_ALL);
+
+        $this->loginHelper('admin');
+
+        // check if share key exists
+        $this->assertTrue($this->view->file_exists('/admin/files_encryption/share-keys'.$folder1.$subfolder.$subsubfolder.'/'.$filename.'.user1.shareKey'));
+
+        // login as user1
+        $this->loginHelper('user1');
+
+        // Get file contents without using any wrapper to get it's actual contents on disk
+        $retreivedCryptedFile = $this->view->file_get_contents('/user1/files/Shared'.$folder1.$subfolder.$subsubfolder.'/'.$filename);
+
+        // check if data is the same
+        $this->assertEquals($this->dataShort, $retreivedCryptedFile);
+
+        if($withTeardown) {
+            // login as admin
+            $this->loginHelper('admin');
+
+            // share the file
+            \OCP\Share::unshare('folder', $fileInfo['fileid'], \OCP\Share::SHARE_TYPE_USER, 'user1');
+
+            // check if share key not exists
+            $this->assertFalse($this->view->file_exists('/admin/files_encryption/share-keys'.$folder1.$subfolder.$subsubfolder.'/'.$filename.'.user1.shareKey'));
+
+            // tear down
+            \OC_User::deleteUser('user1');
         }
     }