These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more
1 | <?php |
||
2 | |||
3 | use AspectMock\Test as test; |
||
0 ignored issues
–
show
|
|||
4 | use Robo\Robo; |
||
5 | |||
6 | class SvnTest extends \Codeception\TestCase\Test |
||
7 | { |
||
8 | /** |
||
9 | * @var \AspectMock\Proxy\ClassProxy |
||
10 | */ |
||
11 | protected $svn; |
||
12 | |||
13 | protected function _before() |
||
14 | { |
||
15 | $progressBar = test::double('Symfony\Component\Console\Helper\ProgressBar'); |
||
16 | $nullOutput = new \Symfony\Component\Console\Output\NullOutput(); |
||
17 | |||
18 | $progressIndicator = new \Robo\Common\ProgressIndicator($progressBar, $nullOutput); |
||
0 ignored issues
–
show
$progressBar is of type object<AspectMock\Proxy\...oxy\InstanceProxy>|null , but the function expects a object<Symfony\Component...ole\Helper\ProgressBar> .
It seems like the type of the argument is not accepted by the function/method which you are calling. In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug. We suggest to add an explicit type cast like in the following example: function acceptsInteger($int) { }
$x = '123'; // string "123"
// Instead of
acceptsInteger($x);
// we recommend to use
acceptsInteger((integer) $x);
Loading history...
|
|||
19 | |||
20 | $this->svn = test::double('Robo\Task\Vcs\SvnStack', [ |
||
21 | 'executeCommand' => new \AspectMock\Proxy\Anything(), |
||
22 | 'output' => $nullOutput, |
||
23 | 'logger' => new \Psr\Log\NullLogger(), |
||
24 | 'logger' => Robo::logger(), |
||
25 | 'getConfig' => Robo::config(), |
||
26 | 'progressIndicator' => $progressIndicator, |
||
27 | ]); |
||
28 | } |
||
29 | |||
30 | // tests |
||
31 | public function testSvnStackRun() |
||
32 | { |
||
33 | $this->svn->construct()->update()->add()->run(); |
||
34 | $this->svn->verifyInvoked('executeCommand', ['svn update && svn add']); |
||
35 | } |
||
36 | |||
37 | public function testSvnStackCommands() |
||
38 | { |
||
39 | verify( |
||
40 | (new \Robo\Task\Vcs\SvnStack('guest', 'foo')) |
||
41 | ->checkout('svn://server/trunk') |
||
42 | ->update() |
||
43 | ->add() |
||
44 | ->commit('changed') |
||
45 | ->getCommand() |
||
46 | )->equals("svn --username guest --password foo checkout svn://server/trunk && svn --username guest --password foo update && svn --username guest --password foo add && svn --username guest --password foo commit -m 'changed'"); |
||
47 | } |
||
48 | |||
49 | } |
||
50 |
Let’s assume that you have a directory layout like this:
and let’s assume the following content of
Bar.php
:If both files
OtherDir/Foo.php
andSomeDir/Foo.php
are loaded in the same runtime, you will see a PHP error such as the following:PHP Fatal error: Cannot use SomeDir\Foo as Foo because the name is already in use in OtherDir/Foo.php
However, as
OtherDir/Foo.php
does not necessarily have to be loaded and the error is only triggered if it is loaded beforeOtherDir/Bar.php
, this problem might go unnoticed for a while. In order to prevent this error from surfacing, you must import the namespace with a different alias: