diff options
Diffstat (limited to 'tests/Wallabag/CoreBundle/WallabagCoreTestCase.php')
-rw-r--r-- | tests/Wallabag/CoreBundle/WallabagCoreTestCase.php | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/tests/Wallabag/CoreBundle/WallabagCoreTestCase.php b/tests/Wallabag/CoreBundle/WallabagCoreTestCase.php new file mode 100644 index 00000000..c0055888 --- /dev/null +++ b/tests/Wallabag/CoreBundle/WallabagCoreTestCase.php | |||
@@ -0,0 +1,83 @@ | |||
1 | <?php | ||
2 | |||
3 | namespace Tests\Wallabag\CoreBundle; | ||
4 | |||
5 | use Symfony\Bundle\FrameworkBundle\Test\WebTestCase; | ||
6 | use Symfony\Component\BrowserKit\Cookie; | ||
7 | |||
8 | abstract class WallabagCoreTestCase extends WebTestCase | ||
9 | { | ||
10 | private $client = null; | ||
11 | |||
12 | public function getClient() | ||
13 | { | ||
14 | return $this->client; | ||
15 | } | ||
16 | |||
17 | public function setUp() | ||
18 | { | ||
19 | parent::setUp(); | ||
20 | |||
21 | $this->client = static::createClient(); | ||
22 | } | ||
23 | |||
24 | /** | ||
25 | * Login a user without making a HTTP request. | ||
26 | * If we make a HTTP request we lose ability to mock service in the container. | ||
27 | * | ||
28 | * @param string $username User to log in | ||
29 | */ | ||
30 | public function logInAs($username) | ||
31 | { | ||
32 | $container = $this->client->getContainer(); | ||
33 | $session = $container->get('session'); | ||
34 | |||
35 | $userManager = $container->get('fos_user.user_manager'); | ||
36 | $loginManager = $container->get('fos_user.security.login_manager'); | ||
37 | $firewallName = $container->getParameter('fos_user.firewall_name'); | ||
38 | |||
39 | $user = $userManager->findUserBy(array('username' => $username)); | ||
40 | $loginManager->loginUser($firewallName, $user); | ||
41 | |||
42 | $session->set('_security_'.$firewallName, serialize($container->get('security.token_storage')->getToken())); | ||
43 | $session->save(); | ||
44 | |||
45 | $cookie = new Cookie($session->getName(), $session->getId()); | ||
46 | $this->client->getCookieJar()->set($cookie); | ||
47 | } | ||
48 | |||
49 | /** | ||
50 | * Instead of `logInAs` this method use a HTTP request to log in the user. | ||
51 | * Could be better for some tests. | ||
52 | * | ||
53 | * @param string $username User to log in | ||
54 | */ | ||
55 | public function logInAsUsingHttp($username) | ||
56 | { | ||
57 | $crawler = $this->client->request('GET', '/login'); | ||
58 | $form = $crawler->filter('button[type=submit]')->form(); | ||
59 | $data = [ | ||
60 | '_username' => $username, | ||
61 | '_password' => 'mypassword', | ||
62 | ]; | ||
63 | |||
64 | $this->client->submit($form, $data); | ||
65 | } | ||
66 | |||
67 | /** | ||
68 | * Return the user id of the logged in user. | ||
69 | * You should be sure that you called `logInAs` before. | ||
70 | * | ||
71 | * @return int | ||
72 | */ | ||
73 | public function getLoggedInUserId() | ||
74 | { | ||
75 | $token = static::$kernel->getContainer()->get('security.token_storage')->getToken(); | ||
76 | |||
77 | if (null !== $token) { | ||
78 | return $token->getUser()->getId(); | ||
79 | } | ||
80 | |||
81 | throw new \RuntimeException('No logged in User.'); | ||
82 | } | ||
83 | } | ||