server/apps/workflowengine/tests/Check/AbstractStringCheckTest.php

150 lines
4.2 KiB
PHP
Raw Normal View History

2016-07-28 09:44:22 +00:00
<?php
/**
* @copyright Copyright (c) 2016 Joas Schilling <coding@schilljs.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\WorkflowEngine\Tests\Check;
class AbstractStringCheckTest extends \Test\TestCase {
2016-08-01 15:56:33 +00:00
protected function getCheckMock() {
$l = $this->getMockBuilder('OCP\IL10N')
->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;
}
2016-07-28 09:44:22 +00:00
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) {
2016-08-01 15:56:33 +00:00
$check = $this->getCheckMock();
2016-07-28 09:44:22 +00:00
/** @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) {
2016-08-01 15:56:33 +00:00
$check = $this->getCheckMock();
2016-07-28 09:44:22 +00:00
/** @var \OCA\WorkflowEngine\Check\AbstractStringCheck $check */
$check->validateCheck($operator, $value);
}
public function dataValidateCheckInvalid() {
return [
2016-08-01 15:56:33 +00:00
['!!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'],
2016-07-28 09:44:22 +00:00
];
}
/**
* @dataProvider dataValidateCheckInvalid
* @param $operator
* @param $value
* @param $exceptionCode
* @param $exceptionMessage
*/
public function testValidateCheckInvalid($operator, $value, $exceptionCode, $exceptionMessage) {
2016-08-01 15:56:33 +00:00
$check = $this->getCheckMock();
2016-07-28 09:44:22 +00:00
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) {
2016-08-01 15:56:33 +00:00
$check = $this->getCheckMock();
2016-07-28 09:44:22 +00:00
$this->invokePrivate($check, 'matches', [$matches]);
$this->assertEquals($expected, $this->invokePrivate($check, 'match', [$pattern, $subject]));
}
}