for testing and deploying your application
for finding and fixing issues
for empowering human code reviews
<?php
/**
* (c) 2018 Douglas Reith.
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Reith\ToyRobot\QueryHandler;
use PHPUnit\Framework\TestCase;
use Psr\Log\LoggerInterface;
use Reith\ToyRobot\Messaging\Query\RobotReport;
use Reith\ToyRobot\Domain\Space\Table;
use Reith\ToyRobot\Domain\Robot\RobotRepositoryInterface;
class RobotReporterTest extends TestCase
{
* @test
public function willHandlePlaceRobot()
$mockRepo = self::createMock(RobotRepositoryInterface::class);
$mockLogger = self::createMock(LoggerInterface::class);
$robotReporter = new RobotReporter($mockRepo, $mockLogger);
$mockRepo
object<PHPUnit\Framework\MockObject\MockObject>
object<Reith\ToyRobot\Do...botRepositoryInterface>
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);
$mockLogger
object<Psr\Log\LoggerInterface>
self::assertInstanceOf(RobotReporter::class, $robotReporter);
$query = new RobotReport();
$robot = Table::create(3)->placeRobot();
$mockRepo->expects($this->once())
->method('load')
->willReturn($robot);
$result = $robotReporter->handleReport($query);
self::assertSame('0,0,E', $result);
}
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: