Chris@13
|
1 <?php
|
Chris@13
|
2
|
Chris@13
|
3 /*
|
Chris@13
|
4 * This file is part of Psy Shell.
|
Chris@13
|
5 *
|
Chris@13
|
6 * (c) 2012-2018 Justin Hileman
|
Chris@13
|
7 *
|
Chris@13
|
8 * For the full copyright and license information, please view the LICENSE
|
Chris@13
|
9 * file that was distributed with this source code.
|
Chris@13
|
10 */
|
Chris@13
|
11
|
Chris@13
|
12 namespace Psy\Test\CodeCleaner;
|
Chris@13
|
13
|
Chris@13
|
14 use Psy\CodeCleaner\PassableByReferencePass;
|
Chris@13
|
15
|
Chris@13
|
16 class PassableByReferencePassTest extends CodeCleanerTestCase
|
Chris@13
|
17 {
|
Chris@13
|
18 public function setUp()
|
Chris@13
|
19 {
|
Chris@13
|
20 $this->setPass(new PassableByReferencePass());
|
Chris@13
|
21 }
|
Chris@13
|
22
|
Chris@13
|
23 /**
|
Chris@13
|
24 * @dataProvider invalidStatements
|
Chris@13
|
25 * @expectedException \Psy\Exception\FatalErrorException
|
Chris@13
|
26 */
|
Chris@13
|
27 public function testProcessStatementFails($code)
|
Chris@13
|
28 {
|
Chris@13
|
29 $this->parseAndTraverse($code);
|
Chris@13
|
30 }
|
Chris@13
|
31
|
Chris@13
|
32 public function invalidStatements()
|
Chris@13
|
33 {
|
Chris@13
|
34 return [
|
Chris@13
|
35 ['array_pop(array())'],
|
Chris@13
|
36 ['array_pop(array($foo))'],
|
Chris@13
|
37 ['array_shift(array())'],
|
Chris@13
|
38 ];
|
Chris@13
|
39 }
|
Chris@13
|
40
|
Chris@13
|
41 /**
|
Chris@13
|
42 * @dataProvider validStatements
|
Chris@13
|
43 */
|
Chris@13
|
44 public function testProcessStatementPasses($code)
|
Chris@13
|
45 {
|
Chris@13
|
46 $this->parseAndTraverse($code);
|
Chris@13
|
47 $this->assertTrue(true);
|
Chris@13
|
48 }
|
Chris@13
|
49
|
Chris@13
|
50 public function validStatements()
|
Chris@13
|
51 {
|
Chris@13
|
52 return [
|
Chris@13
|
53 ['array_pop(json_decode("[]"))'],
|
Chris@13
|
54 ['array_pop($foo)'],
|
Chris@13
|
55 ['array_pop($foo->bar)'],
|
Chris@13
|
56 ['array_pop($foo::baz)'],
|
Chris@13
|
57 ['array_pop(Foo::qux)'],
|
Chris@13
|
58 ];
|
Chris@13
|
59 }
|
Chris@13
|
60
|
Chris@13
|
61 /**
|
Chris@13
|
62 * @dataProvider validArrayMultisort
|
Chris@13
|
63 */
|
Chris@13
|
64 public function testArrayMultisort($code)
|
Chris@13
|
65 {
|
Chris@13
|
66 $this->parseAndTraverse($code);
|
Chris@13
|
67 $this->assertTrue(true);
|
Chris@13
|
68 }
|
Chris@13
|
69
|
Chris@13
|
70 public function validArrayMultisort()
|
Chris@13
|
71 {
|
Chris@13
|
72 return [
|
Chris@13
|
73 ['array_multisort($a)'],
|
Chris@13
|
74 ['array_multisort($a, $b)'],
|
Chris@13
|
75 ['array_multisort($a, SORT_NATURAL, $b)'],
|
Chris@13
|
76 ['array_multisort($a, SORT_NATURAL | SORT_FLAG_CASE, $b)'],
|
Chris@13
|
77 ['array_multisort($a, SORT_ASC, SORT_NATURAL | SORT_FLAG_CASE, $b)'],
|
Chris@13
|
78 ['array_multisort($a, SORT_NATURAL | SORT_FLAG_CASE, SORT_ASC, $b)'],
|
Chris@13
|
79 ['array_multisort($a, $b, SORT_ASC, SORT_NATURAL | SORT_FLAG_CASE)'],
|
Chris@13
|
80 ['array_multisort($a, SORT_NATURAL | SORT_FLAG_CASE, $b, SORT_ASC, SORT_NATURAL | SORT_FLAG_CASE)'],
|
Chris@13
|
81 ['array_multisort($a, 1, $b)'],
|
Chris@13
|
82 ['array_multisort($a, 1 + 2, $b)'],
|
Chris@13
|
83 ['array_multisort($a, getMultisortFlags(), $b)'],
|
Chris@13
|
84 ];
|
Chris@13
|
85 }
|
Chris@13
|
86
|
Chris@13
|
87 /**
|
Chris@13
|
88 * @dataProvider invalidArrayMultisort
|
Chris@13
|
89 * @expectedException \Psy\Exception\FatalErrorException
|
Chris@13
|
90 */
|
Chris@13
|
91 public function testInvalidArrayMultisort($code)
|
Chris@13
|
92 {
|
Chris@13
|
93 $this->parseAndTraverse($code);
|
Chris@13
|
94 }
|
Chris@13
|
95
|
Chris@13
|
96 public function invalidArrayMultisort()
|
Chris@13
|
97 {
|
Chris@13
|
98 return [
|
Chris@13
|
99 ['array_multisort(1)'],
|
Chris@13
|
100 ['array_multisort(array(1, 2, 3))'],
|
Chris@13
|
101 ['array_multisort($a, SORT_NATURAL, SORT_ASC, SORT_NATURAL, $b)'],
|
Chris@13
|
102 ];
|
Chris@13
|
103 }
|
Chris@13
|
104 }
|