diff --git a/IPython/html/static/services/sessions/js/session.js b/IPython/html/static/services/sessions/js/session.js
index fbca98f87..dc41e875b 100644
--- a/IPython/html/static/services/sessions/js/session.js
+++ b/IPython/html/static/services/sessions/js/session.js
@@ -48,6 +48,10 @@ define([
* POST /api/sessions
*/
Session.prototype.start = function (success, error) {
+ if (this.kernel !== null) {
+ throw new Error("session has already been started");
+ };
+
var that = this;
var on_success = function (data, status, xhr) {
var kernel_service_url = utils.url_path_join(that.base_url, "api/kernels");
@@ -95,23 +99,31 @@ define([
* PATCH /api/sessions/[:session_id]
*/
Session.prototype.change = function (notebook_name, notebook_path, kernel_name, success, error) {
- this.notebook_model.name = notebook_name;
- this.notebook_model.path = notebook_path;
- this.kernel_model.name = kernel_name;
+ if (notebook_name !== undefined) {
+ this.notebook_model.name = notebook_name;
+ }
+ if (notebook_path !== undefined) {
+ this.notebook_model.path = notebook_path;
+ }
+ if (kernel_name !== undefined) {
+ this.kernel_model.name = kernel_name;
+ }
+
+ console.log(JSON.stringify(this._get_model()));
$.ajax(this.session_url, {
processData: false,
cache: false,
type: "PATCH",
data: JSON.stringify(this._get_model()),
- dataType : "json",
+ dataType: "json",
success: this._on_success(success),
error: this._on_error(error)
});
};
Session.prototype.rename_notebook = function (name, path, success, error) {
- this.change(name, path, this.kernel_model.name, success, error);
+ this.change(name, path, undefined, success, error);
};
/**
diff --git a/IPython/html/tests/services/session.js b/IPython/html/tests/services/session.js
index fa6c0577e..bb235519d 100644
--- a/IPython/html/tests/services/session.js
+++ b/IPython/html/tests/services/session.js
@@ -4,21 +4,107 @@
//
casper.notebook_test(function () {
+ var that = this;
+ var get_info = function () {
+ return that.evaluate(function () {
+ return JSON.parse(JSON.stringify(IPython.notebook.session._get_model()));
+ });
+ };
+
+ // test that the kernel is running
this.then(function () {
this.test.assert(this.kernel_running(), 'session: kernel is running');
});
+ // test list
+ this.thenEvaluate(function () {
+ IPython._sessions = null;
+ IPython.notebook.session.list(function (data) {
+ IPython._sessions = data;
+ });
+ });
+ this.waitFor(function () {
+ return this.evaluate(function () {
+ return IPython._sessions !== null;
+ });
+ });
+ this.then(function () {
+ var num_sessions = this.evaluate(function () {
+ return IPython._sessions.length;
+ });
+ this.test.assertEquals(num_sessions, 1, 'one session running');
+ });
+
+ // test get_info
+ var session_info = get_info();
+ this.thenEvaluate(function () {
+ IPython._session_info = null;
+ IPython.notebook.session.get_info(function (data) {
+ IPython._session_info = data;
+ });
+ });
+ this.waitFor(function () {
+ return this.evaluate(function () {
+ return IPython._session_info !== null;
+ });
+ });
+ this.then(function () {
+ var new_session_info = this.evaluate(function () {
+ return IPython._session_info;
+ });
+ this.test.assertEquals(session_info.notebook.name, new_session_info.notebook.name, 'session: notebook name correct');
+ this.test.assertEquals(session_info.notebook.path, new_session_info.notebook.path, 'session: notebook path correct');
+ this.test.assertEquals(session_info.kernel.name, new_session_info.kernel.name, 'session: kernel name correct');
+ this.test.assertEquals(session_info.kernel.id, new_session_info.kernel.id, 'session: kernel id correct');
+ });
+
+ // test rename_notebook
+ //
+ // TODO: the PATCH request isn't supported by phantom, so this test always
+ // fails, see https://github.com/ariya/phantomjs/issues/11384
+ // when this is fixed we can properly run this test
+ //
+ // this.thenEvaluate(function () {
+ // IPython._renamed = false;
+ // IPython.notebook.session.rename_notebook(
+ // "foo",
+ // "bar",
+ // function (data) {
+ // IPython._renamed = true;
+ // }
+ // );
+ // });
+ // this.waitFor(function () {
+ // return this.evaluate(function () {
+ // return IPython._renamed;
+ // });
+ // });
+ // this.then(function () {
+ // var info = get_info();
+ // this.test.assertEquals(info.notebook.name, "foo", "notebook was renamed");
+ // this.test.assertEquals(info.notebook.path, "bar", "notebook path was changed");
+ // });
+
+ // test delete
this.thenEvaluate(function () {
IPython.notebook.session.delete();
});
-
this.waitFor(function () {
return this.evaluate(function () {
return IPython.notebook.kernel.is_fully_disconnected();
});
});
-
this.then(function () {
this.test.assert(!this.kernel_running(), 'session deletes kernel');
});
+
+ // test start after delete -- should throw an error
+ this.then(function () {
+ var start = function () {
+ this.evaluate(function () {
+ IPython.notebook.session.start();
+ });
+ };
+ this.test.assertRaises(start, [], 'error raised on start after delete');
+ });
});