- @Test
- public void testLoginUnverified() throws IOException {
- long uniq = System.currentTimeMillis();
- String email = "system" + uniq + "@testmail.org";
- registerUser("an", "bn", email, TEST_PASSWORD);
- waitForMail();
- assertFalse(isLoggedin(login(email, TEST_PASSWORD)));
- }
-
- @Test
- public void testLoginVerified() throws IOException {
- long uniq = System.currentTimeMillis();
- String email = "system2" + uniq + "@testmail.org";
- createVerifiedUser("an", "bn", email, TEST_PASSWORD);
- assertTrue(isLoggedin(login(email, TEST_PASSWORD)));
- }
+ @Test
+ public void testLoginUnverified() throws IOException {
+ String email = createUniqueName() + "@testmail.org";
+ registerUser("an", "bn", email, TEST_PASSWORD);
+ getMailReceiver().receive();
+ assertFalse(isLoggedin(login(email, TEST_PASSWORD)));
+ }
+
+ @Test
+ public void testLoginVerified() throws IOException {
+ String email = createUniqueName() + "@testmail.org";
+ createVerifiedUser("an", "bn", email, TEST_PASSWORD);
+ assertTrue(isLoggedin(login(email, TEST_PASSWORD)));
+ }
+
+ @Test
+ public void testLoginRedirectBack() throws IOException {
+ String email = createUniqueName() + "@testmail.org";
+ createVerifiedUser("an", "bn", email, TEST_PASSWORD);
+
+ URL u0 = new URL("https://" + getServerName() + SECURE_REFERENCE);
+ HttpURLConnection huc0 = (HttpURLConnection) u0.openConnection();
+ String headerField = stripCookie(huc0.getHeaderField("Set-Cookie"));
+
+ HttpURLConnection huc = post(headerField, "/login", "username=" + URLEncoder.encode(email, "UTF-8") + "&password=" + URLEncoder.encode(TEST_PASSWORD, "UTF-8"), 0);
+
+ headerField = huc.getHeaderField("Set-Cookie");
+ assertNotNull(headerField);
+ assertEquals(302, huc.getResponseCode());
+ assertEquals("https://" + getServerName().replaceFirst(":443$", "") + SECURE_REFERENCE, huc.getHeaderField("Location"));
+ }
+
+ @Test
+ public void testLoginWrongPassword() throws IOException {
+ String email = createUniqueName() + "@testmail.org";
+ createVerifiedUser("an", "bn", email, TEST_PASSWORD);
+ assertFalse(isLoggedin(login(email, TEST_PASSWORD + "b")));
+ }
+
+ @Test
+ public void testLogoutVerified() throws IOException {
+ String email = createUniqueName() + "@testmail.org";
+ createVerifiedUser("an", "bn", email, TEST_PASSWORD);
+ String cookie = login(email, TEST_PASSWORD);
+ assertTrue(isLoggedin(cookie));
+ logout(cookie);
+ assertFalse(isLoggedin(cookie));
+ }
+
+ private void logout(String cookie) throws IOException {
+ get(cookie, "/logout").getHeaderField("Location");
+ }
+
+ @Test
+ public void testLoginMethodDisplay() throws IOException {
+ String email = createUniqueName() + "@testmail.org";
+ createVerifiedUser("an", "bn", email, TEST_PASSWORD);
+ String l = login(email, TEST_PASSWORD);
+ URLConnection c = get(l, "");
+ String readURL = IOUtils.readURL(c);
+ assertThat(readURL, containsString("Password"));
+ }