215 lines
5.7 KiB
PHP
215 lines
5.7 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* iCalcreator, the PHP class package managing iCal (rfc2445/rfc5445) calendar information.
|
||
|
*
|
||
|
* This file is a part of iCalcreator.
|
||
|
*
|
||
|
* @author Kjell-Inge Gustafsson, kigkonsult <ical@kigkonsult.se>
|
||
|
* @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 <https://www.gnu.org/licenses/>.
|
||
|
*/
|
||
|
namespace Kigkonsult\Icalcreator;
|
||
|
|
||
|
use Exception;
|
||
|
use Kigkonsult\Icalcreator\Util\DateTimeFactory;
|
||
|
use PHPUnit\Framework\TestCase;
|
||
|
use ValueError;
|
||
|
|
||
|
/**
|
||
|
* class Exception1Test
|
||
|
*
|
||
|
* Testing exceptions in DateTimeFactory, DateTimeZoneFactory and DateIntervalFactory
|
||
|
*
|
||
|
* @since 2.27.14 - 2019-02-27
|
||
|
*/
|
||
|
class Exception1Test extends TestCase
|
||
|
{
|
||
|
/**
|
||
|
* DateTimeFactoryFactoryTest provider
|
||
|
*
|
||
|
* @return mixed[]
|
||
|
*/
|
||
|
public function DateTimeFactoryFactoryTestProvider() : array
|
||
|
{
|
||
|
$dataArr = [];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
1,
|
||
|
'@1',
|
||
|
'invalid/timezone',
|
||
|
];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
1,
|
||
|
'@1111111111111111111111111111111111111111111111111111111111111111111111111',
|
||
|
'invalid/timezone',
|
||
|
];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
2,
|
||
|
'@1',
|
||
|
chr(0),
|
||
|
];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
3,
|
||
|
'@1',
|
||
|
'invalid/timezone',
|
||
|
];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
4,
|
||
|
'invalid timezonestring',
|
||
|
'invalid/timezone',
|
||
|
];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
5,
|
||
|
'now',
|
||
|
'invalid/timezone',
|
||
|
];
|
||
|
|
||
|
return $dataArr;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Testing DateTimeFactory::factory
|
||
|
*
|
||
|
* @test
|
||
|
* @dataProvider DateTimeFactoryFactoryTestProvider
|
||
|
* @param int $case
|
||
|
* @param string $dateTimeString
|
||
|
* @param string $timezoneString
|
||
|
*/
|
||
|
public function DateTimeFactoryFactoryTest( int $case, string $dateTimeString, string $timezoneString ) : void
|
||
|
{
|
||
|
$ok = false;
|
||
|
try {
|
||
|
$dateTime = DateTimeFactory::factory( $dateTimeString, $timezoneString );
|
||
|
}
|
||
|
catch ( ValueError $e ) {
|
||
|
$ok = true;
|
||
|
}
|
||
|
catch ( Exception $e ) {
|
||
|
$ok = true;
|
||
|
}
|
||
|
$this->assertTrue( $ok, 'error in case #' . $case );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* DateTimeFactoryGetYmdFromTimestampTest provider
|
||
|
* @throws Exception
|
||
|
*/
|
||
|
public function DateTimeFactoryGetYmdFromTimestampTestProvider() : array
|
||
|
{
|
||
|
$dataArr = [];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
1,
|
||
|
'1111111111111111111111111111111111111111111111111111111111111111111111111',
|
||
|
'invalid/timezone',
|
||
|
];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
2,
|
||
|
'1',
|
||
|
'invalid/timezone',
|
||
|
];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
3,
|
||
|
DateTimeFactory::factory( 'now' )->getTimestamp(),
|
||
|
'invalid/timezone',
|
||
|
];
|
||
|
|
||
|
|
||
|
return $dataArr;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Testing DateTimeFactory::getYmdFromTimestamp
|
||
|
*
|
||
|
* @test
|
||
|
* @dataProvider DateTimeFactoryGetYmdFromTimestampTestProvider
|
||
|
* @param int $case
|
||
|
* @param string|int $dateTimeString
|
||
|
* @param string $timezoneString
|
||
|
*/
|
||
|
public function getYmdFromTimestampTest( int $case, string|int $dateTimeString, string $timezoneString ) : void
|
||
|
{
|
||
|
$ok = false;
|
||
|
try {
|
||
|
$dateTime = DateTimeFactory::factory( $dateTimeString, $timezoneString )
|
||
|
->format( DateTimeFactory::$Ymd );
|
||
|
}
|
||
|
catch ( Exception $e ) {
|
||
|
$ok = true;
|
||
|
}
|
||
|
$this->assertTrue( $ok, 'error in case #' . $case );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* DateTimeFactorySetDateTest provider
|
||
|
*
|
||
|
* @return mixed[]
|
||
|
* @throws Exception
|
||
|
*/
|
||
|
public function DateTimeFactorySetDateTestProvider() : array
|
||
|
{
|
||
|
$dataArr = [];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
1,
|
||
|
DateTimeFactory::factory( 'now' ),
|
||
|
[ IcalInterface::TZID => 'invalid/timezone' ]
|
||
|
];
|
||
|
|
||
|
$dataArr[] = [
|
||
|
19,
|
||
|
'011201010101',
|
||
|
[ IcalInterface::TZID => 'invalid/timezone']
|
||
|
];
|
||
|
|
||
|
return $dataArr;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Testing DateTimeFactory::setDate
|
||
|
*
|
||
|
* @test
|
||
|
* @dataProvider DateTimeFactorySetDateTestProvider
|
||
|
* @param int $case
|
||
|
* @param mixed $value
|
||
|
* @param mixed[] $params
|
||
|
*/
|
||
|
public function DateTimeFactorySetDateTest( int $case, mixed $value, array $params ) : void
|
||
|
{
|
||
|
$ok = false;
|
||
|
try {
|
||
|
$result = DateTimeFactory::setDate( Pc::factory( $value, $params ));
|
||
|
}
|
||
|
catch ( Exception $e ) {
|
||
|
$ok = true;
|
||
|
}
|
||
|
$this->assertTrue( $ok, 'error in case #' . $case );
|
||
|
}
|
||
|
}
|