summaryrefslogtreecommitdiffstats
path: root/tests/lib
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2016-12-05 15:38:13 +0100
committerGitHub <noreply@github.com>2016-12-05 15:38:12 +0100
commit1253d1008ad22417b1a0c49d327c7ba0c68d4103 (patch)
tree788f6d71528e562a6d13d98366663e00e05ac6d9 /tests/lib
parent86a53b4e191f6cb497429343a94e659e1c975bb4 (diff)
parent0f8fe77b3a7be660e78079bc987bb851b30b576c (diff)
downloadnextcloud-server-1253d1008ad22417b1a0c49d327c7ba0c68d4103.tar.gz
nextcloud-server-1253d1008ad22417b1a0c49d327c7ba0c68d4103.zip
Merge pull request #2411 from nextcloud/fix-encryption-home-storage
check if the file should really be encrypted before we update the file cache
Diffstat (limited to 'tests/lib')
-rw-r--r--tests/lib/Files/Storage/Wrapper/EncryptionTest.php94
1 files changed, 94 insertions, 0 deletions
diff --git a/tests/lib/Files/Storage/Wrapper/EncryptionTest.php b/tests/lib/Files/Storage/Wrapper/EncryptionTest.php
index 245f39f5e2e..fb3b463e43b 100644
--- a/tests/lib/Files/Storage/Wrapper/EncryptionTest.php
+++ b/tests/lib/Files/Storage/Wrapper/EncryptionTest.php
@@ -2,13 +2,21 @@
namespace Test\Files\Storage\Wrapper;
+use OC\Encryption\Exceptions\ModuleDoesNotExistsException;
+use OC\Encryption\Update;
use OC\Encryption\Util;
use OC\Files\Storage\Temporary;
+use OC\Files\Storage\Wrapper\Encryption;
use OC\Files\View;
use OC\Log;
use OC\Memcache\ArrayCache;
use OC\User\Manager;
+use OCP\Encryption\IEncryptionModule;
+use OCP\Encryption\IFile;
+use OCP\Encryption\Keys\IStorage;
use OCP\Files\Cache\ICache;
+use OCP\Files\Mount\IMountPoint;
+use OCP\ILogger;
use Test\Files\Storage\Storage;
class EncryptionTest extends Storage {
@@ -926,4 +934,90 @@ class EncryptionTest extends Storage {
];
}
+ /**
+ * @dataProvider dataTestShouldEncrypt
+ *
+ * @param bool $encryptMountPoint
+ * @param \PHPUnit_Framework_MockObject_MockObject | IEncryptionModule $encryptionModule
+ * @param bool $encryptionModuleShouldEncrypt
+ * @param bool $expected
+ */
+ public function testShouldEncrypt(
+ $encryptMountPoint,
+ $encryptionModule,
+ $encryptionModuleShouldEncrypt,
+ $expected
+ ) {
+ $encryptionManager = $this->createMock(\OC\Encryption\Manager::class);
+ $util = $this->createMock(Util::class);
+ $logger = $this->createMock(ILogger::class);
+ $fileHelper = $this->createMock(IFile::class);
+ $uid = null;
+ $keyStorage = $this->createMock(IStorage::class);
+ $update = $this->createMock(Update::class);
+ $mountManager = $this->createMock(\OC\Files\Mount\Manager::class);
+ $mount = $this->createMock(IMountPoint::class);
+ $arrayCache = $this->createMock(ArrayCache::class);
+ $path = '/welcome.txt';
+ $fullPath = 'admin/files/welcome.txt';
+ $defaultEncryptionModule = $this->createMock(IEncryptionModule::class);
+
+ $wrapper = $this->getMockBuilder(Encryption::class)
+ ->setConstructorArgs(
+ [
+ ['mountPoint' => '', 'mount' => $mount, 'storage' => ''],
+ $encryptionManager,
+ $util,
+ $logger,
+ $fileHelper,
+ $uid,
+ $keyStorage,
+ $update,
+ $mountManager,
+ $arrayCache
+ ]
+ )
+ ->setMethods(['getFullPath', 'getEncryptionModule'])
+ ->getMock();
+
+ $wrapper->method('getFullPath')->with($path)->willReturn($fullPath);
+ $wrapper->method('getEncryptionModule')->with($fullPath)
+ ->willReturnCallback(
+ function() use ($encryptionModule) {
+ if ($encryptionModule === false) {
+ throw new ModuleDoesNotExistsException();
+ }
+ return $encryptionModule;
+ }
+ );
+ $mount->expects($this->once())->method('getOption')->with('encrypt', true)
+ ->willReturn($encryptMountPoint);
+
+ if ($encryptionModule !== null && $encryptionModule !== false) {
+ $encryptionModule->method('shouldEncrypt')->with($fullPath)
+ ->willReturn($encryptionModuleShouldEncrypt);
+ }
+
+ if ($encryptionModule === null) {
+ $encryptionManager->expects($this->once())->method('getEncryptionModule')
+ ->willReturn($defaultEncryptionModule);
+ }
+ $defaultEncryptionModule->method('shouldEncrypt')->willReturn(true);
+
+ $result = $this->invokePrivate($wrapper, 'shouldEncrypt', [$path]);
+
+ $this->assertSame($expected, $result);
+ }
+
+ public function dataTestShouldEncrypt() {
+ $encryptionModule = $this->createMock(IEncryptionModule::class);
+ return [
+ [false, false, false, false],
+ [true, false, false, false],
+ [true, $encryptionModule, false, false],
+ [true, $encryptionModule, true, true],
+ [true, null, false, true],
+ ];
+ }
+
}