You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
146 lines
4.0 KiB
146 lines
4.0 KiB
<?php declare(strict_types = 0);
|
|
/*
|
|
** Zabbix
|
|
** Copyright (C) 2001-2023 Zabbix SIA
|
|
**
|
|
** This program is free software; you can redistribute it and/or modify
|
|
** it under the terms of the GNU General Public License as published by
|
|
** the Free Software Foundation; either version 2 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 General Public License for more details.
|
|
**
|
|
** You should have received a copy of the GNU General Public License
|
|
** along with this program; if not, write to the Free Software
|
|
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
**/
|
|
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
abstract class CValidatorTest extends TestCase {
|
|
|
|
abstract public function dataProviderValidParam();
|
|
abstract public function dataProviderValidValues();
|
|
abstract public function dataProviderInvalidValues();
|
|
abstract public function dataProviderInvalidValuesWithObjects();
|
|
|
|
/**
|
|
* Create and return a validator object using the given params.
|
|
*
|
|
* @param array $params
|
|
*
|
|
* @return CValidator
|
|
*/
|
|
abstract protected function createValidator(array $params = []);
|
|
|
|
/**
|
|
* Test creating the validator with a valid set of parameters.
|
|
*
|
|
* @dataProvider dataProviderValidParam
|
|
*
|
|
* @param array $params
|
|
*/
|
|
public function testValidParams(array $params) {
|
|
$validator = $this->createValidator($params);
|
|
foreach ($params as $name => $value) {
|
|
$this->assertEquals($validator->{$name}, $value);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Test trying to create a validator with an invalid set of parameters.
|
|
*/
|
|
public function testInvalidParams() {
|
|
$this->expectException('Exception',
|
|
'Incorrect option "invalidParam" for validator "'.get_class($this->createValidator()).'".'
|
|
);
|
|
|
|
$this->createValidator([
|
|
'invalidParam' => 'value'
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Test setting valid parameters individually.
|
|
*
|
|
* @dataProvider dataProviderValidParam
|
|
*
|
|
* @param array $params
|
|
*/
|
|
public function setValidParamSet(array $params) {
|
|
$validator = $this->createValidator();
|
|
foreach ($params as $name => $value) {
|
|
$validator->{$name} = $value;
|
|
$this->assertEquals($validator->{$name}, $value);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Test trying to set an invalid parameter.
|
|
*/
|
|
public function testInvalidParamSet() {
|
|
$this->expectException('Exception',
|
|
'Incorrect option "invalidParameter" for validator "'.get_class($this->createValidator()).'".'
|
|
);
|
|
|
|
$validator = $this->createValidator();
|
|
$validator->invalidParameter = 'value';
|
|
}
|
|
|
|
/**
|
|
* Test validating values that are valid.
|
|
*
|
|
* @dataProvider dataProviderValidValues()
|
|
*
|
|
* @param array $params
|
|
* @param $value
|
|
*/
|
|
public function testValidateValid(array $params, $value) {
|
|
$validator = $this->createValidator($params);
|
|
$result = $validator->validate($value);
|
|
|
|
$this->assertSame(true, $result);
|
|
$this->assertNull($validator->getError());
|
|
}
|
|
|
|
|
|
/**
|
|
* Test validating values that are invalid and check the generated error message.
|
|
*
|
|
* @dataProvider dataProviderInvalidValues()
|
|
*
|
|
* @param array $params
|
|
* @param mixed $value
|
|
* @param string $expectedError
|
|
*/
|
|
public function testValidateInvalid(array $params, $value, $expectedError) {
|
|
$validator = $this->createValidator($params);
|
|
$result = $validator->validate($value);
|
|
|
|
$this->assertEquals(false, $result);
|
|
$this->assertSame($expectedError, $validator->getError());
|
|
}
|
|
|
|
/**
|
|
* Test that a correct error message is generated when setting an object name.
|
|
*
|
|
* @dataProvider dataProviderInvalidValuesWithObjects()
|
|
*
|
|
* @param array $params
|
|
* @param mixed $value
|
|
* @param string $expectedError
|
|
*/
|
|
public function testValidateInvalidWithObject(array $params, $value, $expectedError) {
|
|
$validator = $this->createValidator($params);
|
|
$validator->setObjectName('object');
|
|
$result = $validator->validate($value);
|
|
|
|
$this->assertEquals(false, $result);
|
|
$this->assertSame($expectedError, $validator->getError());
|
|
}
|
|
}
|