 1ac0f42a58
			
		
	
	1ac0f42a58
	
	
	
		
			
			Travis config update Removed HHVM script as Laravel no longer support HHVM after releasing 5.3
		
			
				
	
	
		
			140 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Cron\Tests;
 | |
| 
 | |
| use Cron\DayOfWeekField;
 | |
| use Cron\HoursField;
 | |
| use Cron\MinutesField;
 | |
| use Cron\MonthField;
 | |
| use PHPUnit\Framework\TestCase;
 | |
| 
 | |
| /**
 | |
|  * @author Michael Dowling <mtdowling@gmail.com>
 | |
|  */
 | |
| class AbstractFieldTest extends TestCase
 | |
| {
 | |
|     /**
 | |
|      * @covers \Cron\AbstractField::isRange
 | |
|      */
 | |
|     public function testTestsIfRange()
 | |
|     {
 | |
|         $f = new DayOfWeekField();
 | |
|         $this->assertTrue($f->isRange('1-2'));
 | |
|         $this->assertFalse($f->isRange('2'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \Cron\AbstractField::isIncrementsOfRanges
 | |
|      */
 | |
|     public function testTestsIfIncrementsOfRanges()
 | |
|     {
 | |
|         $f = new DayOfWeekField();
 | |
|         $this->assertFalse($f->isIncrementsOfRanges('1-2'));
 | |
|         $this->assertTrue($f->isIncrementsOfRanges('1/2'));
 | |
|         $this->assertTrue($f->isIncrementsOfRanges('*/2'));
 | |
|         $this->assertTrue($f->isIncrementsOfRanges('3-12/2'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \Cron\AbstractField::isInRange
 | |
|      */
 | |
|     public function testTestsIfInRange()
 | |
|     {
 | |
|         $f = new DayOfWeekField();
 | |
|         $this->assertTrue($f->isInRange('1', '1-2'));
 | |
|         $this->assertTrue($f->isInRange('2', '1-2'));
 | |
|         $this->assertTrue($f->isInRange('5', '4-12'));
 | |
|         $this->assertFalse($f->isInRange('3', '4-12'));
 | |
|         $this->assertFalse($f->isInRange('13', '4-12'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \Cron\AbstractField::isInIncrementsOfRanges
 | |
|      */
 | |
|     public function testTestsIfInIncrementsOfRangesOnZeroStartRange()
 | |
|     {
 | |
|         $f = new MinutesField();
 | |
|         $this->assertTrue($f->isInIncrementsOfRanges('3', '3-59/2'));
 | |
|         $this->assertTrue($f->isInIncrementsOfRanges('13', '3-59/2'));
 | |
|         $this->assertTrue($f->isInIncrementsOfRanges('15', '3-59/2'));
 | |
|         $this->assertTrue($f->isInIncrementsOfRanges('14', '*/2'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('2', '3-59/13'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('14', '*/13'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('14', '3-59/2'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('3', '2-59'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('3', '2'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('3', '*'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('0', '*/0'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('1', '*/0'));
 | |
| 
 | |
|         $this->assertTrue($f->isInIncrementsOfRanges('4', '4/1'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('14', '4/1'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('34', '4/1'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \Cron\AbstractField::isInIncrementsOfRanges
 | |
|      */
 | |
|     public function testTestsIfInIncrementsOfRangesOnOneStartRange()
 | |
|     {
 | |
|         $f = new MonthField();
 | |
|         $this->assertTrue($f->isInIncrementsOfRanges('3', '3-12/2'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('13', '3-12/2'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('15', '3-12/2'));
 | |
|         $this->assertTrue($f->isInIncrementsOfRanges('3', '*/2'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('3', '*/3'));
 | |
|         $this->assertTrue($f->isInIncrementsOfRanges('7', '*/3'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('14', '3-12/2'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('3', '2-12'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('3', '2'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('3', '*'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('0', '*/0'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('1', '*/0'));
 | |
| 
 | |
|         $this->assertTrue($f->isInIncrementsOfRanges('4', '4/1'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('14', '4/1'));
 | |
|         $this->assertFalse($f->isInIncrementsOfRanges('34', '4/1'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers \Cron\AbstractField::isSatisfied
 | |
|      */
 | |
|     public function testTestsIfSatisfied()
 | |
|     {
 | |
|         $f = new DayOfWeekField();
 | |
|         $this->assertTrue($f->isSatisfied('12', '3-13'));
 | |
|         $this->assertFalse($f->isSatisfied('15', '3-7/2'));
 | |
|         $this->assertTrue($f->isSatisfied('12', '*'));
 | |
|         $this->assertTrue($f->isSatisfied('12', '12'));
 | |
|         $this->assertFalse($f->isSatisfied('12', '3-11'));
 | |
|         $this->assertFalse($f->isSatisfied('12', '3-7/2'));
 | |
|         $this->assertFalse($f->isSatisfied('12', '11'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Allows ranges and lists to coexist in the same expression
 | |
|      *
 | |
|      * @see https://github.com/dragonmantank/cron-expression/issues/5
 | |
|      */
 | |
|     public function testAllowRangesAndLists()
 | |
|     {
 | |
|         $expression = '5-7,11-13';
 | |
|         $f = new HoursField();
 | |
|         $this->assertTrue($f->validate($expression));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Makes sure that various types of ranges expand out properly
 | |
|      *
 | |
|      * @see https://github.com/dragonmantank/cron-expression/issues/5
 | |
|      */
 | |
|     public function testGetRangeForExpressionExpandsCorrectly()
 | |
|     {
 | |
|         $f = new HoursField();
 | |
|         $this->assertSame([5, 6, 7, 11, 12, 13], $f->getRangeForExpression('5-7,11-13', 23));
 | |
|         $this->assertSame(['5', '6', '7', '11', '12', '13'], $f->getRangeForExpression('5,6,7,11,12,13', 23));
 | |
|         $this->assertSame([0, 6, 12, 18], $f->getRangeForExpression('*/6', 23));
 | |
|         $this->assertSame([5, 11], $f->getRangeForExpression('5-13/6', 23));
 | |
|     }
 | |
| }
 |