]> git.immae.eu Git - github/wallabag/wallabag.git/blame - src/Wallabag/ApiBundle/Tests/WallabagApiTestCase.php
Cleanup tests
[github/wallabag/wallabag.git] / src / Wallabag / ApiBundle / Tests / WallabagApiTestCase.php
CommitLineData
fcb1fba5
NL
1<?php
2
3namespace Wallabag\ApiBundle\Tests;
4
5use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
6use Symfony\Component\BrowserKit\Cookie;
7
8a493541 8abstract class WallabagApiTestCase extends WebTestCase
fcb1fba5
NL
9{
10 /**
11 * @var Client
12 */
13 protected $client = null;
14
15 public function setUp()
16 {
17 $this->client = $this->createAuthorizedClient();
18 }
19
20 /**
21 * @return Client
22 */
23 protected function createAuthorizedClient()
24 {
25 $client = static::createClient();
26 $container = $client->getContainer();
27
fcb1fba5
NL
28 /** @var $userManager \FOS\UserBundle\Doctrine\UserManager */
29 $userManager = $container->get('fos_user.user_manager');
30 /** @var $loginManager \FOS\UserBundle\Security\LoginManager */
31 $loginManager = $container->get('fos_user.security.login_manager');
32 $firewallName = $container->getParameter('fos_user.firewall_name');
33
34 $user = $userManager->findUserBy(array('username' => 'admin'));
35 $loginManager->loginUser($firewallName, $user);
36
37 // save the login token into the session and put it in a cookie
18f8f32f 38 $container->get('session')->set('_security_'.$firewallName, serialize($container->get('security.token_storage')->getToken()));
fcb1fba5 39 $container->get('session')->save();
18f8f32f
JB
40
41 $session = $container->get('session');
fcb1fba5
NL
42 $client->getCookieJar()->set(new Cookie($session->getName(), $session->getId()));
43
44 return $client;
45 }
46}