-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathTimerTest.php
More file actions
77 lines (66 loc) · 1.91 KB
/
TimerTest.php
File metadata and controls
77 lines (66 loc) · 1.91 KB
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
<?php declare(strict_types=1);
namespace Tests\Metric;
use PHPUnit\Framework\TestCase;
/**
* 测试 php-metric\Metric\Timer
*
* @author fdipzone
*/
final class TimerTest extends TestCase
{
/**
* @covers \Metric\Timer::__construct
*/
public function testConstruct()
{
$max_seconds = 3;
$timer_metric = new \Metric\Timer($max_seconds);
$this->assertEquals('Metric\Timer', get_class($timer_metric));
$this->assertInstanceOf(\Metric\IMetric::class, $timer_metric);
$this->assertInstanceOf(\Metric\IMetricCallback::class, $timer_metric);
}
/**
* @covers \Metric\Timer::__construct
*/
public function testConstructException()
{
$this->expectException(\Exception::class);
$this->expectExceptionMessage('max seconds must be greater than 0');
$max_seconds = 0;
new \Metric\Timer($max_seconds);
}
/**
* @covers \Metric\Timer::next
* @covers \Metric\Timer::setCallback
*/
public function testNext()
{
$callback_result = '';
$callback = function() use (&$callback_result)
{
$callback_result = 'ok';
};
$max_seconds = 2;
$timer_metric = new \Metric\Timer($max_seconds);
$timer_metric->setCallback($callback);
$ret = $timer_metric->next();
$this->assertTrue($ret);
usleep(600*1000);
$ret = $timer_metric->next();
$this->assertTrue($ret);
usleep(1600*1000);
$ret = $timer_metric->next();
$this->assertFalse($ret);
$this->assertEquals('ok', $callback_result);
}
/**
* @covers \Metric\Timer::setCallback
*/
public function testSetCallbackException()
{
$this->expectException(\TypeError::class);
$max_seconds = 3;
$timer_metric = new \Metric\Timer($max_seconds);
$timer_metric->setCallback('abc');
}
}