Use test class to load resources from
[rhynodge.git] / src / test / java / net / pterodactylus / rhynodge / filters / comics / CyanideAndHappinessComicFilterTest.java
1 package net.pterodactylus.rhynodge.filters.comics;
2
3 import java.io.IOException;
4
5 import net.pterodactylus.rhynodge.filters.ResourceLoader;
6
7 import com.google.common.base.Optional;
8 import org.hamcrest.MatcherAssert;
9 import org.hamcrest.Matchers;
10 import org.jsoup.nodes.Document;
11 import org.junit.Test;
12
13 /**
14  * Unit test for {@link CyanideAndHappinessComicFilter}.
15  *
16  * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
17  */
18 public class CyanideAndHappinessComicFilterTest {
19
20         private final CyanideAndHappinessComicFilter comicSiteFilter = new CyanideAndHappinessComicFilter();
21         private final Document document;
22
23         public CyanideAndHappinessComicFilterTest() throws IOException {
24                 document = ResourceLoader.loadDocument(getClass(), "cyanide-and-happiness.html", "http://www.explosm.net/comics/new/");
25         }
26
27         @Test
28         public void filterCanParseComicTitle() {
29                 MatcherAssert.assertThat(comicSiteFilter.extractTitle(document), Matchers.is(Optional.absent()));
30         }
31
32         @Test
33         public void filterCanExtractImageUrls() {
34                 MatcherAssert.assertThat(comicSiteFilter.extractImageUrls(document), Matchers.contains("http://files.explosm.net/comics/Dave/moneyhappiness.png"));
35         }
36
37         @Test
38         public void filterExtractNoImageComments() {
39                 MatcherAssert.assertThat(comicSiteFilter.extractImageComments(document), Matchers.empty());
40         }
41
42 }