diff --git a/IPython/html/services/notebooks/tests/test_notebooks_api.py b/IPython/html/services/notebooks/tests/test_notebooks_api.py index 65b7f1252..7e2559ede 100644 --- a/IPython/html/services/notebooks/tests/test_notebooks_api.py +++ b/IPython/html/services/notebooks/tests/test_notebooks_api.py @@ -23,10 +23,6 @@ class NBAPI(object): def __init__(self, base_url): self.base_url = base_url - @property - def nb_url(self): - return url_path_join(self.base_url, 'api/notebooks') - def _req(self, verb, path, body=None): response = requests.request(verb, url_path_join(self.base_url, 'api/notebooks', path), data=body) @@ -58,6 +54,18 @@ class NBAPI(object): body = jsonapi.dumps({'name': new_name}) return self._req('PATCH', url_path_join(path, name), body) + def get_checkpoints(self, name, path): + return self._req('GET', url_path_join(path, name, 'checkpoints')) + + def new_checkpoint(self, name, path): + return self._req('POST', url_path_join(path, name, 'checkpoints')) + + def restore_checkpoint(self, name, path, checkpoint_id): + return self._req('POST', url_path_join(path, name, 'checkpoints', checkpoint_id)) + + def delete_checkpoint(self, name, path, checkpoint_id): + return self._req('DELETE', url_path_join(path, name, 'checkpoints', checkpoint_id)) + class APITest(NotebookTestBase): """Test the kernels web service API""" dirs_nbs = [('', 'inroot'), @@ -210,4 +218,44 @@ class APITest(NotebookTestBase): assert os.path.isfile(pjoin(self.notebook_dir.name,'foo','bar','a2.ipynb')) assert not os.path.isfile(pjoin(self.notebook_dir.name, 'foo', 'a.ipynb')) with assert_http_error(404): - self.nb_api.read('a.ipynb', 'foo') \ No newline at end of file + self.nb_api.read('a.ipynb', 'foo') + + def test_checkpoints(self): + resp = self.nb_api.read('a.ipynb', 'foo') + r = self.nb_api.new_checkpoint('a.ipynb', 'foo') + self.assertEqual(r.status_code, 201) + cp1 = r.json() + self.assertEqual(set(cp1), {'checkpoint_id', 'last_modified'}) + self.assertEqual(r.headers['Location'].split('/')[-1], cp1['checkpoint_id']) + + # Modify it + nbcontent = jsonapi.loads(resp.text)['content'] + nb = to_notebook_json(nbcontent) + ws = new_worksheet() + nb.worksheets = [ws] + hcell = new_heading_cell('Created by test') + ws.cells.append(hcell) + # Save + nbmodel= {'name': 'a.ipynb', 'path':'foo', 'content': nb} + resp = self.nb_api.save('a.ipynb', path='foo', body=jsonapi.dumps(nbmodel)) + + # List checkpoints + cps = self.nb_api.get_checkpoints('a.ipynb', 'foo').json() + self.assertEqual(cps, [cp1]) + + nbcontent = self.nb_api.read('a.ipynb', 'foo').json()['content'] + nb = to_notebook_json(nbcontent) + self.assertEqual(nb.worksheets[0].cells[0].source, 'Created by test') + + # Restore cp1 + r = self.nb_api.restore_checkpoint('a.ipynb', 'foo', cp1['checkpoint_id']) + self.assertEqual(r.status_code, 204) + nbcontent = self.nb_api.read('a.ipynb', 'foo').json()['content'] + nb = to_notebook_json(nbcontent) + self.assertEqual(nb.worksheets, []) + + # Delete cp1 + r = self.nb_api.delete_checkpoint('a.ipynb', 'foo', cp1['checkpoint_id']) + self.assertEqual(r.status_code, 204) + cps = self.nb_api.get_checkpoints('a.ipynb', 'foo').json() + self.assertEqual(cps, [])