aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorBjörn Schießle <bjoern@schiessle.org>2016-07-11 17:34:31 +0200
committerGitHub <noreply@github.com>2016-07-11 17:34:31 +0200
commite8169e0d719ef8932bf30b56aad3925782d171bd (patch)
treed03aa73dba81b622d4cd28934824cf4c3bed2cbe /tests
parente25d1cd62b2362e78f250bf580e0c8defe1052b8 (diff)
parent7c64e1973fdcb41758c221118c6167668a563953 (diff)
downloadnextcloud-server-e8169e0d719ef8932bf30b56aad3925782d171bd.tar.gz
nextcloud-server-e8169e0d719ef8932bf30b56aad3925782d171bd.zip
Merge pull request #364 from nextcloud/ca-bundle-tests
add test for needsRebundling() check
Diffstat (limited to 'tests')
-rw-r--r--tests/lib/Security/CertificateManagerTest.php92
1 files changed, 92 insertions, 0 deletions
diff --git a/tests/lib/Security/CertificateManagerTest.php b/tests/lib/Security/CertificateManagerTest.php
index 43206569cf4..3abd3392e6c 100644
--- a/tests/lib/Security/CertificateManagerTest.php
+++ b/tests/lib/Security/CertificateManagerTest.php
@@ -118,4 +118,96 @@ class CertificateManagerTest extends \Test\TestCase {
$this->assertSame('/' . $this->username . '/files_external/rootcerts.crt', $this->certificateManager->getCertificateBundle());
}
+ /**
+ * @dataProvider dataTestNeedRebundling
+ *
+ * @param string $uid
+ * @param int $CaBundleMtime
+ * @param int $systemWideMtime
+ * @param int $targetBundleMtime
+ * @param int $targetBundleExists
+ * @param bool $expected
+ */
+ function testNeedRebundling($uid,
+ $CaBundleMtime,
+ $systemWideMtime,
+ $targetBundleMtime,
+ $targetBundleExists,
+ $expected
+ ) {
+
+ $view = $this->getMockBuilder('OC\Files\View')
+ ->disableOriginalConstructor()->getMock();
+ $config = $this->getMock('OCP\IConfig');
+
+ /** @var CertificateManager | \PHPUnit_Framework_MockObject_MockObject $certificateManager */
+ $certificateManager = $this->getMockBuilder('OC\Security\CertificateManager')
+ ->setConstructorArgs([$uid, $view, $config])
+ ->setMethods(['getFilemtimeOfCaBundle', 'getCertificateBundle'])
+ ->getMock();
+
+ $certificateManager->expects($this->any())->method('getFilemtimeOfCaBundle')
+ ->willReturn($CaBundleMtime);
+
+ $certificateManager->expects($this->at(1))->method('getCertificateBundle')
+ ->with($uid)->willReturn('targetBundlePath');
+
+ $view->expects($this->any())->method('file_exists')
+ ->with('targetBundlePath')
+ ->willReturn($targetBundleExists);
+
+
+ if ($uid !== null && $targetBundleExists) {
+ $certificateManager->expects($this->at(2))->method('getCertificateBundle')
+ ->with(null)->willReturn('SystemBundlePath');
+
+ }
+
+ $view->expects($this->any())->method('filemtime')
+ ->willReturnCallback(function($path) use ($systemWideMtime, $targetBundleMtime) {
+ if ($path === 'SystemBundlePath') {
+ return $systemWideMtime;
+ } elseif ($path === 'targetBundlePath') {
+ return $targetBundleMtime;
+ }
+ throw new \Exception('unexpected path');
+ });
+
+
+ $this->assertSame($expected,
+ $this->invokePrivate($certificateManager, 'needsRebundling', [$uid])
+ );
+
+ }
+
+ function dataTestNeedRebundling() {
+ return [
+ //values: uid, CaBundleMtime, systemWideMtime, targetBundleMtime, targetBundleExists, expected
+
+ // compare minimum of CaBundleMtime and systemWideMtime with targetBundleMtime
+ ['user1', 10, 20, 30, true, false],
+ ['user1', 10, 20, 15, true, true],
+ ['user1', 10, 5, 30, true, false],
+ ['user1', 10, 5, 8, true, true],
+
+ // if no user exists we ignore 'systemWideMtime' because this is the bundle we re-build
+ [null, 10, 20, 30, true, false],
+ [null, 10, 20, 15, true, false],
+ [null, 10, 20, 8, true, true],
+ [null, 10, 5, 30, true, false],
+ [null, 10, 5, 8, true, true],
+
+ // if no target bundle exists we always build a new one
+ ['user1', 10, 20, 30, false, true],
+ ['user1', 10, 20, 15, false, true],
+ ['user1', 10, 5, 30, false, true],
+ ['user1', 10, 5, 8, false, true],
+ [null, 10, 20, 30, false, true],
+ [null, 10, 20, 15, false, true],
+ [null, 10, 20, 8, false, true],
+ [null, 10, 5, 30, false, true],
+ [null, 10, 5, 8, false, true],
+ ];
+ }
+
}