99 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| <?php
 | |
| /*
 | |
|  * This file is part of the PHP_Timer package.
 | |
|  *
 | |
|  * (c) Sebastian Bergmann <sebastian@phpunit.de>
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| use PHPUnit\Framework\TestCase;
 | |
| 
 | |
| class PHP_TimerTest extends TestCase
 | |
| {
 | |
|     /**
 | |
|      * @covers PHP_Timer::start
 | |
|      * @covers PHP_Timer::stop
 | |
|      */
 | |
|     public function testStartStop()
 | |
|     {
 | |
|         $this->assertInternalType('float', PHP_Timer::stop());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers       PHP_Timer::secondsToTimeString
 | |
|      * @dataProvider secondsProvider
 | |
|      */
 | |
|     public function testSecondsToTimeString($string, $seconds)
 | |
|     {
 | |
|         $this->assertEquals(
 | |
|             $string,
 | |
|             PHP_Timer::secondsToTimeString($seconds)
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers PHP_Timer::timeSinceStartOfRequest
 | |
|      */
 | |
|     public function testTimeSinceStartOfRequest()
 | |
|     {
 | |
|         $this->assertStringMatchesFormat(
 | |
|             '%f %s',
 | |
|             PHP_Timer::timeSinceStartOfRequest()
 | |
|         );
 | |
|     }
 | |
| 
 | |
| 
 | |
|     /**
 | |
|      * @covers PHP_Timer::resourceUsage
 | |
|      */
 | |
|     public function testResourceUsage()
 | |
|     {
 | |
|         $this->assertStringMatchesFormat(
 | |
|             'Time: %s, Memory: %fMB',
 | |
|             PHP_Timer::resourceUsage()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     public function secondsProvider()
 | |
|     {
 | |
|         return array(
 | |
|           array('0 ms', 0),
 | |
|           array('1 ms', .001),
 | |
|           array('10 ms', .01),
 | |
|           array('100 ms', .1),
 | |
|           array('999 ms', .999),
 | |
|           array('1 second', .9999),
 | |
|           array('1 second', 1),
 | |
|           array('2 seconds', 2),
 | |
|           array('59.9 seconds', 59.9),
 | |
|           array('59.99 seconds', 59.99),
 | |
|           array('59.99 seconds', 59.999),
 | |
|           array('1 minute', 59.9999),
 | |
|           array('59 seconds', 59.001),
 | |
|           array('59.01 seconds', 59.01),
 | |
|           array('1 minute', 60),
 | |
|           array('1.01 minutes', 61),
 | |
|           array('2 minutes', 120),
 | |
|           array('2.01 minutes', 121),
 | |
|           array('59.99 minutes', 3599.9),
 | |
|           array('59.99 minutes', 3599.99),
 | |
|           array('59.99 minutes', 3599.999),
 | |
|           array('1 hour', 3599.9999),
 | |
|           array('59.98 minutes', 3599.001),
 | |
|           array('59.98 minutes', 3599.01),
 | |
|           array('1 hour', 3600),
 | |
|           array('1 hour', 3601),
 | |
|           array('1 hour', 3601.9),
 | |
|           array('1 hour', 3601.99),
 | |
|           array('1 hour', 3601.999),
 | |
|           array('1 hour', 3601.9999),
 | |
|           array('1.01 hours', 3659.9999),
 | |
|           array('1.01 hours', 3659.001),
 | |
|           array('1.01 hours', 3659.01),
 | |
|           array('2 hours', 7199.9999),
 | |
|         );
 | |
|     }
 | |
| }
 | 
