mirror of
https://github.com/nextcloud/server.git
synced 2025-02-23 08:28:36 +00:00
251 lines
6.4 KiB
PHP
251 lines
6.4 KiB
PHP
<?php
|
|
/**
|
|
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
namespace Test\Command\Integrity;
|
|
|
|
use OC\Core\Command\Integrity\SignCore;
|
|
use OC\IntegrityCheck\Checker;
|
|
use OC\IntegrityCheck\Helpers\FileAccessHelper;
|
|
use Symfony\Component\Console\Input\InputInterface;
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
|
use Test\TestCase;
|
|
|
|
class SignCoreTest extends TestCase {
|
|
/** @var Checker|\PHPUnit\Framework\MockObject\MockObject */
|
|
private $checker;
|
|
/** @var FileAccessHelper|\PHPUnit\Framework\MockObject\MockObject */
|
|
private $fileAccessHelper;
|
|
/** @var SignCore */
|
|
private $signCore;
|
|
|
|
protected function setUp(): void {
|
|
parent::setUp();
|
|
$this->checker = $this->createMock(Checker::class);
|
|
$this->fileAccessHelper = $this->createMock(FileAccessHelper::class);
|
|
$this->signCore = new SignCore(
|
|
$this->checker,
|
|
$this->fileAccessHelper
|
|
);
|
|
}
|
|
|
|
public function testExecuteWithMissingPrivateKey(): void {
|
|
$inputInterface = $this->createMock(InputInterface::class);
|
|
$outputInterface = $this->createMock(OutputInterface::class);
|
|
|
|
$inputInterface
|
|
->expects($this->exactly(3))
|
|
->method('getOption')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
['certificate'],
|
|
['path'],
|
|
)->willReturnOnConsecutiveCalls(
|
|
null,
|
|
'certificate',
|
|
'certificate',
|
|
);
|
|
|
|
$outputInterface
|
|
->expects($this->any())
|
|
->method('writeln')
|
|
->withConsecutive(
|
|
['--privateKey, --certificate and --path are required.']
|
|
);
|
|
|
|
$this->assertSame(1, self::invokePrivate($this->signCore, 'execute', [$inputInterface, $outputInterface]));
|
|
}
|
|
|
|
public function testExecuteWithMissingCertificate(): void {
|
|
$inputInterface = $this->createMock(InputInterface::class);
|
|
$outputInterface = $this->createMock(OutputInterface::class);
|
|
|
|
$inputInterface
|
|
->expects($this->exactly(3))
|
|
->method('getOption')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
['certificate'],
|
|
['path'],
|
|
)->willReturnOnConsecutiveCalls(
|
|
'privateKey',
|
|
null,
|
|
'certificate',
|
|
);
|
|
|
|
$outputInterface
|
|
->expects($this->any())
|
|
->method('writeln')
|
|
->withConsecutive(
|
|
['--privateKey, --certificate and --path are required.']
|
|
);
|
|
|
|
$this->assertSame(1, self::invokePrivate($this->signCore, 'execute', [$inputInterface, $outputInterface]));
|
|
}
|
|
|
|
public function testExecuteWithNotExistingPrivateKey(): void {
|
|
$inputInterface = $this->createMock(InputInterface::class);
|
|
$outputInterface = $this->createMock(OutputInterface::class);
|
|
|
|
$inputInterface
|
|
->expects($this->exactly(3))
|
|
->method('getOption')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
['certificate'],
|
|
['path'],
|
|
)->willReturnOnConsecutiveCalls(
|
|
'privateKey',
|
|
'certificate',
|
|
'certificate',
|
|
);
|
|
|
|
$this->fileAccessHelper
|
|
->expects($this->any())
|
|
->method('file_get_contents')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
)
|
|
->willReturnOnConsecutiveCalls(
|
|
false,
|
|
);
|
|
|
|
$outputInterface
|
|
->expects($this->any())
|
|
->method('writeln')
|
|
->withConsecutive(
|
|
['Private key "privateKey" does not exists.']
|
|
);
|
|
|
|
$this->assertSame(1, self::invokePrivate($this->signCore, 'execute', [$inputInterface, $outputInterface]));
|
|
}
|
|
|
|
public function testExecuteWithNotExistingCertificate(): void {
|
|
$inputInterface = $this->createMock(InputInterface::class);
|
|
$outputInterface = $this->createMock(OutputInterface::class);
|
|
|
|
$inputInterface
|
|
->expects($this->exactly(3))
|
|
->method('getOption')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
['certificate'],
|
|
['path'],
|
|
)->willReturnOnConsecutiveCalls(
|
|
'privateKey',
|
|
'certificate',
|
|
'certificate',
|
|
);
|
|
|
|
$this->fileAccessHelper
|
|
->expects($this->any())
|
|
->method('file_get_contents')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
['certificate'],
|
|
)
|
|
->willReturnOnConsecutiveCalls(
|
|
file_get_contents(\OC::$SERVERROOT . '/tests/data/integritycheck/core.key'),
|
|
false,
|
|
);
|
|
|
|
$outputInterface
|
|
->expects($this->any())
|
|
->method('writeln')
|
|
->withConsecutive(
|
|
['Certificate "certificate" does not exists.']
|
|
);
|
|
|
|
$this->assertSame(1, self::invokePrivate($this->signCore, 'execute', [$inputInterface, $outputInterface]));
|
|
}
|
|
|
|
public function testExecuteWithException(): void {
|
|
$inputInterface = $this->createMock(InputInterface::class);
|
|
$outputInterface = $this->createMock(OutputInterface::class);
|
|
|
|
$inputInterface
|
|
->expects($this->exactly(3))
|
|
->method('getOption')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
['certificate'],
|
|
['path'],
|
|
)->willReturnOnConsecutiveCalls(
|
|
'privateKey',
|
|
'certificate',
|
|
'certificate',
|
|
);
|
|
|
|
$this->fileAccessHelper
|
|
->expects($this->any())
|
|
->method('file_get_contents')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
['certificate'],
|
|
)
|
|
->willReturnOnConsecutiveCalls(
|
|
file_get_contents(\OC::$SERVERROOT . '/tests/data/integritycheck/core.key'),
|
|
file_get_contents(\OC::$SERVERROOT . '/tests/data/integritycheck/core.crt'),
|
|
);
|
|
|
|
$this->checker
|
|
->expects($this->once())
|
|
->method('writeCoreSignature')
|
|
->willThrowException(new \Exception('My exception message'));
|
|
|
|
$outputInterface
|
|
->expects($this->any())
|
|
->method('writeln')
|
|
->withConsecutive(
|
|
['Error: My exception message']
|
|
);
|
|
|
|
$this->assertEquals(1, self::invokePrivate($this->signCore, 'execute', [$inputInterface, $outputInterface]));
|
|
}
|
|
|
|
public function testExecute(): void {
|
|
$inputInterface = $this->createMock(InputInterface::class);
|
|
$outputInterface = $this->createMock(OutputInterface::class);
|
|
|
|
$inputInterface
|
|
->expects($this->exactly(3))
|
|
->method('getOption')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
['certificate'],
|
|
['path'],
|
|
)->willReturnOnConsecutiveCalls(
|
|
'privateKey',
|
|
'certificate',
|
|
'certificate',
|
|
);
|
|
|
|
$this->fileAccessHelper
|
|
->expects($this->any())
|
|
->method('file_get_contents')
|
|
->withConsecutive(
|
|
['privateKey'],
|
|
['certificate'],
|
|
)
|
|
->willReturnOnConsecutiveCalls(
|
|
file_get_contents(\OC::$SERVERROOT . '/tests/data/integritycheck/core.key'),
|
|
file_get_contents(\OC::$SERVERROOT . '/tests/data/integritycheck/core.crt'),
|
|
);
|
|
|
|
$this->checker
|
|
->expects($this->once())
|
|
->method('writeCoreSignature');
|
|
|
|
$outputInterface
|
|
->expects($this->any())
|
|
->method('writeln')
|
|
->withConsecutive(
|
|
['Successfully signed "core"']
|
|
);
|
|
|
|
$this->assertEquals(0, self::invokePrivate($this->signCore, 'execute', [$inputInterface, $outputInterface]));
|
|
}
|
|
}
|