parent
ccda64fc66
commit
78dcf3744d
@ -1,58 +0,0 @@ |
||||
<?php |
||||
|
||||
declare(strict_types=1); |
||||
|
||||
/** |
||||
* SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors |
||||
* SPDX-License-Identifier: AGPL-3.0-or-later |
||||
*/ |
||||
namespace OCA\WorkflowEngine\Check; |
||||
|
||||
use OCA\WorkflowEngine\Entity\File; |
||||
use OCP\IL10N; |
||||
use OCP\WorkflowEngine\IFileCheck; |
||||
|
||||
class Directory extends AbstractStringCheck implements IFileCheck { |
||||
use TFileCheck; |
||||
|
||||
/** |
||||
* @param IL10N $l |
||||
*/ |
||||
public function __construct( |
||||
IL10N $l, |
||||
) { |
||||
parent::__construct($l); |
||||
} |
||||
|
||||
/** |
||||
* @return string |
||||
*/ |
||||
protected function getActualValue(): string { |
||||
if ($this->path === null) { |
||||
return ''; |
||||
} |
||||
// files/some/path -> some/path |
||||
return preg_replace('/^files\//', '', pathinfo($this->path, PATHINFO_DIRNAME)); |
||||
} |
||||
|
||||
/** |
||||
* @param string $operator |
||||
* @param string $checkValue |
||||
* @param string $actualValue |
||||
* @return bool |
||||
*/ |
||||
protected function executeStringCheck($operator, $checkValue, $actualValue) { |
||||
if ($operator === 'is' || $operator === '!is') { |
||||
$checkValue = ltrim(rtrim($checkValue, '/'), '/'); |
||||
} |
||||
return parent::executeStringCheck($operator, $checkValue, $actualValue); |
||||
} |
||||
|
||||
public function supportedEntities(): array { |
||||
return [ File::class ]; |
||||
} |
||||
|
||||
public function isAvailableForScope(int $scope): bool { |
||||
return true; |
||||
} |
||||
} |
||||
@ -1,68 +0,0 @@ |
||||
<?php |
||||
|
||||
declare(strict_types=1); |
||||
/** |
||||
* SPDX-FileCopyrightText: 2025 Nextcloud GmbH and Nextcloud contributors |
||||
* SPDX-License-Identifier: AGPL-3.0-or-later |
||||
*/ |
||||
|
||||
namespace OCA\WorkflowEngine\Tests\Check; |
||||
|
||||
use OCA\WorkflowEngine\Check\Directory; |
||||
use OCA\WorkflowEngine\Entity\File; |
||||
use OCP\Files\Storage\IStorage; |
||||
use OCP\IL10N; |
||||
use Test\TestCase; |
||||
|
||||
class DirectoryTest extends TestCase { |
||||
/** @var IL10N */ |
||||
private $l10n; |
||||
|
||||
/** @var IStorage */ |
||||
private $storage; |
||||
|
||||
/** @var Directory */ |
||||
private $directory; |
||||
|
||||
protected function setUp(): void { |
||||
parent::setUp(); |
||||
$this->l10n = $this->createMock(IL10N::class); |
||||
$this->storage = $this->createMock(IStorage::class); |
||||
$this->directory = new Directory($this->l10n); |
||||
} |
||||
|
||||
/** |
||||
* @dataProvider dataProviderCheck |
||||
*/ |
||||
public function testExecuteStringCheck(string $operator, string $configuredDirectoryPath, string $filePath, bool $expectedResult): void { |
||||
$this->directory->setFileInfo($this->storage, $filePath); |
||||
|
||||
$result = $this->directory->executeCheck($operator, $configuredDirectoryPath); |
||||
|
||||
$this->assertEquals($expectedResult, $result); |
||||
} |
||||
|
||||
public function testSupportedEntities(): void { |
||||
$this->assertSame([File::class], $this->directory->supportedEntities()); |
||||
} |
||||
|
||||
public function testIsAvailableForScope(): void { |
||||
$this->assertTrue($this->directory->isAvailableForScope(1)); |
||||
} |
||||
|
||||
public function dataProviderCheck(): array { |
||||
return [ |
||||
['is', 'some/path', 'files/some/path/file.txt', true], |
||||
['is', '/some/path/', 'files/some/path/file.txt', true], |
||||
|
||||
['!is', 'some/path', 'files/some/path/file.txt', false], |
||||
['!is', 'some/path/', 'files/someother/path/file.txt', true], |
||||
|
||||
['matches', '/^some\/path\/.+$/i', 'files/SomE/PATH/subfolder/file.txt', true], |
||||
['matches', '/some\/path\/.*\/sub2/', 'files/some/path/subfolder1/sub2/anotherfile.pdf', true], |
||||
|
||||
['!matches', '/some\/path/', 'files/some/path/file.txt', false], |
||||
['!matches', '/some\/path/', 'files/another/path/file.txt', true], |
||||
]; |
||||
} |
||||
} |
||||
Loading…
Reference in new issue