1
|
|
|
<?php namespace Unit\Chekote\NounStore\Store; |
2
|
|
|
|
3
|
|
|
use InvalidArgumentException; |
4
|
|
|
use Unit\Chekote\NounStore\Key\KeyTest; |
5
|
|
|
use Unit\Chekote\Phake\Phake; |
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
|
|
|
|