widget_selectioncontainer.js
112 lines
| 5.0 KiB
| application/javascript
|
JavascriptLexer
Jonathan Frederic
|
r14464 | // Test multicontainer class | |
casper.notebook_test(function () { | |||
index = this.append_cell( | |||
'from IPython.html import widgets\n' + | |||
'from IPython.display import display, clear_output\n' + | |||
'print("Success")'); | |||
this.execute_cell_then(index); | |||
// Test tab view | |||
var multicontainer1_query = '.widget-area .widget-subarea div div.nav-tabs'; | |||
var multicontainer1_index = this.append_cell( | |||
Jonathan Frederic
|
r14596 | 'multicontainer = widgets.TabWidget()\n' + | |
Jonathan Frederic
|
r14834 | 'page1 = widgets.TextWidget()\n' + | |
'page2 = widgets.TextWidget()\n' + | |||
'page3 = widgets.TextWidget()\n' + | |||
Jonathan Frederic
|
r14509 | 'multicontainer.children = [page1, page2, page3]\n' + | |
Jonathan Frederic
|
r14464 | 'display(multicontainer)\n' + | |
'multicontainer.selected_index = 0\n' + | |||
'print("Success")\n'); | |||
this.execute_cell_then(multicontainer1_index, function(index){ | |||
Jonathan Frederic
|
r14526 | ||
MinRK
|
r14797 | this.test.assertEquals(this.get_output_cell(index).text, 'Success\n', | |
Jonathan Frederic
|
r14464 | 'Create multicontainer cell executed with correct output. (1)'); | |
this.test.assert(this.cell_element_exists(index, | |||
'.widget-area .widget-subarea'), | |||
'Widget subarea exists.'); | |||
this.test.assert(this.cell_element_exists(index, multicontainer1_query), | |||
'Widget tab list exists.'); | |||
this.test.assert(this.cell_element_exists(index, multicontainer1_query), | |||
'First widget tab list exists.'); | |||
// JQuery selector is 1 based | |||
MinRK
|
r14797 | this.click(multicontainer1_query + ' li:nth-child(2) a'); | |
Jonathan Frederic
|
r14464 | }); | |
Jonathan Frederic
|
r14970 | this.wait_for_idle(); | |
Jonathan Frederic
|
r14464 | ||
index = this.append_cell( | |||
'print(multicontainer.selected_index)\n' + | |||
'multicontainer.selected_index = 2'); // 0 based | |||
this.execute_cell_then(index, function(index){ | |||
MinRK
|
r14797 | this.test.assertEquals(this.get_output_cell(index).text, '1\n', // 0 based | |
Jonathan Frederic
|
r14464 | 'selected_index property updated with tab change.'); | |
// JQuery selector is 1 based | |||
this.test.assert(!this.cell_element_function(multicontainer1_index, multicontainer1_query + ' li:nth-child(1)', 'hasClass', ['active']), | |||
MinRK
|
r14797 | "Tab 1 is not selected."); | |
Jonathan Frederic
|
r14464 | this.test.assert(!this.cell_element_function(multicontainer1_index, multicontainer1_query + ' li:nth-child(2)', 'hasClass', ['active']), | |
MinRK
|
r14797 | "Tab 2 is not selected."); | |
Jonathan Frederic
|
r14464 | this.test.assert(this.cell_element_function(multicontainer1_index, multicontainer1_query + ' li:nth-child(3)', 'hasClass', ['active']), | |
MinRK
|
r14797 | "Tab 3 is selected."); | |
Jonathan Frederic
|
r14464 | }); | |
index = this.append_cell('multicontainer.set_title(1, "hello")\nprint("Success")'); // 0 based | |||
this.execute_cell_then(index, function(index){ | |||
this.test.assert(this.cell_element_function(multicontainer1_index, multicontainer1_query + | |||
' li:nth-child(2) a', 'html') == 'hello', | |||
'Tab page title set (after display).'); | |||
}); | |||
// Test accordion view | |||
var multicontainer2_query = '.widget-area .widget-subarea .accordion'; | |||
var multicontainer2_index = this.append_cell( | |||
Jonathan Frederic
|
r14596 | 'multicontainer = widgets.AccordionWidget()\n' + | |
Jonathan Frederic
|
r14836 | 'page1 = widgets.TextWidget()\n' + | |
'page2 = widgets.TextWidget()\n' + | |||
'page3 = widgets.TextWidget()\n' + | |||
Jonathan Frederic
|
r14509 | 'multicontainer.children = [page1, page2, page3]\n' + | |
Jonathan Frederic
|
r14464 | 'multicontainer.set_title(2, "good")\n' + | |
Jonathan Frederic
|
r14596 | 'display(multicontainer)\n' + | |
Jonathan Frederic
|
r14464 | 'multicontainer.selected_index = 0\n' + | |
'print("Success")\n'); | |||
this.execute_cell_then(multicontainer2_index, function(index){ | |||
MinRK
|
r14797 | this.test.assertEquals(this.get_output_cell(index).text, 'Success\n', | |
Jonathan Frederic
|
r14464 | 'Create multicontainer cell executed with correct output. (2)'); | |
this.test.assert(this.cell_element_exists(index, | |||
'.widget-area .widget-subarea'), | |||
'Widget subarea exists.'); | |||
this.test.assert(this.cell_element_exists(index, multicontainer2_query), | |||
'Widget accordion exists.'); | |||
this.test.assert(this.cell_element_exists(index, multicontainer2_query + | |||
' .accordion-group:nth-child(1) .accordion-body'), | |||
'First accordion page exists.'); | |||
// JQuery selector is 1 based | |||
this.test.assert(this.cell_element_function(index, multicontainer2_query + | |||
' .accordion-group:nth-child(3) .accordion-heading .accordion-toggle', | |||
'html')=='good', 'Accordion page title set (before display).'); | |||
// JQuery selector is 1 based | |||
this.click(multicontainer2_query + ' .accordion-group:nth-child(2) .accordion-heading .accordion-toggle'); | |||
}); | |||
Jonathan Frederic
|
r14970 | this.wait_for_idle(); | |
Jonathan Frederic
|
r14464 | ||
index = this.append_cell('print(multicontainer.selected_index)'); // 0 based | |||
this.execute_cell_then(index, function(index){ | |||
MinRK
|
r14797 | this.test.assertEquals(this.get_output_cell(index).text, '1\n', // 0 based | |
Jonathan Frederic
|
r14464 | 'selected_index property updated with tab change.'); | |
Jonathan Frederic
|
r15976 | ||
var is_collapsed = this.evaluate(function(s){ | |||
return $(s + ' div.accordion-group:nth-child(2) a').hasClass('collapsed'); // 1 based | |||
}, {s: multicontainer2_query}); | |||
this.test.assertEquals(is_collapsed, false, 'Was tab actually opened?'); | |||
Jonathan Frederic
|
r14464 | }); | |
}); |