Chris@0
|
1 <?php
|
Chris@0
|
2
|
Chris@0
|
3 /*
|
Chris@0
|
4 * This file is part of Psy Shell.
|
Chris@0
|
5 *
|
Chris@0
|
6 * (c) 2012-2017 Justin Hileman
|
Chris@0
|
7 *
|
Chris@0
|
8 * For the full copyright and license information, please view the LICENSE
|
Chris@0
|
9 * file that was distributed with this source code.
|
Chris@0
|
10 */
|
Chris@0
|
11
|
Chris@0
|
12 namespace Psy\Test\VersionUpdater;
|
Chris@0
|
13
|
Chris@0
|
14 use Psy\Shell;
|
Chris@0
|
15
|
Chris@0
|
16 class GitHubCheckerTest extends \PHPUnit\Framework\TestCase
|
Chris@0
|
17 {
|
Chris@0
|
18 /**
|
Chris@0
|
19 * @dataProvider malformedResults
|
Chris@0
|
20 * @expectedException \InvalidArgumentException
|
Chris@0
|
21 * @expectedExceptionMessage Unable to check for updates
|
Chris@0
|
22 *
|
Chris@0
|
23 * @param $input
|
Chris@0
|
24 */
|
Chris@0
|
25 public function testExceptionInvocation($input)
|
Chris@0
|
26 {
|
Chris@0
|
27 $checker = $this->getMockBuilder('Psy\\VersionUpdater\\GitHubChecker')
|
Chris@0
|
28 ->setMethods(array('fetchLatestRelease'))
|
Chris@0
|
29 ->getMock();
|
Chris@0
|
30 $checker->expects($this->once())->method('fetchLatestRelease')->willReturn($input);
|
Chris@0
|
31 $checker->isLatest();
|
Chris@0
|
32 }
|
Chris@0
|
33
|
Chris@0
|
34 /**
|
Chris@0
|
35 * @dataProvider jsonResults
|
Chris@0
|
36 *
|
Chris@0
|
37 * @param $assertion
|
Chris@0
|
38 * @param $input
|
Chris@0
|
39 */
|
Chris@0
|
40 public function testDataSetResults($assertion, $input)
|
Chris@0
|
41 {
|
Chris@0
|
42 $checker = $this->getMockBuilder('Psy\\VersionUpdater\\GitHubChecker')
|
Chris@0
|
43 ->setMethods(array('fetchLatestRelease'))
|
Chris@0
|
44 ->getMock();
|
Chris@0
|
45 $checker->expects($this->once())->method('fetchLatestRelease')->willReturn($input);
|
Chris@0
|
46 $this->assertSame($assertion, $checker->isLatest());
|
Chris@0
|
47 }
|
Chris@0
|
48
|
Chris@0
|
49 /**
|
Chris@0
|
50 * @return array
|
Chris@0
|
51 */
|
Chris@0
|
52 public function jsonResults()
|
Chris@0
|
53 {
|
Chris@0
|
54 return array(
|
Chris@0
|
55 array(false, json_decode('{"tag_name":"v9.0.0"}')),
|
Chris@0
|
56 array(true, json_decode('{"tag_name":"v' . Shell::VERSION . '"}')),
|
Chris@0
|
57 array(true, json_decode('{"tag_name":"v0.0.1"}')),
|
Chris@0
|
58 array(true, json_decode('{"tag_name":"v0.4.1-alpha"}')),
|
Chris@0
|
59 array(true, json_decode('{"tag_name":"v0.4.2-beta3"}')),
|
Chris@0
|
60 array(true, json_decode('{"tag_name":"v0.0.1"}')),
|
Chris@0
|
61 array(true, json_decode('{"tag_name":""}')),
|
Chris@0
|
62 );
|
Chris@0
|
63 }
|
Chris@0
|
64
|
Chris@0
|
65 /**
|
Chris@0
|
66 * @return array
|
Chris@0
|
67 */
|
Chris@0
|
68 public function malformedResults()
|
Chris@0
|
69 {
|
Chris@0
|
70 return array(
|
Chris@0
|
71 array(null),
|
Chris@0
|
72 array(false),
|
Chris@0
|
73 array(true),
|
Chris@0
|
74 array(json_decode('{"foo":"bar"}')),
|
Chris@0
|
75 array(json_decode('{}')),
|
Chris@0
|
76 array(json_decode('[]')),
|
Chris@0
|
77 array(array()),
|
Chris@0
|
78 array(json_decode('{"tag_name":false"}')),
|
Chris@0
|
79 array(json_decode('{"tag_name":true"}')),
|
Chris@0
|
80 );
|
Chris@0
|
81 }
|
Chris@0
|
82 }
|