mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-17 15:03:25 +00:00
151 lines
5.1 KiB
PHP
151 lines
5.1 KiB
PHP
<?php
|
|
|
|
namespace Alchemy\Tests\Phrasea\Controller\Root;
|
|
|
|
use Symfony\Component\HttpKernel\Client;
|
|
|
|
class SessionTest extends \PhraseanetWebTestCaseAuthenticatedAbstract
|
|
{
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Session::updateSession
|
|
*/
|
|
public function testUpdSessionLogout()
|
|
{
|
|
$this->logout(self::$DI['app']);
|
|
$this->XMLHTTPRequest('POST', '/session/update/');
|
|
$this->assertTrue(self::$DI['client']->getResponse()->isOk());
|
|
$datas = json_decode(self::$DI['client']->getResponse()->getContent());
|
|
$this->checkSessionReturn($datas);
|
|
$this->assertEquals('disconnected', $datas->status);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Session::updateSession
|
|
*/
|
|
public function testUpdSessionChangeUser()
|
|
{
|
|
$this->XMLHTTPRequest('POST', '/session/update/', array(
|
|
'usr' => self::$DI['user_alt1']->get_id()
|
|
));
|
|
$this->assertTrue(self::$DI['client']->getResponse()->isOk());
|
|
$datas = json_decode(self::$DI['client']->getResponse()->getContent());
|
|
$this->checkSessionReturn($datas);
|
|
$this->assertEquals('disconnected', $datas->status);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Session::updateSession
|
|
*/
|
|
public function testUpdSession()
|
|
{
|
|
$this->authenticate(self::$DI['app']);
|
|
|
|
$this->XMLHTTPRequest('POST', '/session/update/', array(
|
|
'usr' => self::$DI['user']->get_id(),
|
|
'module' => 1
|
|
));
|
|
$this->assertTrue(self::$DI['client']->getResponse()->isOk());
|
|
$datas = json_decode(self::$DI['client']->getResponse()->getContent());
|
|
$this->checkSessionReturn($datas);
|
|
$this->assertEquals('ok', $datas->status);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Session::updateSession
|
|
*/
|
|
public function testUpdSessionBadRequestMissingModuleArgument()
|
|
{
|
|
$this->authenticate(self::$DI['app']);
|
|
|
|
$this->XMLHTTPRequest('POST', '/session/update/', array(
|
|
'usr' => self::$DI['user']->get_id()
|
|
));
|
|
|
|
$datas = json_decode(self::$DI['client']->getResponse()->getContent());
|
|
$datas = json_decode(self::$DI['client']->getResponse()->getContent());
|
|
$this->checkSessionReturn($datas);
|
|
$this->assertEquals('unknown', $datas->status);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Session::updateSession
|
|
*/
|
|
public function testUpdSessionBadRequest()
|
|
{
|
|
self::$DI['client']->request('POST', '/session/update/');
|
|
|
|
$this->assertBadResponse(self::$DI['client']->getResponse());
|
|
}
|
|
|
|
private function checkSessionReturn(\stdClass $data)
|
|
{
|
|
$this->assertObjectHasAttribute('status', $data);
|
|
$this->assertObjectHasAttribute('message', $data);
|
|
$this->assertObjectHasAttribute('notifications', $data);
|
|
$this->assertObjectHasAttribute('changed', $data);
|
|
}
|
|
|
|
public function testDeleteSession()
|
|
{
|
|
$originalEm = self::$DI['app']['EM'];
|
|
|
|
$session = $this->getMock('Alchemy\Phrasea\Model\Entities\Session');
|
|
|
|
$session->expects($this->once())
|
|
->method('getUsrId')
|
|
->will($this->returnValue(self::$DI['app']['authentication']->getUser()->get_id()));
|
|
|
|
$em = $this->getMockBuilder('Doctrine\ORM\EntityManager')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
|
|
$em->expects($this->once())
|
|
->method('find')
|
|
->will($this->returnValue($session));
|
|
$em->expects($this->once())
|
|
->method('remove')
|
|
->will($this->returnValue(null));
|
|
$em->expects($this->once())
|
|
->method('flush')
|
|
->will($this->returnValue(null));
|
|
|
|
self::$DI['app']['EM'] = $em;
|
|
self::$DI['client'] = new Client(self::$DI['app'], array());
|
|
$this->XMLHTTPRequest('POST', '/session/delete/1');
|
|
$this->assertTrue(self::$DI['client']->getResponse()->isOK());
|
|
self::$DI['app']['EM'] = $originalEm;
|
|
self::$DI['client'] = new Client(self::$DI['app'], array());
|
|
|
|
$em = null;
|
|
}
|
|
|
|
public function testDeleteSessionUnauthorized()
|
|
{
|
|
$originalEm = self::$DI['app']['EM'];
|
|
|
|
$session = $this->getMock('Alchemy\Phrasea\Model\Entities\Session');
|
|
|
|
$session->expects($this->once())
|
|
->method('getUsrId')
|
|
->will($this->returnValue(self::$DI['app']['authentication']->getUser()->get_id() + 1));
|
|
|
|
$em = $this->getMockBuilder('Doctrine\ORM\EntityManager')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
|
|
$em->expects($this->once())
|
|
->method('find')
|
|
->will($this->returnValue($session));
|
|
|
|
self::$DI['app']['EM'] = $em;
|
|
self::$DI['client'] = new Client(self::$DI['app'], array());
|
|
self::$DI['client']->request('POST', '/session/delete/1');
|
|
$this->assertFalse(self::$DI['client']->getResponse()->isOK());
|
|
$this->assertEquals(self::$DI['client']->getResponse()->getStatusCode(), 403);
|
|
self::$DI['app']['EM'] = $originalEm;
|
|
self::$DI['client'] = new Client(self::$DI['app'], array());
|
|
|
|
$em = null;
|
|
}
|
|
}
|