X-Git-Url: http://git.scottworley.com/paperdoorknob/blobdiff_plain/23dabdf5c5133e06fbc44763225cda1ab72e668e..d6e27f4bb8ab56ca2545a72ab3433a12b1eb4a7f:/paperdoorknob_test.py?ds=inline diff --git a/paperdoorknob_test.py b/paperdoorknob_test.py index 4711fcd..571dda6 100644 --- a/paperdoorknob_test.py +++ b/paperdoorknob_test.py @@ -8,14 +8,14 @@ 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 glowfic import ContentOnlyLayout, BesideIconLayout from images import FakeImageStore from spec import Spec from texify import DirectTexifier, PandocTexifier, VerifyingTexifier @@ -35,30 +35,30 @@ class BaseTestProcess(ABC): def testProcess(self) -> None: buf = io.BytesIO() + texifier = PandocTexifier('pandoc') spec = Spec( self.url(), self.fetcher(), FakeImageStore(), lambda x: x, - lambda x: ApplyDOMFilters('NoEdit,NoFooter', x), - ContentOnlyLayout(PandocTexifier('pandoc')), + lambda x: None, + texifier, + lambda x: x, + 20, + ContentOnlyLayout, 'margin=20mm', - buf) + buf, + lambda _: None) paperdoorknob.process(spec) - assert buf.getvalue() == b'''\\documentclass{article} -\\usepackage{graphicx} -\\usepackage{varwidth} -\\usepackage{wrapstuff} -\\usepackage[margin=20mm]{geometry} + assert re.match(br'''\\documentclass{article} +(\\usepackage{[a-z]+}\n)+\\usepackage\[margin=20mm\]{geometry} \\begin{document} -This is glowfic - -You \\emph{sure}? - -Pretty sure. - +(.|\n)* +\\glowhead{}{}{}{}This is \\href{https://glowfic.com}{glowfic} +\\glowhead{}{}{}{}You \\emph{sure}\? +\\glowhead{}{}{}{}Pretty sure. \\end{document} -''' +''', buf.getvalue()) def testDirectTexifier(self) -> None: texifier = VerifyingTexifier( @@ -69,23 +69,32 @@ Pretty sure. self.fetcher(), FakeImageStore(), lambda x: x, - lambda x: ApplyDOMFilters('NoEdit,NoFooter', x), - ContentOnlyLayout(texifier), + lambda x: None, + texifier, + lambda x: x, + 20, + ContentOnlyLayout, None, - buf) + buf, + lambda _: None) paperdoorknob.process(spec) def testPDF(self) -> None: + texifier = PandocTexifier('pandoc') with open("test.tex", 'wb') as out: spec = Spec( self.url(), self.fetcher(), FakeImageStore(), lambda x: x, - lambda x: ApplyDOMFilters('NoEdit,NoFooter', x), - BelowIconLayout(PandocTexifier('pandoc'), 20), + lambda x: None, + texifier, + lambda x: x, + 20, + BesideIconLayout, None, - out) + out, + lambda _: None) paperdoorknob.process(spec) subprocess.run(['pdflatex', 'test.tex'], stdin=subprocess.DEVNULL, check=True) @@ -112,7 +121,8 @@ 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)}) + html = f.read(9999) + return FakeFetcher({'fic': html, 'fic?view=flat': html}) if __name__ == '__main__':