* @author Joas Schilling * @author Lukas Reschke * @author Robin Appelman * @author Vincent Petry * * @license AGPL-3.0 * * This code is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License, version 3, * along with this program. If not, see * */ use PHPUnit\Framework\Assert; require __DIR__ . '/../../vendor/autoload.php'; trait CommandLine { /** @var int return code of last command */ private $lastCode; /** @var string stdout of last command */ private $lastStdOut; /** @var string stderr of last command */ private $lastStdErr; /** @var string */ protected $ocPath = '../..'; /** * Invokes an OCC command * * @param []string $args OCC command, the part behind "occ". For example: "files:transfer-ownership" * @return int exit code */ public function runOcc($args = []) { $args = array_map(function ($arg) { return escapeshellarg($arg); }, $args); $args[] = '--no-ansi'; $args = implode(' ', $args); $descriptor = [ 0 => ['pipe', 'r'], 1 => ['pipe', 'w'], 2 => ['pipe', 'w'], ]; $process = proc_open('php console.php ' . $args, $descriptor, $pipes, $this->ocPath); $this->lastStdOut = stream_get_contents($pipes[1]); $this->lastStdErr = stream_get_contents($pipes[2]); $this->lastCode = proc_close($process); // Clean opcode cache $client = new GuzzleHttp\Client(); $client->request('GET', 'http://localhost:8080/apps/testing/clean_opcode_cache.php'); return $this->lastCode; } /** * @Given /^invoking occ with "([^"]*)"$/ */ public function invokingTheCommand($cmd) { $args = explode(' ', $cmd); $this->runOcc($args); } /** * Find exception texts in stderr */ public function findExceptions() { $exceptions = []; $captureNext = false; // the exception text usually appears after an "[Exception"] row foreach (explode("\n", $this->lastStdErr) as $line) { if (preg_match('/\[Exception\]/', $line)) { $captureNext = true; continue; } if ($captureNext) { $exceptions[] = trim($line); $captureNext = false; } } return $exceptions; } /** * @Then /^the command was successful$/ */ public function theCommandWasSuccessful() { $exceptions = $this->findExceptions(); if ($this->lastCode !== 0) { $msg = 'The command was not successful, exit code was ' . $this->lastCode . '.'; if (!empty($exceptions)) { $msg .= ' Exceptions: ' . implode(', ', $exceptions); } throw new \Exception($msg); } elseif (!empty($exceptions)) { $msg = 'The command was successful but triggered exceptions: ' . implode(', ', $exceptions); throw new \Exception($msg); } } /** * @Then /^the command failed with exit code ([0-9]+)$/ */ public function theCommandFailedWithExitCode($exitCode) { if ($this->lastCode !== (int)$exitCode) { throw new \Exception('The command was expected to fail with exit code ' . $exitCode . ' but got ' . $this->lastCode); } } /** * @Then /^the command failed with exception text "([^"]*)"$/ */ public function theCommandFailedWithException($exceptionText) { $exceptions = $this->findExceptions(); if (empty($exceptions)) { throw new \Exception('The command did not throw any exceptions'); } if (!in_array($exceptionText, $exceptions)) { throw new \Exception('The command did not throw any exception with the text "' . $exceptionText . '"'); } } /** * @Then /^the command output contains the text "([^"]*)"$/ */ public function theCommandOutputContainsTheText($text) { Assert::assertStringContainsString($text, $this->lastStdOut, 'The command did not output the expected text on stdout'); } /** * @Then /^the command error output contains the text "([^"]*)"$/ */ public function theCommandErrorOutputContainsTheText($text) { Assert::assertStringContainsString($text, $this->lastStdErr, 'The command did not output the expected text on stderr'); } } ion_v5.3.1'>artonge/chore/update_password_confirmation_v5.3.1 Nextcloud server, a safe home for all your data: https://github.com/nextcloud/serverwww-data
aboutsummaryrefslogtreecommitdiffstats
blob: e3c14f37ed793465ca6f8db7824e1e339bcdab95 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php
/**
 * SPDX-FileCopyrightText: 2021 Nextcloud GmbH and Nextcloud contributors
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */
namespace OCA\Provisioning_API\Tests\unit;

use OCA\FederatedFileSharing\FederatedShareProvider;
use OCA\Provisioning_API\Capabilities;
use OCP\App\IAppManager;
use PHPUnit\Framework\MockObject\MockObject;
use Test\TestCase;

/**
 * Capabilities test for provisioning API.
 *
 * Note: group DB needed because of usage of overwriteService()
 *
 * @package OCA\Provisioning_API\Tests
 * @group DB
 */
class CapabilitiesTest extends TestCase {

	/** @var Capabilities */
	protected $capabilities;

	/** @var IAppManager|MockObject */
	protected $appManager;

	public function setUp(): void {
		parent::setUp();
		$this->appManager = $this->createMock(IAppManager::class);
		$this->capabilities = new Capabilities($this->appManager);

		$this->appManager->expects($this->once())
			->method('getAppVersion')
			->with('provisioning_api')
			->willReturn('1.12');
	}

	public function getCapabilitiesProvider() {
		return [
			[true, false, false, true, false],
			[true, true, false, true, false],
			[true, true, true, true, true],
			[false, false, false, false, false],
			[false, true, false, false, false],
			[false, true, true, false, true],
		];
	}

	/**
	 * @dataProvider getCapabilitiesProvider
	 */
	public function testGetCapabilities($federationAppEnabled, $federatedFileSharingAppEnabled, $lookupServerEnabled, $expectedFederatedScopeEnabled, $expectedPublishedScopeEnabled): void {
		$this->appManager->expects($this->any())
			->method('isEnabledForUser')
			->will($this->returnValueMap([
				['federation', null, $federationAppEnabled],
				['federatedfilesharing', null, $federatedFileSharingAppEnabled],
			]));

		$federatedShareProvider = $this->createMock(FederatedShareProvider::class);
		$this->overwriteService(FederatedShareProvider::class, $federatedShareProvider);

		$federatedShareProvider->expects($this->any())
			->method('isLookupServerUploadEnabled')
			->willReturn($lookupServerEnabled);

		$expected = [
			'provisioning_api' => [
				'version' => '1.12',
				'AccountPropertyScopesVersion' => 2,
				'AccountPropertyScopesFederatedEnabled' => $expectedFederatedScopeEnabled,
				'AccountPropertyScopesPublishedEnabled' => $expectedPublishedScopeEnabled,
			],
		];
		$this->assertSame($expected, $this->capabilities->getCapabilities());
	}
}