* * @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 . * */ namespace OCA\WorkflowEngine\Tests\Check; use OCP\IL10N; class AbstractStringCheckTest extends \Test\TestCase { protected function getCheckMock() { $l = $this->getMockBuilder(IL10N::class) ->disableOriginalConstructor() ->getMock(); $l->expects($this->any()) ->method('t') ->willReturnCallback(function ($string, $args) { return sprintf($string, $args); }); $check = $this->getMockBuilder('OCA\WorkflowEngine\Check\AbstractStringCheck') ->setConstructorArgs([ $l, ]) ->setMethods([ 'setPath', 'executeCheck', 'getActualValue', ]) ->getMock(); return $check; } public function dataExecuteStringCheck() { return [ ['is', 'same', 'same', true], ['is', 'different', 'not the same', false], ['!is', 'same', 'same', false], ['!is', 'different', 'not the same', true], ['matches', '/match/', 'match', true], ['matches', '/different/', 'not the same', false], ['!matches', '/match/', 'match', false], ['!matches', '/different/', 'not the same', true], ]; } /** * @dataProvider dataExecuteStringCheck * @param string $operation * @param string $checkValue * @param string $actualValue * @param bool $expected */ public function testExecuteStringCheck($operation, $checkValue, $actualValue, $expected) { $check = $this->getCheckMock(); /** @var \OCA\WorkflowEngine\Check\AbstractStringCheck $check */ $this->assertEquals($expected, $this->invokePrivate($check, 'executeStringCheck', [$operation, $checkValue, $actualValue])); } public function dataValidateCheck() { return [ ['is', '/Invalid(Regex/'], ['!is', '/Invalid(Regex/'], ['matches', '/Valid(Regex)/'], ['!matches', '/Valid(Regex)/'], ]; } /** * @dataProvider dataValidateCheck * @param string $operator * @param string $value */ public function testValidateCheck($operator, $value) { $check = $this->getCheckMock(); /** @var \OCA\WorkflowEngine\Check\AbstractStringCheck $check */ $check->validateCheck($operator, $value); $this->addToAssertionCount(1); } public function dataValidateCheckInvalid() { return [ ['!!is', '', 1, 'The given operator is invalid'], ['less', '', 1, 'The given operator is invalid'], ['matches', '/Invalid(Regex/', 2, 'The given regular expression is invalid'], ['!matches', '/Invalid(Regex/', 2, 'The given regular expression is invalid'], ]; } /** * @dataProvider dataValidateCheckInvalid * @param $operator * @param $value * @param $exceptionCode * @param $exceptionMessage */ public function testValidateCheckInvalid($operator, $value, $exceptionCode, $exceptionMessage) { $check = $this->getCheckMock(); try { /** @var \OCA\WorkflowEngine\Check\AbstractStringCheck $check */ $check->validateCheck($operator, $value); } catch (\UnexpectedValueException $e) { $this->assertEquals($exceptionCode, $e->getCode()); $this->assertEquals($exceptionMessage, $e->getMessage()); } } public function dataMatch() { return [ ['/valid/', 'valid', [], true], ['/valid/', 'valid', [md5('/valid/') => [md5('valid') => false]], false], // Cache hit ]; } /** * @dataProvider dataMatch * @param string $pattern * @param string $subject * @param array[] $matches * @param bool $expected */ public function testMatch($pattern, $subject, $matches, $expected) { $check = $this->getCheckMock(); $this->invokePrivate($check, 'matches', [$matches]); $this->assertEquals($expected, $this->invokePrivate($check, 'match', [$pattern, $subject])); } }