+ {
+ $container = $this->client->getContainer();
+ $session = $container->get('session');
+
+ $userManager = $container->get('fos_user.user_manager');
+ $loginManager = $container->get('fos_user.security.login_manager');
+ $firewallName = $container->getParameter('fos_user.firewall_name');
+
+ $user = $userManager->findUserBy(array('username' => $username));
+ $loginManager->loginUser($firewallName, $user);
+
+ $session->set('_security_'.$firewallName, serialize($container->get('security.token_storage')->getToken()));
+ $session->save();
+
+ $cookie = new Cookie($session->getName(), $session->getId());
+ $this->client->getCookieJar()->set($cookie);
+ }
+
+ /**
+ * Instead of `logInAs` this method use a HTTP request to log in the user.
+ * Could be better for some tests.
+ *
+ * @param string $username User to log in
+ */
+ public function logInAsUsingHttp($username)