X-Git-Url: http://git.scottworley.com/paperdoorknob/blobdiff_plain/386218397a4723129b31e3954bb960da61f72474..a5f4539c4cc5954515e1256289784f1b174a5a16:/paperdoorknob_test.py diff --git a/paperdoorknob_test.py b/paperdoorknob_test.py index 425d5e3..a608f8b 100644 --- a/paperdoorknob_test.py +++ b/paperdoorknob_test.py @@ -8,12 +8,16 @@ from abc import ABC, abstractmethod import unittest import io +import re import subprocess import paperdoorknob from testing.fakeserver import FakeGlowficServer +from domfilter import ApplyDOMFilters from fetch import DirectFetcher, FakeFetcher, Fetcher +from glowfic import ContentOnlyLayout, BelowIconLayout +from images import FakeImageStore from spec import Spec from texify import DirectTexifier, PandocTexifier, VerifyingTexifier @@ -30,38 +34,43 @@ class BaseTestProcess(ABC): def fetcher(self) -> Fetcher: raise NotImplementedError() - def testReplies(self) -> None: - replies = paperdoorknob.replies( - paperdoorknob.clean( - paperdoorknob.parse( - self.fetcher().fetch( - self.url())))) - assert [r.text.strip() for r in replies] == [ - "This is glowfic", - "You sure?", - "Pretty sure."] - def testProcess(self) -> None: buf = io.BytesIO() spec = Spec( self.url(), self.fetcher(), - PandocTexifier('pandoc'), + FakeImageStore(), + lambda x: x, + lambda x: ApplyDOMFilters('NoEdit,NoFooter', x), + ContentOnlyLayout(PandocTexifier('pandoc')), + 'margin=20mm', buf) paperdoorknob.process(spec) - assert buf.getvalue() == b'''\\documentclass{article} + assert re.match(br'''\\documentclass{article} +(\\usepackage{[a-z]+}\n)+\\usepackage\[margin=20mm\]{geometry} \\begin{document} This is glowfic -You \\emph{sure}? + +You \\emph{sure}\? + Pretty sure. + \\end{document} -''' +''', buf.getvalue()) def testDirectTexifier(self) -> None: texifier = VerifyingTexifier( PandocTexifier('pandoc'), DirectTexifier()) buf = io.BytesIO() - spec = Spec(self.url(), self.fetcher(), texifier, buf) + spec = Spec( + self.url(), + self.fetcher(), + FakeImageStore(), + lambda x: x, + lambda x: ApplyDOMFilters('NoEdit,NoFooter', x), + ContentOnlyLayout(texifier), + None, + buf) paperdoorknob.process(spec) def testPDF(self) -> None: @@ -69,7 +78,11 @@ Pretty sure. spec = Spec( self.url(), self.fetcher(), - PandocTexifier('pandoc'), + FakeImageStore(), + lambda x: x, + lambda x: ApplyDOMFilters('NoEdit,NoFooter', x), + BelowIconLayout(PandocTexifier('pandoc'), 20), + None, out) paperdoorknob.process(spec) subprocess.run(['pdflatex', 'test.tex'], @@ -97,7 +110,7 @@ class TestProcessFromFakeFetcher(BaseTestProcess, unittest.TestCase): def fetcher(self) -> Fetcher: with open('testdata/this-is-glowfic.html', 'rb') as f: - return FakeFetcher({'fic': f.read(9999)}) + return FakeFetcher({'fic?view=flat': f.read(9999)}) if __name__ == '__main__':