|
|
"""
|
|
|
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
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
import os
|
|
|
from .base import TestsBase
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# Classes and functions
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
class TestNbConvertApp(TestsBase):
|
|
|
"""Collection of NbConvertApp tests"""
|
|
|
|
|
|
|
|
|
def test_notebook_help(self):
|
|
|
"""
|
|
|
Will help show if no notebooks are specified?
|
|
|
"""
|
|
|
with self.create_temp_cwd():
|
|
|
assert "see '--help-all'" in self.call(['ipython', 'nbconvert'])
|
|
|
|
|
|
|
|
|
def test_glob(self):
|
|
|
"""
|
|
|
Do search patterns work for notebook names?
|
|
|
"""
|
|
|
with self.create_temp_cwd(['notebook*.ipynb']):
|
|
|
assert not 'error' in self.call(['ipython', 'nbconvert',
|
|
|
'--format="python"', '--notebooks=["*.ipynb"]']).lower()
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook1.py'))
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook2.py'))
|
|
|
|
|
|
|
|
|
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/')
|
|
|
assert not 'error' in self.call(['ipython', 'nbconvert', '--format="python"',
|
|
|
'--notebooks=["%s"]' % os.path.join('subdir', '*.ipynb')]).lower()
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook1.py'))
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook2.py'))
|
|
|
|
|
|
|
|
|
def test_explicit(self):
|
|
|
"""
|
|
|
Do explicit notebook names work?
|
|
|
"""
|
|
|
with self.create_temp_cwd(['notebook*.ipynb']):
|
|
|
assert not 'error' in self.call(['ipython', 'nbconvert', '--format="python"',
|
|
|
'--notebooks=["notebook2.ipynb"]']).lower()
|
|
|
assert not os.path.isfile(os.path.join('nbconvert_build', 'notebook1.py'))
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook2.py'))
|
|
|
|
|
|
|
|
|
def test_glob_explicit(self):
|
|
|
"""
|
|
|
Can a search pattern be used along with matching explicit notebook names?
|
|
|
"""
|
|
|
with self.create_temp_cwd(['notebook*.ipynb']):
|
|
|
assert not 'error' in self.call(['ipython', 'nbconvert', '--format="python"',
|
|
|
'--notebooks=["*.ipynb", "notebook1.ipynb", "notebook2.ipynb"]']).lower()
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook1.py'))
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook2.py'))
|
|
|
|
|
|
|
|
|
def test_explicit_glob(self):
|
|
|
"""
|
|
|
Can explicit notebook names be used and then a matching search pattern?
|
|
|
"""
|
|
|
with self.create_temp_cwd(['notebook*.ipynb']):
|
|
|
assert not 'error' in self.call(['ipython', 'nbconvert', '--format="python"',
|
|
|
'--notebooks=["notebook1.ipynb", "notebook2.ipynb", "*.ipynb"]']).lower()
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook1.py'))
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook2.py'))
|
|
|
|
|
|
|
|
|
def test_default_config(self):
|
|
|
"""
|
|
|
Does the default config work?
|
|
|
"""
|
|
|
with self.create_temp_cwd(['notebook*.ipynb', 'ipython_nbconvert_config.py']):
|
|
|
assert not 'error' in self.call(['ipython', 'nbconvert']).lower()
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook1.py'))
|
|
|
assert not os.path.isfile(os.path.join('nbconvert_build', 'notebook2.py'))
|
|
|
|
|
|
|
|
|
def test_override_config(self):
|
|
|
"""
|
|
|
Can the default config be overriden?
|
|
|
"""
|
|
|
with self.create_temp_cwd(['notebook*.ipynb', 'ipython_nbconvert_config.py',
|
|
|
'override.py']):
|
|
|
assert not 'error' in self.call(['ipython', 'nbconvert', '--config="override.py"']).lower()
|
|
|
assert not os.path.isfile(os.path.join('nbconvert_build', 'notebook1.py'))
|
|
|
assert os.path.isfile(os.path.join('nbconvert_build', 'notebook2.py'))
|
|
|
|