##// END OF EJS Templates
Merge pull request #3845 from martijnvermaat/nbconvert-fix-serve-dir...
Merge pull request #3845 from martijnvermaat/nbconvert-fix-serve-dir nbconvert: Serve from original build directory

File last commit:

r11767:c1cdf94d
r11883:6bc8d9bf merge
Show More
test_nbconvertapp.py
149 lines | 5.4 KiB | text/x-python | PythonLexer
Jonathan Frederic
Added tests directory
r11477 """
Contains tests for the nbconvertapp
"""
#-----------------------------------------------------------------------------
#Copyright (c) 2013, the IPython Development Team.
#
#Distributed under the terms of the Modified BSD License.
#
#The full license is in the file COPYING.txt, distributed with this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
Jonathan Frederic
Added test files, and basic tests
r11478 import os
Jonathan Frederic
Added tests directory
r11477 from .base import TestsBase
Jonathan Frederic
Fixes for Py3.3
r11547 from IPython.utils import py3compat
Jonathan Frederic
Moved PDF logic into Post-Processor class
r11747 from IPython.testing import decorators as dec
Jonathan Frederic
Fixes for Py3.3
r11547
#-----------------------------------------------------------------------------
# Constants
#-----------------------------------------------------------------------------
Jonathan Frederic
Added space between pund and comment
r11640 # Define ipython commandline name
Jonathan Frederic
Fixes for Py3.3
r11547 if py3compat.PY3:
IPYTHON = 'ipython3'
else:
IPYTHON = 'ipython'
Jonathan Frederic
Added tests directory
r11477 #-----------------------------------------------------------------------------
# Classes and functions
#-----------------------------------------------------------------------------
Jonathan Frederic
s/Test_/Test
r11494 class TestNbConvertApp(TestsBase):
Jonathan Frederic
Added tests directory
r11477 """Collection of NbConvertApp tests"""
Jonathan Frederic
Added test files, and basic tests
r11478
def test_notebook_help(self):
"""
Will help show if no notebooks are specified?
"""
with self.create_temp_cwd():
Jonathan Frederic
Fixes for Py3.3
r11547 assert "see '--help-all'" in self.call([IPYTHON, 'nbconvert'])
Jonathan Frederic
Added test files, and basic tests
r11478
def test_glob(self):
"""
Do search patterns work for notebook names?
"""
with self.create_temp_cwd(['notebook*.ipynb']):
Jonathan Frederic
Fixes for Py3.3
r11547 assert not 'error' in self.call([IPYTHON, 'nbconvert',
Jonathan Frederic
Fixed tests
r11740 '--to="python"', '--notebooks=["*.ipynb"]']).lower()
Jonathan Frederic
Updated app tests...
r11639 assert os.path.isfile('notebook1.py')
assert os.path.isfile('notebook2.py')
Jonathan Frederic
Added test files, and basic tests
r11478
def test_glob_subdir(self):
"""
Do search patterns work for subdirectory notebook names?
"""
with self.create_temp_cwd() as cwd:
self.copy_files_to(['notebook*.ipynb'], 'subdir/')
Jonathan Frederic
Fixed tests
r11740 assert not 'error' in self.call([IPYTHON, 'nbconvert', '--to="python"',
Jonathan Frederic
Added test files, and basic tests
r11478 '--notebooks=["%s"]' % os.path.join('subdir', '*.ipynb')]).lower()
Jonathan Frederic
Updated app tests...
r11639 assert os.path.isfile('notebook1.py')
assert os.path.isfile('notebook2.py')
Jonathan Frederic
Added test files, and basic tests
r11478
def test_explicit(self):
"""
Do explicit notebook names work?
"""
with self.create_temp_cwd(['notebook*.ipynb']):
Jonathan Frederic
Fixed tests
r11740 assert not 'error' in self.call([IPYTHON, 'nbconvert', '--to="python"',
Jonathan Frederic
Added test files, and basic tests
r11478 '--notebooks=["notebook2.ipynb"]']).lower()
Jonathan Frederic
Updated app tests...
r11639 assert not os.path.isfile('notebook1.py')
assert os.path.isfile('notebook2.py')
Jonathan Frederic
Added test files, and basic tests
r11478
Jonathan Frederic
Fixed tests, broken because of missing pdflatex
r11752 @dec.onlyif_cmds_exist('pdflatex')
Jonathan Frederic
Moved PDF logic into Post-Processor class
r11747 def test_post_processor(self):
"""
Do post processors work?
"""
with self.create_temp_cwd(['notebook1.ipynb']):
assert not 'error' in self.call([IPYTHON, 'nbconvert', '--to="latex"',
Jonathan Frederic
Fixed tests, broken because of missing pdflatex
r11752 'notebook1', '--post="PDF"', '--PDFPostProcessor.verbose=True']).lower()
Jonathan Frederic
Moved PDF logic into Post-Processor class
r11747 assert os.path.isfile('notebook1.tex')
print("\n\n\t" + "\n\t".join([f for f in os.listdir('.') if os.path.isfile(f)]) + "\n\n")
assert os.path.isfile('notebook1.pdf')
Jonathan Frederic
flavor=template
r11745 def test_template(self):
Jonathan Frederic
Fixed tests
r11740 """
Jonathan Frederic
flavor=template
r11745 Do export templates work?
Jonathan Frederic
Fixed tests
r11740 """
Jonathan Frederic
Fixed tests (because of reveal extension change)
r11767 with self.create_temp_cwd(['notebook2.ipynb']):
assert not 'error' in self.call([IPYTHON, 'nbconvert', '--to=slides',
'--notebooks=["notebook2.ipynb"]', '--template=reveal']).lower()
assert os.path.isfile('notebook2.slides.html')
with open('notebook2.slides.html') as f:
Jonathan Frederic
Fixed tests
r11740 assert '/reveal.css' in f.read()
Jonathan Frederic
Added test files, and basic tests
r11478 def test_glob_explicit(self):
"""
Can a search pattern be used along with matching explicit notebook names?
"""
with self.create_temp_cwd(['notebook*.ipynb']):
Jonathan Frederic
Fixed tests
r11740 assert not 'error' in self.call([IPYTHON, 'nbconvert', '--to="python"',
Jonathan Frederic
Added test files, and basic tests
r11478 '--notebooks=["*.ipynb", "notebook1.ipynb", "notebook2.ipynb"]']).lower()
Jonathan Frederic
Updated app tests...
r11639 assert os.path.isfile('notebook1.py')
assert os.path.isfile('notebook2.py')
Jonathan Frederic
Added test files, and basic tests
r11478
def test_explicit_glob(self):
"""
Can explicit notebook names be used and then a matching search pattern?
"""
with self.create_temp_cwd(['notebook*.ipynb']):
Jonathan Frederic
Fixed tests
r11740 assert not 'error' in self.call([IPYTHON, 'nbconvert', '--to="python"',
Jonathan Frederic
Added test files, and basic tests
r11478 '--notebooks=["notebook1.ipynb", "notebook2.ipynb", "*.ipynb"]']).lower()
Jonathan Frederic
Updated app tests...
r11639 assert os.path.isfile('notebook1.py')
assert os.path.isfile('notebook2.py')
Jonathan Frederic
Added test files, and basic tests
r11478
def test_default_config(self):
"""
Does the default config work?
"""
with self.create_temp_cwd(['notebook*.ipynb', 'ipython_nbconvert_config.py']):
Jonathan Frederic
Fixes for Py3.3
r11547 assert not 'error' in self.call([IPYTHON, 'nbconvert']).lower()
Jonathan Frederic
Updated app tests...
r11639 assert os.path.isfile('notebook1.py')
assert not os.path.isfile('notebook2.py')
Jonathan Frederic
Added test files, and basic tests
r11478
def test_override_config(self):
"""
Can the default config be overriden?
"""
with self.create_temp_cwd(['notebook*.ipynb', 'ipython_nbconvert_config.py',
'override.py']):
Jonathan Frederic
Fixes for Py3.3
r11547 assert not 'error' in self.call([IPYTHON, 'nbconvert', '--config="override.py"']).lower()
Jonathan Frederic
Updated app tests...
r11639 assert not os.path.isfile('notebook1.py')
assert os.path.isfile('notebook2.py')