|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
namespace Cgi\Calc\Tests\Point; |
|
4
|
|
|
|
|
5
|
|
|
use Cgi\Calc\Point; |
|
6
|
|
|
use Cgi\Calc\Point\PointSet; |
|
7
|
|
|
|
|
8
|
|
|
class PointSetTest extends \PHPUnit_Framework_TestCase |
|
9
|
|
|
{ |
|
10
|
|
|
public function test_index_data_with_points() |
|
11
|
|
|
{ |
|
12
|
|
|
$set = new PointSet(); |
|
13
|
|
|
$set->attach($p11 = new Point(1,1), $v11 = 'v11'); |
|
14
|
|
|
|
|
15
|
|
|
static::assertTrue($set->contains($p11)); |
|
16
|
|
|
static::assertEquals($set[$p11], $v11); |
|
17
|
|
|
} |
|
18
|
|
|
|
|
19
|
|
|
public function test_union() |
|
20
|
|
|
{ |
|
21
|
|
|
$a = new PointSet([new Point(1,1), new Point(2,2), new Point(3,3)]); |
|
22
|
|
|
$b = new PointSet([new Point(3,1), new Point(2,2), new Point(1,3)]); |
|
23
|
|
|
$r = $a->union($b); |
|
24
|
|
|
|
|
25
|
|
|
static::assertEquals(3, $a->count()); |
|
26
|
|
|
static::assertEquals(3, $b->count()); |
|
27
|
|
|
static::assertEquals(5, $r->count()); |
|
28
|
|
|
static::assertNotSame($r, $a); |
|
29
|
|
|
static::assertNotSame($r, $b); |
|
30
|
|
|
|
|
31
|
|
|
foreach ($a as $point) { |
|
32
|
|
|
static::assertTrue($r->contains($point)); |
|
33
|
|
|
} |
|
34
|
|
|
foreach ($b as $point) { |
|
35
|
|
|
static::assertTrue($r->contains($point)); |
|
36
|
|
|
} |
|
37
|
|
|
} |
|
38
|
|
|
|
|
39
|
|
|
public function test_intersect() |
|
40
|
|
|
{ |
|
41
|
|
|
$a = new PointSet([new Point(1,1), new Point(2,2), new Point(3,3)]); |
|
42
|
|
|
$b = new PointSet([new Point(3,1), new Point(2,2), new Point(1,3)]); |
|
43
|
|
|
$r = $a->intersect($b); |
|
44
|
|
|
|
|
45
|
|
|
static::assertEquals(3, $a->count()); |
|
46
|
|
|
static::assertEquals(3, $b->count()); |
|
47
|
|
|
static::assertEquals(1, $r->count()); |
|
48
|
|
|
static::assertNotSame($r, $a); |
|
49
|
|
|
static::assertNotSame($r, $b); |
|
50
|
|
|
|
|
51
|
|
|
static::assertTrue($r->contains(new Point(2,2))); |
|
52
|
|
|
} |
|
53
|
|
|
|
|
54
|
|
|
public function test_diff() |
|
55
|
|
|
{ |
|
56
|
|
|
$a = new PointSet([new Point(1,1), new Point(2,2), new Point(3,3)]); |
|
57
|
|
|
$b = new PointSet([new Point(3,1), new Point(2,2), new Point(1,3)]); |
|
58
|
|
|
$r = $a->diff($b); |
|
59
|
|
|
|
|
60
|
|
|
static::assertEquals(3, $a->count()); |
|
61
|
|
|
static::assertEquals(3, $b->count()); |
|
62
|
|
|
static::assertEquals(2, $r->count()); |
|
63
|
|
|
static::assertNotSame($r, $a); |
|
64
|
|
|
static::assertNotSame($r, $b); |
|
65
|
|
|
|
|
66
|
|
|
static::assertTrue($r->contains(new Point(1,1))); |
|
67
|
|
|
static::assertTrue($r->contains(new Point(3,3))); |
|
68
|
|
|
} |
|
69
|
|
|
} |
|
70
|
|
|
|