annotate vendor/psy/psysh/test/Psy/Test/VersionUpdater/GitHubCheckerTest.php @ 0:4c8ae668cc8c

Initial import (non-working)
author Chris Cannam
date Wed, 29 Nov 2017 16:09:58 +0000
parents
children
rev   line source
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 }