X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fajax%2FGetStatusAjaxPageTest.kt;h=9ec927d57acf5a91516ae05094b382251898ab2d;hp=d397b93320992bb8a7a6ece8624626fa1c199286;hb=dd96e781b592c3bae9b0f66f85ba05a4e4cc18ce;hpb=787aa8a7839dcb32c07a8e2b6d982c7e2cb67244 diff --git a/src/test/kotlin/net/pterodactylus/sone/web/ajax/GetStatusAjaxPageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/ajax/GetStatusAjaxPageTest.kt index d397b93..9ec927d 100644 --- a/src/test/kotlin/net/pterodactylus/sone/web/ajax/GetStatusAjaxPageTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/web/ajax/GetStatusAjaxPageTest.kt @@ -11,6 +11,7 @@ import net.pterodactylus.sone.test.mock import net.pterodactylus.sone.test.whenever import net.pterodactylus.sone.text.TimeText import net.pterodactylus.sone.text.TimeTextConverter +import net.pterodactylus.sone.utils.jsonArray import net.pterodactylus.util.notify.Notification import org.hamcrest.MatcherAssert.assertThat import org.hamcrest.Matchers.allOf @@ -30,7 +31,7 @@ class GetStatusAjaxPageTest: JsonPageTest() { private val timeTextConverter = mock() private val l10nFilter = mock() - override var page: JsonPage = GetStatusAjaxPage(webInterface, timeTextConverter, l10nFilter) + override var page: JsonPage = GetStatusAjaxPage(webInterface, elementLoader, timeTextConverter, l10nFilter) @Before fun setupTimeTextConverter() { @@ -134,6 +135,19 @@ class GetStatusAjaxPageTest: JsonPageTest() { )) } + @Test + fun `page returns information about loaded elements`() { + addLoadedElement("KSK@test.png", loading = false, failed = false) + addLoadedElement("KSK@test.html", loading = true, failed = false) + addLoadedElement("KSK@test.jpeg", loading = false, failed = true) + addRequestParameter("elements", jsonArray("KSK@test.png", "KSK@test.html", "KSK@test.jpeg").toString()) + assertThat(json.get("loadedElements").elements().asSequence().map { it.toMap() }.toList(), containsInAnyOrder( + mapOf("link" to "KSK@test.png", "loading" to "false", "failed" to "false"), + mapOf("link" to "KSK@test.html", "loading" to "true", "failed" to "false"), + mapOf("link" to "KSK@test.jpeg", "loading" to "false", "failed" to "true") + )) + } + private fun JsonNode.toMap() = fields().asSequence().map { it.key!! to if (it.value.isNull) null else it.value.asText()!! }.toMap() }