diff --git a/IPython/html/tests/notebook/output.js b/IPython/html/tests/notebook/output.js new file mode 100644 index 0000000..1fcfe44 --- /dev/null +++ b/IPython/html/tests/notebook/output.js @@ -0,0 +1,98 @@ +// +// Various output tests +// + +casper.notebook_test(function () { + + this.test_coalesced_output = function (msg, code, expected) { + this.then(function () { + this.echo("Test coalesced output: " + msg); + }); + + this.thenEvaluate(function (code) { + IPython.notebook.insert_cell_at_index(0, "code"); + var cell = IPython.notebook.get_cell(0); + cell.set_text(code); + cell.execute(); + }, {code: code}); + + this.wait_for_output(0); + + this.then(function () { + var results = this.evaluate(function () { + var cell = IPython.notebook.get_cell(0); + return cell.output_area.outputs; + }); + this.test.assertEquals(results.length, expected.length, "correct number of outputs"); + for (var i = 0; i < results.length; i++) { + var r = results[i]; + var ex = expected[i]; + this.test.assertEquals(r.output_type, ex.output_type, "output " + i); + if (r.output_type === 'stream') { + this.test.assertEquals(r.stream, ex.stream, "stream " + i); + this.test.assertEquals(r.text, ex.text, "content " + i); + } + } + }); + + }; + + this.thenEvaluate(function () { + IPython.notebook.insert_cell_at_index(0, "code"); + var cell = IPython.notebook.get_cell(0); + cell.set_text([ + "from __future__ import print_function", + "import sys", + "from IPython.display import display" + ].join("\n") + ); + cell.execute(); + }); + + this.test_coalesced_output("stdout", [ + "print(1)", + "sys.stdout.flush()", + "print(2)", + "sys.stdout.flush()", + "print(3)" + ].join("\n"), [{ + output_type: "stream", + stream: "stdout", + text: "1\n2\n3\n" + }] + ); + + this.test_coalesced_output("stdout+sdterr", [ + "print(1)", + "sys.stdout.flush()", + "print(2)", + "print(3, file=sys.stderr)" + ].join("\n"), [{ + output_type: "stream", + stream: "stdout", + text: "1\n2\n" + },{ + output_type: "stream", + stream: "stderr", + text: "3\n" + }] + ); + + this.test_coalesced_output("display splits streams", [ + "print(1)", + "sys.stdout.flush()", + "display(2)", + "print(3)" + ].join("\n"), [{ + output_type: "stream", + stream: "stdout", + text: "1\n" + },{ + output_type: "display_data", + },{ + output_type: "stream", + stream: "stdout", + text: "3\n" + }] + ); +}); diff --git a/IPython/html/tests/widgets/widget.js b/IPython/html/tests/widgets/widget.js index 5eb8d5b..dce37a2 100644 --- a/IPython/html/tests/widgets/widget.js +++ b/IPython/html/tests/widgets/widget.js @@ -151,7 +151,7 @@ casper.notebook_test(function () { 'display(textbox)\n' + 'textbox.add_class("my-throttle-textbox")\n' + 'def handle_change(name, old, new):\n' + - ' print(len(new))\n' + + ' display(len(new))\n' + ' time.sleep(0.5)\n' + 'textbox.on_trait_change(handle_change, "value")\n' + 'print(textbox.model_id)'); @@ -182,7 +182,7 @@ casper.notebook_test(function () { this.test.assert(outputs.length <= 5, 'Messages throttled.'); // We also need to verify that the last state sent was correct. - var last_state = outputs[outputs.length-1].text; - this.test.assertEquals(last_state, "20\n", "Last state sent when throttling."); + var last_state = outputs[outputs.length-1]['text/plain']; + this.test.assertEquals(last_state, "20", "Last state sent when throttling."); }); }); diff --git a/IPython/html/tests/widgets/widget_button.js b/IPython/html/tests/widgets/widget_button.js index 75b35e3..ae0aec6 100644 --- a/IPython/html/tests/widgets/widget_button.js +++ b/IPython/html/tests/widgets/widget_button.js @@ -8,14 +8,14 @@ casper.notebook_test(function () { var button_index = this.append_cell( 'button = widgets.ButtonWidget(description="Title")\n' + - 'display(button)\n'+ + 'display(button)\n' + 'print("Success")\n' + 'def handle_click(sender):\n' + - ' print("Clicked")\n' + + ' display("Clicked")\n' + 'button.on_click(handle_click)'); this.execute_cell_then(button_index, function(index){ - this.test.assertEquals(this.get_output_cell(index).text, 'Success\n', + this.test.assertEquals(this.get_output_cell(index).text, 'Success\n', 'Create button cell executed with correct output.'); this.test.assert(this.cell_element_exists(index, @@ -37,7 +37,7 @@ casper.notebook_test(function () { this.wait_for_output(button_index, 1); this.then(function () { - this.test.assertEquals(this.get_output_cell(button_index, 1).text, 'Clicked\n', + this.test.assertEquals(this.get_output_cell(button_index, 1)['text/plain'], "'Clicked'", 'Button click event fires.'); }); }); \ No newline at end of file