Replace create sone page and test with Kotlin version
[Sone.git] / src / test / java / net / pterodactylus / sone / web / CreateSonePageTest.java
diff --git a/src/test/java/net/pterodactylus/sone/web/CreateSonePageTest.java b/src/test/java/net/pterodactylus/sone/web/CreateSonePageTest.java
deleted file mode 100644 (file)
index c7bb2f2..0000000
+++ /dev/null
@@ -1,167 +0,0 @@
-package net.pterodactylus.sone.web;
-
-import static net.pterodactylus.sone.web.WebTestUtils.redirectsTo;
-import static net.pterodactylus.util.web.Method.POST;
-import static org.hamcrest.MatcherAssert.assertThat;
-import static org.hamcrest.Matchers.contains;
-import static org.hamcrest.Matchers.is;
-import static org.mockito.ArgumentMatchers.anyString;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.verify;
-import static org.mockito.Mockito.when;
-
-import java.util.Arrays;
-import java.util.Collection;
-import java.util.HashSet;
-
-import net.pterodactylus.sone.data.Profile;
-import net.pterodactylus.sone.data.Sone;
-import net.pterodactylus.sone.freenet.wot.OwnIdentity;
-
-import org.junit.Test;
-import org.mockito.invocation.InvocationOnMock;
-import org.mockito.stubbing.Answer;
-
-/**
- * Unit test for {@link CreateSonePage}.
- *
- * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
- */
-public class CreateSonePageTest extends WebPageTest {
-
-       private final CreateSonePage page = new CreateSonePage(template, webInterface);
-       private final Sone[] localSones = { createSone("local-sone1"), createSone("local-sone2"), createSone("local-sone3") };
-       private final OwnIdentity[] ownIdentities = {
-                       createOwnIdentity("own-id-1", "Sone"),
-                       createOwnIdentity("own-id-2", "Test", "Foo"),
-                       createOwnIdentity("own-id-3"),
-                       createOwnIdentity("own-id-4", "Sone")
-       };
-
-       @Test
-       public void pageReturnsCorrectPath() {
-               assertThat(page.getPath(), is("createSone.html"));
-       }
-
-       @Test
-       @SuppressWarnings("unchecked")
-       public void getRequestStoresListOfIdentitiesInTemplateContext() throws Exception {
-               addDefaultLocalSones();
-               addDefaultOwnIdentities();
-               page.processTemplate(freenetRequest, templateContext);
-               assertThat((Collection<Sone>) templateContext.get("sones"), contains(localSones[0], localSones[1], localSones[2]));
-               assertThat((Collection<OwnIdentity>) templateContext.get("identitiesWithoutSone"), contains(ownIdentities[1], ownIdentities[2]));
-       }
-
-       private void addDefaultLocalSones() {
-               addLocalSone("local-sone3", localSones[2]);
-               addLocalSone("local-sone1", localSones[0]);
-               addLocalSone("local-sone2", localSones[1]);
-       }
-
-       private void addDefaultOwnIdentities() {
-               addOwnIdentity(ownIdentities[2]);
-               addOwnIdentity(ownIdentities[0]);
-               addOwnIdentity(ownIdentities[3]);
-               addOwnIdentity(ownIdentities[1]);
-       }
-
-       private Sone createSone(String id) {
-               Sone sone = mock(Sone.class);
-               when(sone.getId()).thenReturn(id);
-               when(sone.getProfile()).thenReturn(new Profile(sone));
-               return sone;
-       }
-
-       private OwnIdentity createOwnIdentity(String id, final String... contexts) {
-               OwnIdentity ownIdentity = mock(OwnIdentity.class);
-               when(ownIdentity.getId()).thenReturn(id);
-               when(ownIdentity.getNickname()).thenReturn(id);
-               when(ownIdentity.getContexts()).thenReturn(new HashSet<>(Arrays.asList(contexts)));
-               when(ownIdentity.hasContext(anyString())).thenAnswer(new Answer<Boolean>() {
-                       @Override
-                       public Boolean answer(InvocationOnMock invocation) throws Throwable {
-                               return Arrays.asList(contexts).contains(invocation.<String>getArgument(0));
-                       }
-               });
-               return ownIdentity;
-       }
-
-       @Test
-       public void soneIsCreatedAndLoggedIn() throws Exception {
-               addDefaultLocalSones();
-               addDefaultOwnIdentities();
-               addHttpRequestParameter("identity", "own-id-3");
-               request("", POST);
-               Sone newSone = mock(Sone.class);
-               when(core.createSone(ownIdentities[2])).thenReturn(newSone);
-               expectedException.expect(redirectsTo("index.html"));
-               try {
-                       page.processTemplate(freenetRequest, templateContext);
-               } finally {
-                       verify(core).createSone(ownIdentities[2]);
-                       verify(webInterface).setCurrentSone(toadletContext, newSone);
-               }
-       }
-
-       @Test
-       public void onInvalidIdentityIdFlagIsStoredInTemplateContext() throws Exception {
-               addDefaultLocalSones();
-               addDefaultOwnIdentities();
-               addHttpRequestParameter("identity", "own-id-invalid");
-               request("", POST);
-               page.processTemplate(freenetRequest, templateContext);
-               assertThat(((Boolean) templateContext.get("errorNoIdentity")), is(true));
-       }
-
-       @Test
-       public void ifSoneIsNotCreatedUserIsStillRedirectedToIndex() throws Exception {
-               addDefaultLocalSones();
-               addDefaultOwnIdentities();
-               addHttpRequestParameter("identity", "own-id-3");
-               request("", POST);
-               when(core.createSone(ownIdentities[2])).thenReturn(null);
-               expectedException.expect(redirectsTo("index.html"));
-               try {
-                       page.processTemplate(freenetRequest, templateContext);
-               } finally {
-                       verify(core).createSone(ownIdentities[2]);
-                       verify(webInterface).setCurrentSone(toadletContext, null);
-               }
-       }
-
-       @Test
-       public void doNotShowCreateSoneInMenuIfFullAccessRequiredButClientHasNoFullAccess() {
-               core.getPreferences().setRequireFullAccess(true);
-               when(toadletContext.isAllowedFullAccess()).thenReturn(false);
-               assertThat(page.isEnabled(toadletContext), is(false));
-       }
-
-       @Test
-       public void showCreateSoneInMenuIfNotLoggedInAndClientHasFullAccess() {
-               core.getPreferences().setRequireFullAccess(true);
-               when(toadletContext.isAllowedFullAccess()).thenReturn(true);
-               unsetCurrentSone();
-               assertThat(page.isEnabled(toadletContext), is(true));
-       }
-
-       @Test
-       public void showCreateSoneInMenuIfNotLoggedIn() {
-               unsetCurrentSone();
-               assertThat(page.isEnabled(toadletContext), is(true));
-       }
-
-       @Test
-       public void showCreateSoneInMenuIfLoggedInAndASingleSoneExists() {
-               addLocalSone("local-sone", mock(Sone.class));
-               assertThat(page.isEnabled(toadletContext), is(true));
-       }
-
-       @Test
-       public void doNotShowCreateSoneInMenuIfLoggedInAndMoreLocalSonesExists() {
-               addLocalSone("local-sone1", mock(Sone.class));
-               addLocalSone("local-sone2", mock(Sone.class));
-               assertThat(page.isEnabled(toadletContext), is(false));
-       }
-
-}