Browse Source
Migrate tests for AppDirsWithDifferentOwner setup check
Migrate tests for AppDirsWithDifferentOwner setup check
Signed-off-by: Côme Chilliet <come.chilliet@nextcloud.com>pull/42176/head
No known key found for this signature in database
GPG Key ID: A3E2F658B28C760A
2 changed files with 100 additions and 57 deletions
-
57apps/settings/tests/Controller/CheckSetupControllerTest.php
-
100apps/settings/tests/SetupChecks/AppDirsWithDifferentOwnerTest.php
@ -0,0 +1,100 @@ |
|||
<?php |
|||
|
|||
declare(strict_types=1); |
|||
|
|||
/** |
|||
* @copyright Copyright (c) 2024 Côme Chilliet <come.chilliet@nextcloud.com> |
|||
* |
|||
* @author Côme Chilliet <come.chilliet@nextcloud.com> |
|||
* |
|||
* @license GNU AGPL version 3 or any later version |
|||
* |
|||
* This program is free software: you can redistribute it and/or modify |
|||
* it under the terms of the GNU Affero General Public License as |
|||
* published by the Free Software Foundation, either version 3 of the |
|||
* License, or (at your option) any later version. |
|||
* |
|||
* 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 |
|||
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
* |
|||
*/ |
|||
namespace OCA\Settings\Tests; |
|||
|
|||
use OCA\Settings\SetupChecks\AppDirsWithDifferentOwner; |
|||
use OCP\IL10N; |
|||
use Test\TestCase; |
|||
|
|||
class AppDirsWithDifferentOwnerTest extends TestCase { |
|||
private IL10N $l10n; |
|||
private AppDirsWithDifferentOwner $check; |
|||
|
|||
protected function setUp(): void { |
|||
parent::setUp(); |
|||
|
|||
$this->l10n = $this->getMockBuilder(IL10N::class) |
|||
->disableOriginalConstructor()->getMock(); |
|||
$this->l10n->expects($this->any()) |
|||
->method('t') |
|||
->willReturnCallback(function ($message, array $replace) { |
|||
return vsprintf($message, $replace); |
|||
}); |
|||
$this->check = new AppDirsWithDifferentOwner( |
|||
$this->l10n, |
|||
); |
|||
} |
|||
|
|||
/** |
|||
* Setups a temp directory and some subdirectories. |
|||
* Then calls the 'getAppDirsWithDifferentOwner' method. |
|||
* The result is expected to be empty since |
|||
* there are no directories with different owners than the current user. |
|||
* |
|||
* @return void |
|||
*/ |
|||
public function testAppDirectoryOwnersOk() { |
|||
$tempDir = tempnam(sys_get_temp_dir(), 'apps') . 'dir'; |
|||
mkdir($tempDir); |
|||
mkdir($tempDir . DIRECTORY_SEPARATOR . 'app1'); |
|||
mkdir($tempDir . DIRECTORY_SEPARATOR . 'app2'); |
|||
$this->dirsToRemove[] = $tempDir . DIRECTORY_SEPARATOR . 'app1'; |
|||
$this->dirsToRemove[] = $tempDir . DIRECTORY_SEPARATOR . 'app2'; |
|||
$this->dirsToRemove[] = $tempDir; |
|||
\OC::$APPSROOTS = [ |
|||
[ |
|||
'path' => $tempDir, |
|||
'url' => '/apps', |
|||
'writable' => true, |
|||
], |
|||
]; |
|||
$this->assertSame( |
|||
[], |
|||
$this->invokePrivate($this->check, 'getAppDirsWithDifferentOwner', [posix_getuid()]) |
|||
); |
|||
} |
|||
|
|||
/** |
|||
* Calls the check for a none existing app root that is marked as not writable. |
|||
* It's expected that no error happens since the check shouldn't apply. |
|||
* |
|||
* @return void |
|||
*/ |
|||
public function testAppDirectoryOwnersNotWritable() { |
|||
$tempDir = tempnam(sys_get_temp_dir(), 'apps') . 'dir'; |
|||
\OC::$APPSROOTS = [ |
|||
[ |
|||
'path' => $tempDir, |
|||
'url' => '/apps', |
|||
'writable' => false, |
|||
], |
|||
]; |
|||
$this->assertSame( |
|||
[], |
|||
$this->invokePrivate($this->check, 'getAppDirsWithDifferentOwner', [posix_getuid()]) |
|||
); |
|||
} |
|||
} |
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue