2013-12-13 02:49:34 +08:00
|
|
|
// Test widget float class
|
|
|
|
casper.notebook_test(function () {
|
2014-02-01 03:48:51 +08:00
|
|
|
var float_text = {};
|
2014-08-27 23:15:11 +08:00
|
|
|
float_text.query = '.widget-area .widget-subarea .my-second-float-text input';
|
2014-02-01 03:48:51 +08:00
|
|
|
float_text.index = this.append_cell(
|
2014-11-11 04:36:39 +08:00
|
|
|
'from IPython.html import widgets\n' +
|
|
|
|
'from IPython.display import display, clear_output\n' +
|
2014-07-19 03:47:33 +08:00
|
|
|
'float_widget = widgets.FloatText()\n' +
|
2013-12-13 02:49:34 +08:00
|
|
|
'display(float_widget)\n' +
|
2014-08-23 03:20:59 +08:00
|
|
|
'float_widget._dom_classes = ["my-second-float-text"]\n' +
|
2014-02-01 03:48:51 +08:00
|
|
|
'print(float_widget.model_id)\n');
|
|
|
|
this.execute_cell_then(float_text.index, function(index){
|
|
|
|
float_text.model_id = this.get_output_cell(index).text.trim();
|
2014-11-11 04:36:39 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
// Wait for the widget to actually display.
|
|
|
|
this.wait_for_element(float_text.index, float_text.query);
|
|
|
|
|
|
|
|
// Continue with the tests
|
|
|
|
this.then(function(){
|
|
|
|
this.test.assert(this.cell_element_exists(float_text.index,
|
2013-12-13 02:49:34 +08:00
|
|
|
'.widget-area .widget-subarea'),
|
|
|
|
'Widget subarea exists.');
|
|
|
|
|
2014-11-11 04:36:39 +08:00
|
|
|
this.test.assert(this.cell_element_exists(float_text.index, float_text.query),
|
2013-12-13 02:49:34 +08:00
|
|
|
'Widget float textbox exists.');
|
|
|
|
|
2014-02-01 03:48:51 +08:00
|
|
|
this.cell_element_function(float_text.index, float_text.query, 'val', ['']);
|
|
|
|
this.sendKeys(float_text.query, '1.05');
|
2013-12-13 02:49:34 +08:00
|
|
|
});
|
|
|
|
|
2014-02-01 03:48:51 +08:00
|
|
|
this.wait_for_widget(float_text);
|
2013-12-13 02:49:34 +08:00
|
|
|
|
|
|
|
index = this.append_cell('print(float_widget.value)\n');
|
|
|
|
this.execute_cell_then(index, function(index){
|
2014-01-27 09:01:59 +08:00
|
|
|
this.test.assertEquals(this.get_output_cell(index).text, '1.05\n',
|
2013-12-13 02:49:34 +08:00
|
|
|
'Float textbox value set.');
|
2014-02-01 03:48:51 +08:00
|
|
|
this.cell_element_function(float_text.index, float_text.query, 'val', ['']);
|
|
|
|
this.sendKeys(float_text.query, '123456789.0');
|
2013-12-13 02:49:34 +08:00
|
|
|
});
|
|
|
|
|
2014-02-01 03:48:51 +08:00
|
|
|
this.wait_for_widget(float_text);
|
|
|
|
|
2013-12-13 02:49:34 +08:00
|
|
|
index = this.append_cell('print(float_widget.value)\n');
|
|
|
|
this.execute_cell_then(index, function(index){
|
2014-01-27 09:01:59 +08:00
|
|
|
this.test.assertEquals(this.get_output_cell(index).text, '123456789.0\n',
|
2013-12-13 02:49:34 +08:00
|
|
|
'Long float textbox value set (probably triggers throttling).');
|
2014-02-01 03:48:51 +08:00
|
|
|
this.cell_element_function(float_text.index, float_text.query, 'val', ['']);
|
|
|
|
this.sendKeys(float_text.query, '12hello');
|
2013-12-13 02:49:34 +08:00
|
|
|
});
|
|
|
|
|
2014-02-01 03:48:51 +08:00
|
|
|
this.wait_for_widget(float_text);
|
2013-12-13 02:49:34 +08:00
|
|
|
|
|
|
|
index = this.append_cell('print(float_widget.value)\n');
|
|
|
|
this.execute_cell_then(index, function(index){
|
2014-01-27 09:01:59 +08:00
|
|
|
this.test.assertEquals(this.get_output_cell(index).text, '12.0\n',
|
2013-12-13 02:49:34 +08:00
|
|
|
'Invald float textbox value caught and filtered.');
|
|
|
|
});
|
2014-01-22 08:52:37 +08:00
|
|
|
|
2014-08-27 23:15:11 +08:00
|
|
|
var float_text_query = '.widget-area .widget-subarea .widget-numeric-text';
|
2014-02-01 03:48:51 +08:00
|
|
|
var slider = {};
|
2014-08-27 23:15:11 +08:00
|
|
|
slider.query = '.widget-area .widget-subarea .slider';
|
2014-02-01 03:48:51 +08:00
|
|
|
slider.index = this.append_cell(
|
2014-07-19 03:47:33 +08:00
|
|
|
'floatrange = [widgets.BoundedFloatText(), \n' +
|
|
|
|
' widgets.FloatSlider()]\n' +
|
2014-01-22 08:52:37 +08:00
|
|
|
'[display(floatrange[i]) for i in range(2)]\n' +
|
|
|
|
'print("Success")\n');
|
2014-02-01 03:48:51 +08:00
|
|
|
this.execute_cell_then(slider.index, function(index){
|
2014-01-27 09:01:59 +08:00
|
|
|
this.test.assertEquals(this.get_output_cell(index).text, 'Success\n',
|
2014-01-22 08:52:37 +08:00
|
|
|
'Create float range cell executed with correct output.');
|
2014-11-11 04:36:39 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
// Wait for the widgets to actually display.
|
|
|
|
this.wait_for_element(slider.index, slider.query);
|
|
|
|
this.wait_for_element(slider.index, float_text_query);
|
2014-01-22 08:52:37 +08:00
|
|
|
|
2014-11-11 04:36:39 +08:00
|
|
|
this.then(function(){
|
|
|
|
this.test.assert(this.cell_element_exists(slider.index,
|
2014-01-22 08:52:37 +08:00
|
|
|
'.widget-area .widget-subarea'),
|
|
|
|
'Widget subarea exists.');
|
|
|
|
|
2014-11-11 04:36:39 +08:00
|
|
|
this.test.assert(this.cell_element_exists(slider.index, slider.query),
|
2014-01-22 08:52:37 +08:00
|
|
|
'Widget slider exists.');
|
|
|
|
|
2014-11-11 04:36:39 +08:00
|
|
|
this.test.assert(this.cell_element_exists(slider.index, float_text_query),
|
2014-01-22 08:52:37 +08:00
|
|
|
'Widget float textbox exists.');
|
|
|
|
});
|
|
|
|
|
|
|
|
index = this.append_cell(
|
|
|
|
'for widget in floatrange:\n' +
|
|
|
|
' widget.max = 50.0\n' +
|
|
|
|
' widget.min = -50.0\n' +
|
2014-01-23 04:12:08 +08:00
|
|
|
' widget.value = 25.0\n' +
|
2014-01-22 08:52:37 +08:00
|
|
|
'print("Success")\n');
|
|
|
|
this.execute_cell_then(index, function(index){
|
|
|
|
|
2014-01-27 09:01:59 +08:00
|
|
|
this.test.assertEquals(this.get_output_cell(index).text, 'Success\n',
|
2014-01-22 08:52:37 +08:00
|
|
|
'Float range properties cell executed with correct output.');
|
|
|
|
|
2014-02-01 03:48:51 +08:00
|
|
|
this.test.assert(this.cell_element_exists(slider.index, slider.query),
|
2014-01-22 08:52:37 +08:00
|
|
|
'Widget slider exists.');
|
|
|
|
|
2014-02-01 03:48:51 +08:00
|
|
|
this.test.assert(this.cell_element_function(slider.index, slider.query,
|
2014-01-23 04:12:08 +08:00
|
|
|
'slider', ['value']) == 25.0,
|
2014-01-22 08:52:37 +08:00
|
|
|
'Slider set to Python value.');
|
|
|
|
});
|
2013-12-13 02:49:34 +08:00
|
|
|
});
|