0
0
Fork 0
mirror of https://github.com/nextcloud/server.git synced 2025-02-23 08:28:36 +00:00
nextcloud_server/tests/lib/Command/Integrity/SignCoreTest.php
Christoph Wurst 49dd79eabb
refactor: Add void return type to PHPUnit test methods
Signed-off-by: Christoph Wurst <christoph@winzerhof-wurst.at>
2024-09-15 22:32:31 +02:00

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]));
}
}