test_latextools.py
139 lines
| 4.0 KiB
| text/x-python
|
PythonLexer
Takafumi Arakaki
|
r7858 | # encoding: utf-8 | ||
"""Tests for IPython.utils.path.py""" | ||||
#----------------------------------------------------------------------------- | ||||
# Copyright (C) 2008-2011 The IPython Development Team | ||||
# | ||||
# Distributed under the terms of the BSD License. The full license is in | ||||
# the file COPYING, distributed as part of this software. | ||||
#----------------------------------------------------------------------------- | ||||
import nose.tools as nt | ||||
from IPython.lib import latextools | ||||
Thomas Kluyver
|
r8013 | from IPython.testing.decorators import onlyif_cmds_exist, skipif_not_matplotlib | ||
Takafumi Arakaki
|
r7858 | from IPython.testing.tools import monkeypatch | ||
from IPython.utils.process import FindCmdError | ||||
def test_latex_to_png_dvipng_fails_when_no_cmd(): | ||||
""" | ||||
`latex_to_png_dvipng` should return None when there is no required command | ||||
""" | ||||
for command in ['latex', 'dvipng']: | ||||
yield (check_latex_to_png_dvipng_fails_when_no_cmd, command) | ||||
def check_latex_to_png_dvipng_fails_when_no_cmd(command): | ||||
def mock_find_cmd(arg): | ||||
if arg == command: | ||||
raise FindCmdError | ||||
with monkeypatch(latextools, "find_cmd", mock_find_cmd): | ||||
nt.assert_equals(latextools.latex_to_png_dvipng("whatever", True), | ||||
None) | ||||
@onlyif_cmds_exist('latex', 'dvipng') | ||||
def test_latex_to_png_dvipng_runs(): | ||||
""" | ||||
Test that latex_to_png_dvipng just runs without error. | ||||
""" | ||||
def mock_kpsewhich(filename): | ||||
nt.assert_equals(filename, "breqn.sty") | ||||
return None | ||||
for (s, wrap) in [("$$x^2$$", False), ("x^2", True)]: | ||||
yield (latextools.latex_to_png_dvipng, s, wrap) | ||||
with monkeypatch(latextools, "kpsewhich", mock_kpsewhich): | ||||
yield (latextools.latex_to_png_dvipng, s, wrap) | ||||
Thomas Kluyver
|
r8013 | @skipif_not_matplotlib | ||
def test_latex_to_png_mpl_runs(): | ||||
""" | ||||
Test that latex_to_png_mpl just runs without error. | ||||
""" | ||||
def mock_kpsewhich(filename): | ||||
nt.assert_equals(filename, "breqn.sty") | ||||
return None | ||||
for (s, wrap) in [("$x^2$", False), ("x^2", True)]: | ||||
yield (latextools.latex_to_png_mpl, s, wrap) | ||||
with monkeypatch(latextools, "kpsewhich", mock_kpsewhich): | ||||
yield (latextools.latex_to_png_mpl, s, wrap) | ||||
@skipif_not_matplotlib | ||||
def test_latex_to_html(): | ||||
img = latextools.latex_to_html("$x^2$") | ||||
nt.assert_in("", img) | ||||
Takafumi Arakaki
|
r7858 | |||
def test_genelatex_no_wrap(): | ||||
""" | ||||
Test genelatex with wrap=False. | ||||
""" | ||||
def mock_kpsewhich(filename): | ||||
assert False, ("kpsewhich should not be called " | ||||
"(called with {0})".format(filename)) | ||||
with monkeypatch(latextools, "kpsewhich", mock_kpsewhich): | ||||
nt.assert_equals( | ||||
'\n'.join(latextools.genelatex("body text", False)), | ||||
r'''\documentclass{article} | ||||
\usepackage{amsmath} | ||||
\usepackage{amsthm} | ||||
\usepackage{amssymb} | ||||
\usepackage{bm} | ||||
\pagestyle{empty} | ||||
\begin{document} | ||||
body text | ||||
\end{document}''') | ||||
def test_genelatex_wrap_with_breqn(): | ||||
""" | ||||
Test genelatex with wrap=True for the case breqn.sty is installed. | ||||
""" | ||||
def mock_kpsewhich(filename): | ||||
nt.assert_equals(filename, "breqn.sty") | ||||
return "path/to/breqn.sty" | ||||
with monkeypatch(latextools, "kpsewhich", mock_kpsewhich): | ||||
nt.assert_equals( | ||||
'\n'.join(latextools.genelatex("x^2", True)), | ||||
r'''\documentclass{article} | ||||
\usepackage{amsmath} | ||||
\usepackage{amsthm} | ||||
\usepackage{amssymb} | ||||
\usepackage{bm} | ||||
\usepackage{breqn} | ||||
\pagestyle{empty} | ||||
\begin{document} | ||||
\begin{dmath*} | ||||
x^2 | ||||
\end{dmath*} | ||||
\end{document}''') | ||||
def test_genelatex_wrap_without_breqn(): | ||||
""" | ||||
Test genelatex with wrap=True for the case breqn.sty is not installed. | ||||
""" | ||||
def mock_kpsewhich(filename): | ||||
nt.assert_equals(filename, "breqn.sty") | ||||
return None | ||||
with monkeypatch(latextools, "kpsewhich", mock_kpsewhich): | ||||
nt.assert_equals( | ||||
'\n'.join(latextools.genelatex("x^2", True)), | ||||
r'''\documentclass{article} | ||||
\usepackage{amsmath} | ||||
\usepackage{amsthm} | ||||
\usepackage{amssymb} | ||||
\usepackage{bm} | ||||
\pagestyle{empty} | ||||
\begin{document} | ||||
$$x^2$$ | ||||
\end{document}''') | ||||