|
1
|
|
|
<?php namespace Unit\Chekote\NounStore\Store; |
|
2
|
|
|
|
|
3
|
|
|
use Unit\Chekote\NounStore\Key\KeyTest; |
|
4
|
|
|
use Unit\Chekote\Phake\Phake; |
|
5
|
|
|
use InvalidArgumentException; |
|
6
|
|
|
|
|
7
|
|
|
/** |
|
8
|
|
|
* @covers \Chekote\NounStore\Store::get() |
|
9
|
|
|
*/ |
|
10
|
|
|
class GetTest extends StoreTest |
|
11
|
|
|
{ |
|
12
|
|
|
public function setUp() |
|
13
|
|
|
{ |
|
14
|
|
|
parent::setUp(); |
|
15
|
|
|
|
|
16
|
|
|
/* @noinspection PhpUndefinedMethodInspection */ |
|
17
|
|
|
Phake::when($this->store)->get(Phake::anyParameters())->thenCallParent(); |
|
|
|
|
|
|
18
|
|
|
} |
|
19
|
|
|
|
|
20
|
|
|
public function testKeyIsParsedAndParsedValuesAreUsed() |
|
21
|
|
|
{ |
|
22
|
|
|
$key = '2nd ' . StoreTest::KEY; |
|
23
|
|
|
$parsedKey = StoreTest::KEY; |
|
24
|
|
|
$parsedIndex = 1; |
|
25
|
|
|
|
|
26
|
|
|
/* @noinspection PhpUndefinedMethodInspection */ |
|
27
|
|
|
Phake::expect($this->key, 1)->parse($key)->thenReturn([[$parsedKey, $parsedIndex]]); |
|
|
|
|
|
|
28
|
|
|
|
|
29
|
|
|
$this->assertEquals(StoreTest::$SECOND_VALUE, $this->store->get($key)); |
|
|
|
|
|
|
30
|
|
|
} |
|
31
|
|
|
|
|
32
|
|
|
public function testInvalidArgumentExceptionBubblesUpFromParse() |
|
33
|
|
|
{ |
|
34
|
|
|
$exception = new InvalidArgumentException('Key syntax is invalid'); |
|
35
|
|
|
|
|
36
|
|
|
/* @noinspection PhpUndefinedMethodInspection */ |
|
37
|
|
|
Phake::expect($this->key, 1)->parse(KeyTest::INVALID_KEY)->thenThrow($exception); |
|
|
|
|
|
|
38
|
|
|
|
|
39
|
|
|
$this->expectException(get_class($exception)); |
|
40
|
|
|
$this->expectExceptionMessage($exception->getMessage()); |
|
41
|
|
|
|
|
42
|
|
|
$this->store->get(KeyTest::INVALID_KEY); |
|
43
|
|
|
} |
|
44
|
|
|
|
|
45
|
|
|
/** |
|
46
|
|
|
* @dataProvider happyPathProvider |
|
47
|
|
|
* @param string $key the key to fetch. |
|
48
|
|
|
* @param array[] $parsedKey the parsed key. |
|
49
|
|
|
* @param mixed $expected the expected value. |
|
50
|
|
|
*/ |
|
51
|
|
|
public function testHappyPath($key, $parsedKey, $expected) |
|
52
|
|
|
{ |
|
53
|
|
|
/* @noinspection PhpUndefinedMethodInspection */ |
|
54
|
|
|
Phake::expect($this->key, 1)->parse($key)->thenReturn($parsedKey); |
|
|
|
|
|
|
55
|
|
|
|
|
56
|
|
|
$this->assertEquals($expected, $this->store->get($key)); |
|
57
|
|
|
} |
|
58
|
|
|
|
|
59
|
|
|
public function happyPathProvider() |
|
60
|
|
|
{ |
|
61
|
|
|
return [ |
|
62
|
|
|
// key parsed key expected |
|
63
|
|
|
'Noun without index returns most recent noun' => [StoreTest::KEY, [[StoreTest::KEY, null]], StoreTest::$MOST_RECENT_VALUE], |
|
64
|
|
|
'Noun with index returns specific noun' => ['1st ' . StoreTest::KEY, [[StoreTest::KEY, 0]], StoreTest::$FIRST_VALUE], |
|
65
|
|
|
'Non-existent noun returns null' => ['3rd ' . StoreTest::KEY, [[StoreTest::KEY, 2]], null], |
|
66
|
|
|
'Possessive noun w/o index string property' => [StoreTest::KEY . "'s color", [[StoreTest::KEY, null], ['color', null]], 'Blue'], |
|
67
|
|
|
'Possessive noun with index string property' => ['1st ' . StoreTest::KEY . "'s color", [[StoreTest::KEY, 0], ['color', null]], 'Red'], |
|
68
|
|
|
'Possessive noun w/o index collection w/o index' => [StoreTest::KEY . "'s option", [[StoreTest::KEY, null], ['option', null]], 'Air Conditioning'], |
|
69
|
|
|
'Possessive noun with index collection w/o index' => ['1st ' . StoreTest::KEY . "'s option", [[StoreTest::KEY, 0], ['option', null]], 'Heated Seats'], |
|
70
|
|
|
'Possessive noun w/o index collection with index' => [StoreTest::KEY . "'s 1st option", [[StoreTest::KEY, null], ['option', 0]], 'Cruise Control'], |
|
71
|
|
|
'Possessive noun with index collection with index' => ['1st ' . StoreTest::KEY . "'s 1st option", [[StoreTest::KEY, 0], ['option', 0]], 'GPS'], |
|
72
|
|
|
]; |
|
73
|
|
|
} |
|
74
|
|
|
} |
|
75
|
|
|
|