widgets.js
76 lines
| 2.7 KiB
| application/javascript
|
JavascriptLexer
Jonathan Frederic
|
r14309 | // Test the widget framework. | ||
casper.notebook_test(function () { | ||||
Jonathan Frederic
|
r14435 | var index; | ||
Jonathan Frederic
|
r14436 | |||
Jonathan Frederic
|
r14309 | this.then(function () { | ||
// Check if the WidgetManager class is defined. | ||||
this.test.assert(this.evaluate(function() { | ||||
return IPython.WidgetManager != undefined; | ||||
}), 'WidgetManager class is defined'); | ||||
Jonathan Frederic
|
r14350 | }); | ||
Jonathan Frederic
|
r14436 | index = this.append_cell( | ||
Jonathan Frederic
|
r14435 | 'from IPython.html import widgets\n' + | ||
'from IPython.display import display, clear_output\n' + | ||||
'print("Success")'); | ||||
Jonathan Frederic
|
r14436 | this.execute_cell_then(index); | ||
Jonathan Frederic
|
r14435 | |||
Jonathan Frederic
|
r14350 | this.wait(500); // Wait for require.js async callbacks to load dependencies. | ||
this.then(function () { | ||||
Jonathan Frederic
|
r14309 | // Check if the widget manager has been instanciated. | ||
this.test.assert(this.evaluate(function() { | ||||
Jonathan Frederic
|
r14625 | return IPython.notebook.kernel.widget_manager != undefined; | ||
Jonathan Frederic
|
r14309 | }), 'Notebook widget manager instanciated'); | ||
}); | ||||
Jonathan Frederic
|
r14463 | throttle_index = this.append_cell( | ||
'import time\n' + | ||||
Jonathan Frederic
|
r14595 | 'textbox = widgets.TextBoxWidget()\n' + | ||
Jonathan Frederic
|
r14463 | 'display(textbox)\n'+ | ||
'textbox.add_class("my-throttle-textbox")\n' + | ||||
'def handle_change(name, old, new):\n' + | ||||
' print(len(new))\n' + | ||||
' time.sleep(0.5)\n' + | ||||
'textbox.on_trait_change(handle_change)\n' + | ||||
'print("Success")'); | ||||
this.execute_cell_then(throttle_index, function(index){ | ||||
this.test.assert(this.get_output_cell(index).text == 'Success\n', | ||||
'Test throttling cell executed with correct output'); | ||||
this.test.assert(this.cell_element_exists(index, | ||||
'.widget-area .widget-subarea'), | ||||
'Widget subarea exists.'); | ||||
this.test.assert(this.cell_element_exists(index, | ||||
'.my-throttle-textbox'), 'Textbox exists.'); | ||||
// Send 20 characters | ||||
this.sendKeys('.my-throttle-textbox', '....................'); | ||||
}); | ||||
this.wait(2000); // Wait for clicks to execute in kernel | ||||
this.then(function(){ | ||||
var resume = true; | ||||
var i = 0; | ||||
while (resume) { | ||||
i++; | ||||
var output = this.get_output_cell(throttle_index, i); | ||||
if (output === undefined || output === null) { | ||||
resume = false; | ||||
i--; | ||||
} | ||||
} | ||||
// Only 4 outputs should have printed, but because of timing, sometimes | ||||
// 5 outputs will print. All we need to do is verify num outputs <= 5 | ||||
// because that is much less than 20. | ||||
this.test.assert(i <= 5, 'Messages throttled.'); | ||||
// We also need to verify that the last state sent was correct. | ||||
var last_state = this.get_output_cell(throttle_index, i).text; | ||||
this.test.assert(last_state == "20\n", "Last state sent when throttling."); | ||||
Jonathan Frederic
|
r14625 | }); | ||
Jonathan Frederic
|
r14454 | }); | ||