-
-
Notifications
You must be signed in to change notification settings - Fork 9.4k
/
MarkingTest.php
91 lines (69 loc) · 2.47 KB
/
MarkingTest.php
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Workflow\Tests;
use PHPUnit\Framework\TestCase;
use Symfony\Component\Workflow\Marking;
class MarkingTest extends TestCase
{
public function testMarking()
{
$marking = new Marking(['a' => 1]);
$this->assertTrue($marking->has('a'));
$this->assertFalse($marking->has('b'));
$this->assertPlaces(['a' => 1], $marking);
$marking->mark('b');
$this->assertTrue($marking->has('a'));
$this->assertTrue($marking->has('b'));
$this->assertPlaces(['a' => 1, 'b' => 1], $marking);
$marking->unmark('a');
$this->assertFalse($marking->has('a'));
$this->assertTrue($marking->has('b'));
$this->assertPlaces(['b' => 1], $marking);
$marking->unmark('b');
$this->assertFalse($marking->has('a'));
$this->assertFalse($marking->has('b'));
$this->assertPlaces([], $marking);
$marking->mark('a');
$this->assertPlaces(['a' => 1], $marking);
$marking->mark('a');
$this->assertPlaces(['a' => 2], $marking);
$marking->unmark('a');
$this->assertPlaces(['a' => 1], $marking);
$marking->unmark('a');
$this->assertPlaces([], $marking);
}
public function testGuardNotMarked()
{
$marking = new Marking([]);
$this->expectException(\LogicException::class);
$this->expectExceptionMessage('The place "a" is not marked.');
$marking->unmark('a');
}
public function testGuardNotNbTokenLowerThanZero()
{
$marking = new Marking(['a' => 1]);
$this->expectException(\LogicException::class);
$this->expectExceptionMessage('The place "a" could not contain a negative token number.');
$marking->unmark('a', 2);
}
public function testGuardNotNbTokenEquals0()
{
$marking = new Marking(['a' => 1]);
$this->expectException(\LogicException::class);
$this->expectExceptionMessage('The number of tokens must be greater than 0, "0" given.');
$marking->unmark('a', 0);
}
private function assertPlaces(array $expected, Marking $marking)
{
$places = $marking->getPlaces();
ksort($places);
$this->assertSame($expected, $places);
}
}