为了对我的Symfony2应用程序进行一些日志记录,我创建了一个记录任何连接的服务,这里是在kernel.response上调用的方法:
public function log(FilterResponseEvent $event)
{
$log = new Log();
$request = $event->getRequest();
$response = $event->getResponse();
//fill the Log entity with stuff from request & response data
$manager = $this->container->get('doctrine.orm.entity_manager');
$manager->persist($log);
$manager->flush();
}
所有这一切似乎都很好,但是当我执行像这样的测试时(带有空数据的补丁触发失败):
$this->client->request(
'PATCH',
'/users/testificate',
array(
'firstName' => '',
)
);
调用此操作:
protected function processForm($item, $method = 'PATCH')
{
$form = $this->createForm(new $this->form(), $item, array('method' => $method));
$form->handleRequest($this->getRequest());
if ($form->isValid()) {
$response = new Response();
// Set the `Location` header only when creating new resources
if ($method == 'POST') {
$response->setStatusCode(201);
$response->headers->set('Location',
$this->generateUrl(
'get_' . strtolower($class), array('slug' => $item->getId()),
true // absolute
)
);
}
else {
$response->setStatusCode(204);
}
$this->em->flush();
return $response;
}
$this->em->detach($item);
return RestView::create($form, 400);
}
虽然测试失败,但实体已修补,当然不能。 经过一些搜索,我所学到的是:
到目前为止我尝试过的事情: 1)做一个$ manager-> clear();在$ manager-> persist()之前; ......没有改变任何事情 2)做一个$ manager->分离($ item);如果表单验证失败...不会改变任何内容
谢谢!
答案 0 :(得分:0)
在从Doctrine 2.3.4升级到最新的2.4分支时,我最近偶然发现了kernel.response
中的刷新问题。尝试从kernel.terminate
刷新日志实体。在kernel.response
。