* @copyright 2007-2022 Kjell-Inge Gustafsson, kigkonsult, All rights reserved * @link https://kigkonsult.se * @license Subject matter of licence is the software iCalcreator. * The above copyright, link, package and version notices, * this licence notice and the invariant [rfc5545] PRODID result use * as implemented and invoked in iCalcreator shall be included in * all copies or substantial portions of the iCalcreator. * * iCalcreator is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * iCalcreator 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with iCalcreator. If not, see . */ namespace Kigkonsult\Icalcreator; use InvalidArgumentException; use PHPUnit\Framework\TestCase; use Kigkonsult\Icalcreator\Util\StringFactory; /** * class Exception7Test * * Testing exceptions TZOFFSETFROM and TZOFFSETTO * * @since 2.27.14 - 2019-02-27 */ class Exception7Test extends TestCase { /** * DateIntervalFactoryTest provider * * @return mixed[] */ public function DateIntervalFactoryTestProvider() : array { $dataArr = []; $dataArr[] = [ 11, IcalInterface::TZOFFSETFROM, null, [ IcalInterface::ALLOWEMPTY => false ] ]; $dataArr[] = [ 11, IcalInterface::TZOFFSETFROM, 'abc', [] ]; $dataArr[] = [ 21, IcalInterface::TZOFFSETTO, null, [ IcalInterface::ALLOWEMPTY => false ] ]; $dataArr[] = [ 21, IcalInterface::TZOFFSETTO, 'abc', [] ]; return $dataArr; } /** * Testing DateInterval::factory * * @test * @dataProvider DateIntervalFactoryTestProvider * @param int $case * @param string $property * @param string|null $value * @param mixed[] $config */ public function DateIntervalFactoryTest( int $case, string $property, string $value = null, array $config = [] ) : void { $standard = new Standard( $config ); $method = StringFactory::getSetMethodName( $property ); $ok = false; try { $standard->{$method}( $value ); } catch ( InvalidArgumentException $e ) { $ok = true; } $this->assertTrue( $ok, 'error in case #' . $case ); } }