##// END OF EJS Templates
Merge pull request #4799 from ivanov/minor-jstest...
Min RK -
r14186:f4bfdce9 merge
parent child Browse files
Show More
@@ -1,235 +1,237 b''
1 // Test opening a rich notebook, saving it, and reopening it again.
1 // Test opening a rich notebook, saving it, and reopening it again.
2 //
2 //
3 //toJSON fromJSON toJSON and do a string comparison
3 //toJSON fromJSON toJSON and do a string comparison
4
4
5
5
6 // this is just a copy of OutputArea.mime_mape_r in IPython/html/static/notebook/js/outputarea.js
6 // this is just a copy of OutputArea.mime_mape_r in IPython/html/static/notebook/js/outputarea.js
7 mime = {
7 mime = {
8 "text" : "text/plain",
8 "text" : "text/plain",
9 "html" : "text/html",
9 "html" : "text/html",
10 "svg" : "image/svg+xml",
10 "svg" : "image/svg+xml",
11 "png" : "image/png",
11 "png" : "image/png",
12 "jpeg" : "image/jpeg",
12 "jpeg" : "image/jpeg",
13 "latex" : "text/latex",
13 "latex" : "text/latex",
14 "json" : "application/json",
14 "json" : "application/json",
15 "javascript" : "application/javascript",
15 "javascript" : "application/javascript",
16 };
16 };
17
17
18 var black_dot_jpeg="u\"\"\"/9j/4AAQSkZJRgABAQEASABIAAD/2wBDACodICUgGiolIiUvLSoyP2lEPzo6P4FcYUxpmYagnpaG\nk5GovfLNqLPltZGT0v/V5fr/////o8v///////L/////2wBDAS0vLz83P3xERHz/rpOu////////\n////////////////////////////////////////////////////////////wgARCAABAAEDAREA\nAhEBAxEB/8QAFAABAAAAAAAAAAAAAAAAAAAABP/EABQBAQAAAAAAAAAAAAAAAAAAAAD/2gAMAwEA\nAhADEAAAARn/xAAUEAEAAAAAAAAAAAAAAAAAAAAA/9oACAEBAAEFAn//xAAUEQEAAAAAAAAAAAAA\nAAAAAAAA/9oACAEDAQE/AX//xAAUEQEAAAAAAAAAAAAAAAAAAAAA/9oACAECAQE/AX//xAAUEAEA\nAAAAAAAAAAAAAAAAAAAA/9oACAEBAAY/An//xAAUEAEAAAAAAAAAAAAAAAAAAAAA/9oACAEBAAE/\nIX//2gAMAwEAAgADAAAAEB//xAAUEQEAAAAAAAAAAAAAAAAAAAAA/9oACAEDAQE/EH//xAAUEQEA\nAAAAAAAAAAAAAAAAAAAA/9oACAECAQE/EH//xAAUEAEAAAAAAAAAAAAAAAAAAAAA/9oACAEBAAE/\nEH//2Q==\"\"\"";
18 var black_dot_jpeg="u\"\"\"/9j/4AAQSkZJRgABAQEASABIAAD/2wBDACodICUgGiolIiUvLSoyP2lEPzo6P4FcYUxpmYagnpaG\nk5GovfLNqLPltZGT0v/V5fr/////o8v///////L/////2wBDAS0vLz83P3xERHz/rpOu////////\n////////////////////////////////////////////////////////////wgARCAABAAEDAREA\nAhEBAxEB/8QAFAABAAAAAAAAAAAAAAAAAAAABP/EABQBAQAAAAAAAAAAAAAAAAAAAAD/2gAMAwEA\nAhADEAAAARn/xAAUEAEAAAAAAAAAAAAAAAAAAAAA/9oACAEBAAEFAn//xAAUEQEAAAAAAAAAAAAA\nAAAAAAAA/9oACAEDAQE/AX//xAAUEQEAAAAAAAAAAAAAAAAAAAAA/9oACAECAQE/AX//xAAUEAEA\nAAAAAAAAAAAAAAAAAAAA/9oACAEBAAY/An//xAAUEAEAAAAAAAAAAAAAAAAAAAAA/9oACAEBAAE/\nIX//2gAMAwEAAgADAAAAEB//xAAUEQEAAAAAAAAAAAAAAAAAAAAA/9oACAEDAQE/EH//xAAUEQEA\nAAAAAAAAAAAAAAAAAAAA/9oACAECAQE/EH//xAAUEAEAAAAAAAAAAAAAAAAAAAAA/9oACAEBAAE/\nEH//2Q==\"\"\"";
19 var black_dot_png = 'u\"iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAAACnej3aAAAAAWJLR0QA\\niAUdSAAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB94BCRQnOqNu0b4AAAAKSURBVAjXY2AA\\nAAACAAHiIbwzAAAAAElFTkSuQmCC\"';
19 var black_dot_png = 'u\"iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAAACnej3aAAAAAWJLR0QA\\niAUdSAAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB94BCRQnOqNu0b4AAAAKSURBVAjXY2AA\\nAAACAAHiIbwzAAAAAElFTkSuQmCC\"';
20 var svg = "\"<svg width='1cm' height='1cm' viewBox='0 0 1000 500'><defs><style>rect {fill:red;}; </style></defs><rect id='r1' x='200' y='100' width='600' height='300' /></svg>\"";
20 var svg = "\"<svg width='1cm' height='1cm' viewBox='0 0 1000 500'><defs><style>rect {fill:red;}; </style></defs><rect id='r1' x='200' y='100' width='600' height='300' /></svg>\"";
21
21
22 // helper function to ensure that the short_name is found in the toJSON
22 // helper function to ensure that the short_name is found in the toJSON
23 // represetnation, while the original in-memory cell retains its long mimetype
23 // represetnation, while the original in-memory cell retains its long mimetype
24 // name, and that fromJSON also gets its long mimetype name
24 // name, and that fromJSON also gets its long mimetype name
25 function assert_has(short_name, json, result, result2) {
25 function assert_has(short_name, json, result, result2) {
26 long_name = mime[short_name];
26 long_name = mime[short_name];
27 this.test.assertTrue(json[0].hasOwnProperty(short_name),
27 this.test.assertTrue(json[0].hasOwnProperty(short_name),
28 'toJSON() representation uses ' + short_name);
28 'toJSON() representation uses ' + short_name);
29 this.test.assertTrue(result.hasOwnProperty(long_name),
29 this.test.assertTrue(result.hasOwnProperty(long_name),
30 'toJSON() original embeded JSON keeps ' + long_name);
30 'toJSON() original embeded JSON keeps ' + long_name);
31 this.test.assertTrue(result2.hasOwnProperty(long_name),
31 this.test.assertTrue(result2.hasOwnProperty(long_name),
32 'fromJSON() embeded ' + short_name + ' gets mime key ' + long_name);
32 'fromJSON() embeded ' + short_name + ' gets mime key ' + long_name);
33 }
33 }
34
34
35 // helper function for checkout that the first two cells have a particular
35 // helper function for checkout that the first two cells have a particular
36 // output_type (either 'pyout' or 'display_data'), and checks the to/fromJSON
36 // output_type (either 'pyout' or 'display_data'), and checks the to/fromJSON
37 // for a set of mimetype keys, using their short names ('javascript', 'text',
37 // for a set of mimetype keys, using their short names ('javascript', 'text',
38 // 'png', etc).
38 // 'png', etc).
39 function check_output_area(output_type, keys) {
39 function check_output_area(output_type, keys) {
40 this.wait_for_output(0);
40 this.wait_for_output(0);
41 json = this.evaluate(function() {
41 json = this.evaluate(function() {
42 var json = IPython.notebook.get_cell(0).output_area.toJSON();
42 var json = IPython.notebook.get_cell(0).output_area.toJSON();
43 // appended cell will initially be empty, lets add it some output
43 // appended cell will initially be empty, lets add it some output
44 var cell = IPython.notebook.get_cell(1).output_area.fromJSON(json);
44 var cell = IPython.notebook.get_cell(1).output_area.fromJSON(json);
45 return json;
45 return json;
46 });
46 });
47 // The evaluate call above happens asyncrhonously: wait for cell[1] to have output
48 this.wait_for_output(1);
47 var result = this.get_output_cell(0);
49 var result = this.get_output_cell(0);
48 var result2 = this.get_output_cell(1);
50 var result2 = this.get_output_cell(1);
49 this.test.assertEquals(result.output_type, output_type,
51 this.test.assertEquals(result.output_type, output_type,
50 'testing ' + output_type + ' for ' + keys.join(' and '));
52 'testing ' + output_type + ' for ' + keys.join(' and '));
51
53
52 for (var idx in keys) {
54 for (var idx in keys) {
53 assert_has.apply(this, [keys[idx], json, result, result2]);
55 assert_has.apply(this, [keys[idx], json, result, result2]);
54 }
56 }
55 }
57 }
56
58
57
59
58 // helper function to clear the first two cells, set the text of and execute
60 // helper function to clear the first two cells, set the text of and execute
59 // the first one
61 // the first one
60 function clear_and_execute(that, code) {
62 function clear_and_execute(that, code) {
61 that.evaluate(function() {
63 that.evaluate(function() {
62 IPython.notebook.get_cell(0).clear_output();
64 IPython.notebook.get_cell(0).clear_output();
63 IPython.notebook.get_cell(1).clear_output();
65 IPython.notebook.get_cell(1).clear_output();
64 });
66 });
65 that.set_cell_text(0, code);
67 that.set_cell_text(0, code);
66 that.execute_cell(0);
68 that.execute_cell(0);
67 }
69 }
68
70
69 casper.notebook_test(function () {
71 casper.notebook_test(function () {
70 this.evaluate(function () {
72 this.evaluate(function () {
71 var cell = IPython.notebook.get_cell(0);
73 var cell = IPython.notebook.get_cell(0);
72 // "we have to make messes to find out who we are"
74 // "we have to make messes to find out who we are"
73 cell.set_text([
75 cell.set_text([
74 "%%javascript",
76 "%%javascript",
75 "IPython.notebook.insert_cell_below('code')"
77 "IPython.notebook.insert_cell_below('code')"
76 ].join('\n')
78 ].join('\n')
77 );
79 );
78
80
79 cell.execute();
81 cell.execute();
80 });
82 });
81
83
82 this.wait_for_output(0);
84 this.wait_for_output(0);
83
85
84 this.then(function ( ) {
86 this.then(function ( ) {
85 var result = this.get_output_cell(0);
87 var result = this.get_output_cell(0);
86 var num_cells = this.get_cells_length();
88 var num_cells = this.get_cells_length();
87 this.test.assertEquals(num_cells, 2, '%%javascript magic works');
89 this.test.assertEquals(num_cells, 2, '%%javascript magic works');
88 this.test.assertTrue(result.hasOwnProperty('application/javascript'),
90 this.test.assertTrue(result.hasOwnProperty('application/javascript'),
89 'testing JS embeded with mime key');
91 'testing JS embeded with mime key');
90 });
92 });
91
93
92 //this.thenEvaluate(function() { IPython.notebook.save_notebook(); });
94 //this.thenEvaluate(function() { IPython.notebook.save_notebook(); });
93
95
94 this.then(function ( ) {
96 this.then(function ( ) {
95 check_output_area.apply(this, ['display_data', ['javascript']]);
97 check_output_area.apply(this, ['display_data', ['javascript']]);
96
98
97 });
99 });
98
100
99 this.then(function() {
101 this.then(function() {
100 clear_and_execute(this, '%lsmagic');
102 clear_and_execute(this, '%lsmagic');
101 });
103 });
102
104
103 this.then(function () {
105 this.then(function () {
104 check_output_area.apply(this, ['pyout', ['text', 'json']]);
106 check_output_area.apply(this, ['pyout', ['text', 'json']]);
105 });
107 });
106
108
107 this.then(function() {
109 this.then(function() {
108 clear_and_execute(this,
110 clear_and_execute(this,
109 "x = %lsmagic\nfrom IPython.display import display; display(x)");
111 "x = %lsmagic\nfrom IPython.display import display; display(x)");
110 });
112 });
111
113
112 this.then(function ( ) {
114 this.then(function ( ) {
113 check_output_area.apply(this, ['display_data', ['text', 'json']]);
115 check_output_area.apply(this, ['display_data', ['text', 'json']]);
114 });
116 });
115
117
116 this.then(function() {
118 this.then(function() {
117 clear_and_execute(this,
119 clear_and_execute(this,
118 "from IPython.display import Latex; Latex('$X^2$')");
120 "from IPython.display import Latex; Latex('$X^2$')");
119 });
121 });
120
122
121 this.then(function ( ) {
123 this.then(function ( ) {
122 check_output_area.apply(this, ['pyout', ['text', 'latex']]);
124 check_output_area.apply(this, ['pyout', ['text', 'latex']]);
123 });
125 });
124
126
125 this.then(function() {
127 this.then(function() {
126 clear_and_execute(this,
128 clear_and_execute(this,
127 "from IPython.display import Latex, display; display(Latex('$X^2$'))");
129 "from IPython.display import Latex, display; display(Latex('$X^2$'))");
128 });
130 });
129
131
130 this.then(function ( ) {
132 this.then(function ( ) {
131 check_output_area.apply(this, ['display_data', ['text', 'latex']]);
133 check_output_area.apply(this, ['display_data', ['text', 'latex']]);
132 });
134 });
133
135
134 this.then(function() {
136 this.then(function() {
135 clear_and_execute(this,
137 clear_and_execute(this,
136 "from IPython.display import HTML; HTML('<b>it works!</b>')");
138 "from IPython.display import HTML; HTML('<b>it works!</b>')");
137 });
139 });
138
140
139 this.then(function ( ) {
141 this.then(function ( ) {
140 check_output_area.apply(this, ['pyout', ['text', 'html']]);
142 check_output_area.apply(this, ['pyout', ['text', 'html']]);
141 });
143 });
142
144
143 this.then(function() {
145 this.then(function() {
144 clear_and_execute(this,
146 clear_and_execute(this,
145 "from IPython.display import HTML, display; display(HTML('<b>it works!</b>'))");
147 "from IPython.display import HTML, display; display(HTML('<b>it works!</b>'))");
146 });
148 });
147
149
148 this.then(function ( ) {
150 this.then(function ( ) {
149 check_output_area.apply(this, ['display_data', ['text', 'html']]);
151 check_output_area.apply(this, ['display_data', ['text', 'html']]);
150 });
152 });
151
153
152
154
153 this.then(function() {
155 this.then(function() {
154 clear_and_execute(this,
156 clear_and_execute(this,
155 "from IPython.display import Image; Image(" + black_dot_png + ")");
157 "from IPython.display import Image; Image(" + black_dot_png + ")");
156 });
158 });
157 this.thenEvaluate(function() { IPython.notebook.save_notebook(); });
159 this.thenEvaluate(function() { IPython.notebook.save_notebook(); });
158
160
159 this.then(function ( ) {
161 this.then(function ( ) {
160 check_output_area.apply(this, ['pyout', ['text', 'png']]);
162 check_output_area.apply(this, ['pyout', ['text', 'png']]);
161 });
163 });
162
164
163 this.then(function() {
165 this.then(function() {
164 clear_and_execute(this,
166 clear_and_execute(this,
165 "from IPython.display import Image, display; display(Image(" + black_dot_png + "))");
167 "from IPython.display import Image, display; display(Image(" + black_dot_png + "))");
166 });
168 });
167
169
168 this.then(function ( ) {
170 this.then(function ( ) {
169 check_output_area.apply(this, ['display_data', ['text', 'png']]);
171 check_output_area.apply(this, ['display_data', ['text', 'png']]);
170 });
172 });
171
173
172
174
173 this.then(function() {
175 this.then(function() {
174 clear_and_execute(this,
176 clear_and_execute(this,
175 "from IPython.display import Image; Image(" + black_dot_jpeg + ", format='jpeg')");
177 "from IPython.display import Image; Image(" + black_dot_jpeg + ", format='jpeg')");
176 });
178 });
177
179
178 this.then(function ( ) {
180 this.then(function ( ) {
179 check_output_area.apply(this, ['pyout', ['text', 'jpeg']]);
181 check_output_area.apply(this, ['pyout', ['text', 'jpeg']]);
180 });
182 });
181
183
182 this.then(function() {
184 this.then(function() {
183 clear_and_execute(this,
185 clear_and_execute(this,
184 "from IPython.display import Image, display; display(Image(" + black_dot_jpeg + ", format='jpeg'))");
186 "from IPython.display import Image, display; display(Image(" + black_dot_jpeg + ", format='jpeg'))");
185 });
187 });
186
188
187 this.then(function ( ) {
189 this.then(function ( ) {
188 check_output_area.apply(this, ['display_data', ['text', 'jpeg']]);
190 check_output_area.apply(this, ['display_data', ['text', 'jpeg']]);
189 });
191 });
190
192
191 this.then(function() {
193 this.then(function() {
192 clear_and_execute(this,
194 clear_and_execute(this,
193 "from IPython.core.display import SVG; SVG(" + svg + ")");
195 "from IPython.core.display import SVG; SVG(" + svg + ")");
194 });
196 });
195
197
196 this.then(function ( ) {
198 this.then(function ( ) {
197 check_output_area.apply(this, ['pyout', ['text', 'svg']]);
199 check_output_area.apply(this, ['pyout', ['text', 'svg']]);
198 });
200 });
199
201
200 this.then(function() {
202 this.then(function() {
201 clear_and_execute(this,
203 clear_and_execute(this,
202 "from IPython.core.display import SVG, display; display(SVG(" + svg + "))");
204 "from IPython.core.display import SVG, display; display(SVG(" + svg + "))");
203 });
205 });
204
206
205 this.then(function ( ) {
207 this.then(function ( ) {
206 check_output_area.apply(this, ['display_data', ['text', 'svg']]);
208 check_output_area.apply(this, ['display_data', ['text', 'svg']]);
207 });
209 });
208
210
209 this.thenEvaluate(function() { IPython.notebook.save_notebook(); });
211 this.thenEvaluate(function() { IPython.notebook.save_notebook(); });
210
212
211 this.then(function() {
213 this.then(function() {
212 clear_and_execute(this, [
214 clear_and_execute(this, [
213 "from IPython.core.formatters import HTMLFormatter",
215 "from IPython.core.formatters import HTMLFormatter",
214 "x = HTMLFormatter()",
216 "x = HTMLFormatter()",
215 "x.format_type = 'text/superfancymimetype'",
217 "x.format_type = 'text/superfancymimetype'",
216 "get_ipython().display_formatter.formatters['text/superfancymimetype'] = x",
218 "get_ipython().display_formatter.formatters['text/superfancymimetype'] = x",
217 "from IPython.display import HTML, display",
219 "from IPython.display import HTML, display",
218 'display(HTML("yo"))',
220 'display(HTML("yo"))',
219 "HTML('hello')"].join('\n')
221 "HTML('hello')"].join('\n')
220 );
222 );
221
223
222 });
224 });
223
225
224 this.then(function ( ) {
226 this.then(function ( ) {
225 var long_name = 'text/superfancymimetype';
227 var long_name = 'text/superfancymimetype';
226 var result = this.get_output_cell(0);
228 var result = this.get_output_cell(0);
227 this.test.assertTrue(result.hasOwnProperty(long_name),
229 this.test.assertTrue(result.hasOwnProperty(long_name),
228 'display_data custom mimetype ' + long_name);
230 'display_data custom mimetype ' + long_name);
229 var result = this.get_output_cell(0, 1);
231 var result = this.get_output_cell(0, 1);
230 this.test.assertTrue(result.hasOwnProperty(long_name),
232 this.test.assertTrue(result.hasOwnProperty(long_name),
231 'pyout custom mimetype ' + long_name);
233 'pyout custom mimetype ' + long_name);
232
234
233 });
235 });
234
236
235 });
237 });
General Comments 0
You need to be logged in to leave comments. Login now