我不知道如何测试创建查询生成器

时间:2018-09-25 13:48:55

标签: php phpunit symfony4 doctrine-mongodb prophecy

我正在尝试测试存储库的所有方法,但是我不知道如何进行测试,我想使用Profecy。我正在使用DoctrineMongoDBBundle

实体

class UsuarioEntidade{
/**
 * @MongoDB\Id
 */
protected $usuId;

/**
 * @MongoDB\Field(type="string", name="usua_nome")
 */
protected $usuNome;

/**
 * @MongoDB\Field(type="string", name="usua_telefone")
 */
protected $usuTelefone;

/**
 * @MongoDB\Field(type="string", name="usua_email")
 */
protected $usuEmail;

/**
 * @MongoDB\Field(type="string", name="usua_imagem_perfil")
 */
protected $usuImagemPerfil;

/**
 * @MongoDB\Field(type="date")
 */
protected $createdAt;

##get and set

存储库

class UsuarioRepositorio
{
protected $dm;

public function __construct(DocumentManager $documentManager)
{
    $this->dm = $documentManager;
}
public function all(array $input = null)
{
    $usuario = UsuarioEntidade::class;

    $all = $this->dm->createQueryBuilder($usuario);     

    return $all->getQuery();
}

这是我不知道如何根据存储库类执行的测试。

class UsuarioRepositorioTest extends TestCase
{

protected $repositorio;

protected $documento;

public function setUp()
{
    $this->documento = $this->prophesize(DocumentManager::class);

    $this->repositorio = new UsuarioRepositorio($this->documento->reveal());
}
public function testObtendoTodosOsDados()
{
    $output = $this->usuario();
    $this->documento->createQueryBuilder(UsuarioEntidade::class)->willReturn($output)->shouldBeCalled();

    $all = $this->repositorio->all();

    $this->assertEquals($output, $all);
}

protected function usuario()
    {
        $usuarioEntidade = new UsuarioEntidade();
        $usuarioEntidade->setUsuNome('Humanos');
        $usuarioEntidade->setUsuTelefone('89855236554');
        $usuarioEntidade->setUsuEmail('mano@email.com');
        $usuarioEntidade->setUsuImagemPerfil('/application/sam/tests/Usuario/ImagemPerfil/sam.png');

        $data = new \DateTime();
        $usuarioEntidade->setCreatedAt($data->format('Y-m-d'));

        return $usuarioEntidade;
    }

我不知道如何模拟方法“ getQuery()”。 总是会发生此错误: 错误:在数组上调用成员函数getQuery()

1 个答案:

答案 0 :(得分:1)

代码中的问题是您对createQUeryBuilder()的期望返回一个数组,而您正在尝试在该数组上调用函数。

您必须模拟QueryBuilder对象,并为其getQuery()函数设置期望值,以返回所需的输出。为DocumentManager createQueryBuilder()函数设置期望值时,必须返回QueryBuilder模拟。

类似这样的东西:

public function testObtendoTodosOsDados()
{
    $output = $this->usuario();

    $mockQueryBuilder = $this->prophesize(QueryBuilder::class); // Remember to import the proper QueryBuilder namespace

    $mockQueryBuilder->getQuery()->willReturn($output)->shouldBeCalled();

    $this->documento->createQueryBuilder(UsuarioEntidade::class)->willReturn($mockQueryBuilder)->shouldBeCalled();

    $all = $this->repositorio->all();

    $this->assertEquals($output, $all);
}