✅ Add base class for comic tests
authorDavid ‘Bombe’ Roden <bombe@pterodactylus.net>
Thu, 20 Jan 2022 20:35:16 +0000 (21:35 +0100)
committerDavid ‘Bombe’ Roden <bombe@pterodactylus.net>
Thu, 20 Jan 2022 20:35:16 +0000 (21:35 +0100)
src/test/kotlin/net/pterodactylus/rhynodge/filters/comics/ComicSiteFilterTest.kt [new file with mode: 0644]

diff --git a/src/test/kotlin/net/pterodactylus/rhynodge/filters/comics/ComicSiteFilterTest.kt b/src/test/kotlin/net/pterodactylus/rhynodge/filters/comics/ComicSiteFilterTest.kt
new file mode 100644 (file)
index 0000000..ce1a8e2
--- /dev/null
@@ -0,0 +1,31 @@
+package net.pterodactylus.rhynodge.filters.comics
+
+import net.pterodactylus.rhynodge.filters.ComicSiteFilter
+import net.pterodactylus.rhynodge.filters.ResourceLoader
+import net.pterodactylus.rhynodge.states.ComicState
+import net.pterodactylus.rhynodge.states.ComicState.Comic
+import net.pterodactylus.rhynodge.states.HtmlState
+import org.hamcrest.MatcherAssert.assertThat
+import org.hamcrest.Matchers.equalTo
+import org.junit.Test
+
+abstract class ComicSiteFilterTest {
+
+       protected abstract val filter: ComicSiteFilter
+       protected abstract val baseUrl: String
+       protected abstract val resource: String
+       protected abstract val expectedComics: List<Comic>
+
+       private val htmlState: HtmlState by lazy {
+               ResourceLoader
+                       .loadDocument(javaClass, resource, baseUrl)
+                       .let { HtmlState(baseUrl, it) }
+       }
+
+       @Test
+       fun `comic is loaded correctly`() {
+               val comicState = filter.filter(htmlState) as ComicState
+               assertThat(comicState.comics(), equalTo(expectedComics))
+       }
+
+}