for testing and deploying your application
for finding and fixing issues
for empowering human code reviews
<?php
namespace Test;
use Basis\Config;
use Basis\Test;
class ConfigTest extends Test
{
public function test()
$config = $this->app->get(Config::class);
$this->assertInstanceOf(Config::class, $config);
$this->assertSame($config, $this->app->get(Config::class));
$this->assertSame($config['service'], 'test');
$this->assertSame($config['environment'], 'testing');
$this->assertSame($config['tarantool.connection'], getenv('TARANTOOL_CONNECTION'));
$this->assertCount(4, get_object_vars($config));
get_object_vars($config)
array
object<Countable>|object...nit\Framework\iterable>
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);
$this->assertArrayHasKey('service', $config);
$config['custom.property'] = true;
$this->assertArrayHasKey('custom', $config);
$this->assertArrayHasKey('custom.property', $config);
unset($config['custom']);
$this->assertNull($config['custom']);
$this->assertNull($config['custom.property']);
}
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: