import java.net.URI;
import java.net.URISyntaxException;
import java.util.ArrayList;
+import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
+import java.util.Map;
import java.util.Set;
+import javax.annotation.Nonnull;
+
import net.pterodactylus.sone.core.Core;
import net.pterodactylus.sone.core.Preferences;
import net.pterodactylus.sone.core.UpdateChecker;
protected final TemplateContext templateContext = new TemplateContext();
protected final HTTPRequest httpRequest = mock(HTTPRequest.class);
+ protected final Map<String, String> requestHeaders = new HashMap<>();
protected final FreenetRequest freenetRequest = mock(FreenetRequest.class);
protected final ToadletContext toadletContext = mock(ToadletContext.class);
});
when(httpRequest.getParam(anyString())).thenReturn("");
when(httpRequest.getParam(anyString(), anyString())).thenReturn("");
+ when(httpRequest.getHeader(anyString())).thenAnswer(new Answer<String>() {
+ @Override
+ public String answer(InvocationOnMock invocation) throws Throwable {
+ return requestHeaders.get(invocation.<String>getArgument(0).toLowerCase());
+ }
+ });
}
@Before
when(freenetRequest.getMethod()).thenReturn(method);
}
+ protected void addHttpRequestHeader(@Nonnull String name, String value) {
+ requestHeaders.put(name.toLowerCase(), value);
+ }
+
protected void addHttpRequestParameter(String name, final String value) {
when(httpRequest.getPartAsStringFailsafe(eq(name), anyInt())).thenAnswer(new Answer<String>() {
@Override
--- /dev/null
+package net.pterodactylus.sone.web
+
+import net.pterodactylus.sone.data.Album
+import net.pterodactylus.sone.data.Album.Modifier.AlbumTitleMustNotBeEmpty
+import net.pterodactylus.sone.data.Sone
+import net.pterodactylus.sone.test.mock
+import net.pterodactylus.sone.test.mockBuilder
+import net.pterodactylus.sone.test.whenever
+import net.pterodactylus.sone.web.WebTestUtils.redirectsTo
+import net.pterodactylus.util.web.Method.GET
+import net.pterodactylus.util.web.Method.POST
+import org.junit.Before
+import org.junit.Test
+import org.mockito.Mockito.verify
+
+/**
+ * Unit test for [EditAlbumPage].
+ */
+class EditAlbumPageTest : WebPageTest() {
+
+ private val page = EditAlbumPage(template, webInterface)
+
+ private val album = mock<Album>()
+ private val parentAlbum = mock<Album>()
+ private val modifier = mockBuilder<Album.Modifier>()
+ private val sone = mock<Sone>()
+
+ @Before
+ fun setup() {
+ whenever(album.id).thenReturn("album-id")
+ whenever(album.sone).thenReturn(sone)
+ whenever(album.parent).thenReturn(parentAlbum)
+ whenever(album.modify()).thenReturn(modifier)
+ whenever(modifier.update()).thenReturn(album)
+ whenever(parentAlbum.id).thenReturn("parent-id")
+ whenever(sone.isLocal).thenReturn(true)
+ addHttpRequestHeader("Host", "www.te.st")
+ }
+
+ @Test
+ fun `get request does not redirect`() {
+ request("", GET)
+ page.handleRequest(freenetRequest, templateContext)
+ }
+
+ @Test
+ fun `post request with invalid album redirects to invalid page`() {
+ request("", POST)
+ expectedException.expect(redirectsTo("invalid.html"))
+ page.handleRequest(freenetRequest, templateContext)
+ }
+
+ @Test
+ fun `post request with album of non-local sone redirects to no permissions page`() {
+ request("", POST)
+ whenever(sone.isLocal).thenReturn(false)
+ addAlbum("album-id", album)
+ addHttpRequestParameter("album", "album-id")
+ expectedException.expect(redirectsTo("noPermission.html"))
+ page.handleRequest(freenetRequest, templateContext)
+ }
+
+ @Test
+ fun `post request with move left requested moves album to the left and redirects to album browser`() {
+ request("", POST)
+ addAlbum("album-id", album)
+ addHttpRequestParameter("album", "album-id")
+ addHttpRequestParameter("moveLeft", "true")
+ expectedException.expect(redirectsTo("imageBrowser.html?album=parent-id"))
+ try {
+ page.handleRequest(freenetRequest, templateContext)
+ } finally {
+ verify(parentAlbum).moveAlbumUp(album)
+ verify(core).touchConfiguration()
+ }
+ }
+
+ @Test
+ fun `post request with move right requested moves album to the left and redirects to album browser`() {
+ request("", POST)
+ addAlbum("album-id", album)
+ addHttpRequestParameter("album", "album-id")
+ addHttpRequestParameter("moveRight", "true")
+ expectedException.expect(redirectsTo("imageBrowser.html?album=parent-id"))
+ try {
+ page.handleRequest(freenetRequest, templateContext)
+ } finally {
+ verify(parentAlbum).moveAlbumDown(album)
+ verify(core).touchConfiguration()
+ }
+ }
+
+ @Test
+ fun `post request with empty album title redirects to empty album title page`() {
+ request("", POST)
+ addAlbum("album-id", album)
+ addHttpRequestParameter("album", "album-id")
+ whenever(modifier.setTitle("")).thenThrow(AlbumTitleMustNotBeEmpty())
+ expectedException.expect(redirectsTo("emptyAlbumTitle.html"))
+ page.handleRequest(freenetRequest, templateContext)
+ }
+
+ @Test
+ fun `post request with non-empty album title and description redirects to album browser`() {
+ request("", POST)
+ addAlbum("album-id", album)
+ addHttpRequestParameter("album", "album-id")
+ addHttpRequestParameter("title", "title")
+ addHttpRequestParameter("description", "description")
+ expectedException.expect(redirectsTo("imageBrowser.html?album=album-id"))
+ try {
+ page.handleRequest(freenetRequest, templateContext)
+ } finally {
+ verify(modifier).setTitle("title")
+ verify(modifier).setDescription("description")
+ verify(modifier).update()
+ verify(core).touchConfiguration()
+ }
+ }
+
+}