2017-03-06 182 views
0

我编码一个PHPUnit的测试,并得到了这个失败:PHPUnit进行测试

Tests\Professor\Controller\DisciplinaControllerTest::testListaDisciplinas 
Failed asserting response code "200", actual status code is "500" 

要获得更多的信息时出现错误在测试情况下,我的保护$ traceError成员设置真正。然后得到这个错误:

Tests\Professor\Controller\DisciplinaControllerTest::testListaDisciplinas 
Argument 1 passed to Doctrine\ORM\Tools\Pagination\Paginator::cloneQuery() must be an instance of Doctrine\ORM\Query, array given, called in /uov-videos/www/david/plataovirtual/vendor/doctrine/orm/lib/Doctrine/ORM/Tools/Pagination/Paginator.php on line 239 and defined 

发生这种情况,因为我的查询返回一个分页程序对象和我的测试是期待一个数组。如何实例化一个嘲笑的Paginator以在我的测试中使用它?

PHPUnit的功能代码:

public function testListaDisciplinas() 
{ 
    $this->auth(); 
    // simulate the repository to not affect the db 
    $disciplinaRepository = $this->getMock('Domain\Model\Disciplina\DisciplinaRepository'); 

    $disciplinaRepository->method('getByProfessorTutor') 
         ->willReturn(array()); 

    $serviceManager = $this->getApplicationServiceLocator(); 
    $serviceManager->setAllowOverride(true); 
    $serviceManager->setService('DisciplinaRepository', $disciplinaRepository); 

    // Route to getList() above 
    $result = $this->dispatch('/uov/professor/disciplinas'); 
    $this->assertResponseStatusCode(200); 
} 

在我的控制器:

public function getList() 
{ 
    $usuario = $this->getSessaoUsuario(); 

    $professor = $this->professorRepository()->getByUsuario($usuario); 

    $disciplinas = $this->disciplinaRepository()->getByProfessorTutor($professor); 

    $adapter = new DoctrinePaginator($disciplinas); 
    $paginator = new Paginator($adapter); 
    $paginator->setDefaultItemCountPerPage(20); 

    $view = new ViewModel(array(
     'disciplinas' => $paginator, 
    )); 

    $request = $this->getRequest(); 

    $view->setTerminal($request->isXmlHttpRequest()); 

    return $view; 
} 

功能我在仓库里:

public function getByProfessorTutor(Professor $professor) 
{ 
    $query = $this->em->createQueryBuilder(); 

    $query->select('d') 
      ->from($this->class, 'd') 
      ->leftJoin('Domain\Model\Turma\Turma', 't', 'WITH', 't.disciplina = d') 
      ->leftJoin('Domain\Model\Professor\ProfessorTurma', 'pt', 'WITH', 'pt.turma = t.id') 
      ->where('(t.professor = :professor OR pt.professor = :professor)') 
      ->setParameter('professor', $professor); 

    return new Paginator($query, $fetchJoinCollection = false); 
} 
+0

如果您想要某人帮助您,您最好发布您的代码。 – feedMe

+0

谢谢@feedMe,我更新了我的问题。 –

+0

没有关于您的测试的线索,但在您的控制器中存储您的存储库对于MVC最佳实践是不利的。这只是一个建议,因为:) – Hooli

回答

0

我设法解决这个问题。这里是代码,如何模拟Doctrine Paginator对象。

public function testListaDisciplinas() 
{ 
    $this->auth(); 
    // simulate the repository to not modify the db 
    $disciplinaRepository = $this->getMock('Domain\Model\Disciplina\DisciplinaRepository'); 

    $em = $this->getApplicationServiceLocator()->get('Doctrine\ORM\EntityManager'); 

    $query = $em->createQueryBuilder(); 
    $query->select('d') 
      ->from('Domain\Model\Disciplina\Disciplina', 'd') 
      ->setMaxResults(1); 

    $disciplinaRepository->method('getByProfessorTutor') 
         ->willReturn(new Paginator($query, $fetchJoinCollection = false)); 

    $serviceManager = $this->getApplicationServiceLocator(); 
    $serviceManager->setAllowOverride(true); 
    $serviceManager->setService('DisciplinaRepository', $disciplinaRepository); 
    $result = $this->dispatch('/uov/professor/disciplinas'); 
    $this->assertResponseStatusCode(200); 
}