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
|
<?php
class Benchmark_test extends CI_TestCase {
public function set_up()
{
$this->benchmark = new CI_Benchmark();
}
// --------------------------------------------------------------------
public function test_mark()
{
$this->assertEmpty($this->benchmark->marker);
$this->benchmark->mark('code_start');
$this->assertCount(1, $this->benchmark->marker);
$this->assertArrayHasKey('code_start', $this->benchmark->marker);
}
// --------------------------------------------------------------------
public function test_elapsed_time()
{
$this->assertEquals('{elapsed_time}', $this->benchmark->elapsed_time());
$this->assertEmpty($this->benchmark->elapsed_time('undefined_point'));
$this->benchmark->mark('code_start');
$this->benchmark->mark('code_end');
// Override values, because time isn't testable, but make sure the markers were set
if (isset($this->benchmark->marker['code_start']) && is_float($this->benchmark->marker['code_start']))
{
$this->benchmark->marker['code_start'] = 1389956144.1944;
}
if (isset($this->benchmark->marker['code_end']) && is_float($this->benchmark->marker['code_end']))
{
$this->benchmark->marker['code_end'] = 1389956145.1946;
}
$this->assertEquals('1', $this->benchmark->elapsed_time('code_start', 'code_end', 0));
$this->assertEquals('1.0', $this->benchmark->elapsed_time('code_start', 'code_end', 1));
$this->assertEquals('1.00', $this->benchmark->elapsed_time('code_start', 'code_end', 2));
$this->assertEquals('1.000', $this->benchmark->elapsed_time('code_start', 'code_end', 3));
$this->assertEquals('1.0002', $this->benchmark->elapsed_time('code_start', 'code_end', 4));
$this->assertEquals('1.0002', $this->benchmark->elapsed_time('code_start', 'code_end'));
// Test with non-existing 2nd marker, but again - we need to override the value
$this->benchmark->elapsed_time('code_start', 'code_end2');
if (isset($this->benchmark->marker['code_end2']) && is_float($this->benchmark->marker['code_end2']))
{
$this->benchmark->marker['code_end2'] = 1389956146.2046;
}
$this->assertEquals('2.0102', $this->benchmark->elapsed_time('code_start', 'code_end2'));
}
// --------------------------------------------------------------------
public function test_memory_usage()
{
$this->assertEquals('{memory_usage}', $this->benchmark->memory_usage());
}
}
|