1

我正在尝试测试存储库的所有方法,但我不知道如何进行测试,我想使用 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()

4

1 回答 1

1

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

您必须模拟一个QueryBuilder对象并为其getQuery()功能设置期望以返回您想要的输出。createQueryBuilder()为 DocumentManager函数设置期望时,必须返回 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);
}
于 2018-09-25T19:58:54.727 回答