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
self.fetcher(),
FakeImageStore(),
lambda x: x,
- lambda x: ApplyDOMFilters('NoEdit,NoFooter', x),
+ lambda x: None,
+ lambda x: x,
ContentOnlyLayout(PandocTexifier('pandoc')),
'margin=20mm',
- buf)
+ buf,
+ lambda _: None)
paperdoorknob.process(spec)
- assert buf.getvalue() == b'''\\documentclass{article}
-\\usepackage{graphicx}
-\\usepackage{wrapfig}
-\\usepackage[margin=20mm]{geometry}
+ assert re.match(br'''\\documentclass{article}
+(\\usepackage{[a-z]+}\n)+\\usepackage\[margin=20mm\]{geometry}
\\begin{document}
-This is glowfic
-
-\\vspace{-.5\\ht\\strutbox}\\noindent\\hrulefill
-
-You \\emph{sure}?
+.*
+This is \\href{https://glowfic.com}{glowfic}
-\\vspace{-.5\\ht\\strutbox}\\noindent\\hrulefill
+You \\emph{sure}\?
Pretty sure.
+
\\end{document}
-'''
+''', buf.getvalue())
def testDirectTexifier(self) -> None:
texifier = VerifyingTexifier(
self.fetcher(),
FakeImageStore(),
lambda x: x,
- lambda x: ApplyDOMFilters('NoEdit,NoFooter', x),
+ lambda x: None,
+ lambda x: x,
ContentOnlyLayout(texifier),
None,
- buf)
+ buf,
+ lambda _: None)
paperdoorknob.process(spec)
def testPDF(self) -> None:
self.fetcher(),
FakeImageStore(),
lambda x: x,
- lambda x: ApplyDOMFilters('NoEdit,NoFooter', x),
- BelowIconLayout(PandocTexifier('pandoc'), 20),
+ lambda x: None,
+ lambda x: x,
+ BesideIconLayout(PandocTexifier('pandoc'), 20),
None,
- out)
+ out,
+ lambda _: None)
paperdoorknob.process(spec)
subprocess.run(['pdflatex', 'test.tex'],
stdin=subprocess.DEVNULL, check=True)
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__':