1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130
|
<?php
declare(strict_types=1);
namespace Cron\Tests;
use Cron\MinutesField;
use DateTime;
use DateTimeImmutable;
use PHPUnit\Framework\TestCase;
/**
* @author Michael Dowling <mtdowling@gmail.com>
*/
class MinutesFieldTest extends TestCase
{
/**
* @covers \Cron\MinutesField::validate
*/
public function testValidatesField(): void
{
$f = new MinutesField();
$this->assertTrue($f->validate('1'));
$this->assertTrue($f->validate('*'));
$this->assertTrue($f->validate('*/3,1,1-12'));
$this->assertFalse($f->validate('1/10'));
}
/**
* @covers \Cron\MinutesField::isSatisfiedBy
*/
public function testChecksIfSatisfied(): void
{
$f = new MinutesField();
$this->assertTrue($f->isSatisfiedBy(new DateTime(), '?', false));
$this->assertTrue($f->isSatisfiedBy(new DateTimeImmutable(), '?', false));
}
/**
* @covers \Cron\MinutesField::increment
*/
public function testIncrementsDate(): void
{
$d = new DateTime('2011-03-15 11:15:00');
$f = new MinutesField();
$f->increment($d);
$this->assertSame('2011-03-15 11:16:00', $d->format('Y-m-d H:i:s'));
$f->increment($d, true);
$this->assertSame('2011-03-15 11:15:00', $d->format('Y-m-d H:i:s'));
}
/**
* @covers \Cron\MinutesField::increment
*/
public function testIncrementsDateTimeImmutable(): void
{
$d = new DateTimeImmutable('2011-03-15 11:15:00');
$f = new MinutesField();
$f->increment($d);
$this->assertSame('2011-03-15 11:16:00', $d->format('Y-m-d H:i:s'));
}
/**
* Various bad syntaxes that are reported to work, but shouldn't.
*
* @author Chris Tankersley
*
* @since 2017-08-18
*/
public function testBadSyntaxesShouldNotValidate(): void
{
$f = new MinutesField();
$this->assertFalse($f->validate('*-1'));
$this->assertFalse($f->validate('1-2-3'));
$this->assertFalse($f->validate('-1'));
}
/**
* Ranges that are invalid should not validate.
* In this case `0/5` would be invalid because `0` is not part of the minute range.
*
* @author Chris Tankersley
* @since 2019-07-29
* @see https://github.com/dragonmantank/cron-expression/issues/18
*/
public function testInvalidRangeShouldNotValidate(): void
{
$f = new MinutesField();
$this->assertFalse($f->validate('0/5'));
}
/**
* @covers \Cron\MinutesField::increment
*/
public function testIncrementAcrossDstChangeBerlin(): void
{
$tz = new \DateTimeZone("Europe/Berlin");
$d = \DateTimeImmutable::createFromFormat("!Y-m-d H:i:s", "2021-03-28 01:59:00", $tz);
$f = new MinutesField();
$f->increment($d);
$this->assertSame("2021-03-28 03:00:00", $d->format("Y-m-d H:i:s"));
$f->increment($d, true);
$this->assertSame("2021-03-28 01:59:00", $d->format("Y-m-d H:i:s"));
$f->increment($d, true);
$this->assertSame("2021-03-28 01:58:00", $d->format("Y-m-d H:i:s"));
}
/**
* @covers \Cron\MinutesField::increment
*/
public function testIncrementAcrossDstChangeLondon(): void
{
$tz = new \DateTimeZone("Europe/London");
$d = \DateTimeImmutable::createFromFormat("!Y-m-d H:i:s", "2021-03-28 00:59:00", $tz);
$f = new MinutesField();
$f->increment($d);
$this->assertSame("2021-03-28 02:00:00", $d->format("Y-m-d H:i:s"));
$f->increment($d);
$this->assertSame("2021-03-28 02:01:00", $d->format("Y-m-d H:i:s"));
$f->increment($d, true);
$this->assertSame("2021-03-28 02:00:00", $d->format("Y-m-d H:i:s"));
$f->increment($d, true);
$this->assertSame("2021-03-28 00:59:00", $d->format("Y-m-d H:i:s"));
$f->increment($d, true);
$this->assertSame("2021-03-28 00:58:00", $d->format("Y-m-d H:i:s"));
}
}
|