##// END OF EJS Templates
add nbformat.output_from_msg...
add nbformat.output_from_msg for creating the appropriate NotebookNode from an output message on the IOPub channel.

File last commit:

r18580:ba8461eb
r18582:b3e49660
Show More
test_extractoutput.py
59 lines | 1.9 KiB | text/x-python | PythonLexer
MinRK
update nbconvert to nbformat 4
r18580 """Tests for the extractoutput preprocessor"""
Jonathan Frederic
Added extract output test
r12029
MinRK
update nbconvert to nbformat 4
r18580 # Copyright (c) IPython Development Team.
Jonathan Frederic
Added extract output test
r12029 # Distributed under the terms of the Modified BSD License.
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 from .base import PreprocessorTestsBase
from ..extractoutput import ExtractOutputPreprocessor
Jonathan Frederic
Added extract output test
r12029
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 class TestExtractOutput(PreprocessorTestsBase):
Jonathan Frederic
Added extract output test
r12029 """Contains test functions for extractoutput.py"""
Jonathan Frederic
Fixes small things pointed out by @minrk
r12035
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 def build_preprocessor(self):
"""Make an instance of a preprocessor"""
preprocessor = ExtractOutputPreprocessor()
MinRK
update nbconvert to nbformat 4
r18580 preprocessor.extract_output_types = {'text/plain', 'image/png', 'application/pdf'}
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 preprocessor.enabled = True
return preprocessor
Jonathan Frederic
Fixes small things pointed out by @minrk
r12035
def test_constructor(self):
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 """Can a ExtractOutputPreprocessor be constructed?"""
self.build_preprocessor()
Jonathan Frederic
Added extract output test
r12029
def test_output(self):
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 """Test the output of the ExtractOutputPreprocessor"""
Jonathan Frederic
Expanded transformer pass line, for easier debugging
r12039 nb = self.build_notebook()
res = self.build_resources()
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 preprocessor = self.build_preprocessor()
nb, res = preprocessor(nb, res)
Jonathan Frederic
Added extract output test
r12029
# Check if text was extracted.
MinRK
update nbconvert to nbformat 4
r18580 output = nb.cells[0].outputs[1]
assert 'text/plain_filename' in output
text_filename = output['text/plain_filename']
Jonathan Frederic
Added extract output test
r12029
# Check if png was extracted.
MinRK
update nbconvert to nbformat 4
r18580 output = nb.cells[0].outputs[6]
assert 'image/png_filename' in output
png_filename = output['image/png_filename']
MinRK
add pdf to extract output tests
r15386
# Check that pdf was extracted
MinRK
update nbconvert to nbformat 4
r18580 output = nb.cells[0].outputs[7]
MinRK
add pdf to extract output tests
r15386 assert 'application/pdf_filename' in output
pdf_filename = output['application/pdf_filename']
Jonathan Frederic
Added extract output test
r12029
# Verify text output
assert text_filename in res['outputs']
Jonathan Frederic
Extracted output are now test against byte arrays instead of strings
r12038 self.assertEqual(res['outputs'][text_filename], b'b')
Jonathan Frederic
Added extract output test
r12029
# Verify png output
assert png_filename in res['outputs']
Jonathan Frederic
Extracted output are now test against byte arrays instead of strings
r12038 self.assertEqual(res['outputs'][png_filename], b'g')
MinRK
add pdf to extract output tests
r15386
# Verify pdf output
assert pdf_filename in res['outputs']
self.assertEqual(res['outputs'][pdf_filename], b'h')