##// END OF EJS Templates
fix handling of no-checkpoint-defined...
fix handling of no-checkpoint-defined a few typos and missing handling of undefined checkpoint regression introduced in #6205

File last commit:

r17222:c1223d48
r17715:f807e847
Show More
test_sessionmanager.py
105 lines | 5.1 KiB | text/x-python | PythonLexer
Zachary Sailer
session manager restructuring...
r13035 """Tests for the session manager."""
from unittest import TestCase
Thomas Kluyver
Fix sessionmanager test
r13097 from tornado import web
Zachary Sailer
session manager restructuring...
r13035 from ..sessionmanager import SessionManager
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 from IPython.html.services.kernels.kernelmanager import MappingKernelManager
class DummyKernel(object):
def __init__(self, kernel_name='python'):
self.kernel_name = kernel_name
class DummyMKM(MappingKernelManager):
"""MappingKernelManager interface that doesn't start kernels, for testing"""
def __init__(self, *args, **kwargs):
super(DummyMKM, self).__init__(*args, **kwargs)
self.id_letters = iter(u'ABCDEFGHIJK')
def _new_id(self):
return next(self.id_letters)
def start_kernel(self, kernel_id=None, path=None, kernel_name='python', **kwargs):
kernel_id = kernel_id or self._new_id()
self._kernels[kernel_id] = DummyKernel(kernel_name=kernel_name)
return kernel_id
def shutdown_kernel(self, kernel_id, now=False):
del self._kernels[kernel_id]
Zachary Sailer
session manager restructuring...
r13035
class TestSessionManager(TestCase):
def test_get_session(self):
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 sm = SessionManager(kernel_manager=DummyMKM())
session_id = sm.create_session(name='test.ipynb', path='/path/to/',
kernel_name='bar')['id']
MinRK
review pass on Sessions API
r13101 model = sm.get_session(session_id=session_id)
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 expected = {'id':session_id,
'notebook':{'name':u'test.ipynb', 'path': u'/path/to/'},
'kernel': {'id':u'A', 'name': 'bar'}}
Zachary Sailer
session manager restructuring...
r13035 self.assertEqual(model, expected)
def test_bad_get_session(self):
# Should raise error if a bad key is passed to the database.
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 sm = SessionManager(kernel_manager=DummyMKM())
session_id = sm.create_session(name='test.ipynb', path='/path/to/',
kernel_name='foo')['id']
MinRK
review pass on Sessions API
r13101 self.assertRaises(TypeError, sm.get_session, bad_id=session_id) # Bad keyword
Zachary Sailer
session manager restructuring...
r13035
def test_list_sessions(self):
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 sm = SessionManager(kernel_manager=DummyMKM())
sessions = [
sm.create_session(name='test1.ipynb', path='/path/to/1/', kernel_name='python'),
sm.create_session(name='test2.ipynb', path='/path/to/2/', kernel_name='python'),
sm.create_session(name='test3.ipynb', path='/path/to/3/', kernel_name='python'),
]
Zachary Sailer
session manager restructuring...
r13035 sessions = sm.list_sessions()
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 expected = [{'id':sessions[0]['id'], 'notebook':{'name':u'test1.ipynb',
'path': u'/path/to/1/'}, 'kernel':{'id':u'A', 'name':'python'}},
{'id':sessions[1]['id'], 'notebook': {'name':u'test2.ipynb',
'path': u'/path/to/2/'}, 'kernel':{'id':u'B', 'name':'python'}},
{'id':sessions[2]['id'], 'notebook':{'name':u'test3.ipynb',
'path': u'/path/to/3/'}, 'kernel':{'id':u'C', 'name':'python'}}]
Zachary Sailer
session manager restructuring...
r13035 self.assertEqual(sessions, expected)
def test_update_session(self):
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 sm = SessionManager(kernel_manager=DummyMKM())
session_id = sm.create_session(name='test.ipynb', path='/path/to/',
kernel_name='julia')['id']
Zachary Sailer
session manager restructuring...
r13035 sm.update_session(session_id, name='new_name.ipynb')
MinRK
review pass on Sessions API
r13101 model = sm.get_session(session_id=session_id)
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 expected = {'id':session_id,
'notebook':{'name':u'new_name.ipynb', 'path': u'/path/to/'},
'kernel':{'id':u'A', 'name':'julia'}}
Zachary Sailer
session manager restructuring...
r13035 self.assertEqual(model, expected)
def test_bad_update_session(self):
# try to update a session with a bad keyword ~ raise error
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 sm = SessionManager(kernel_manager=DummyMKM())
session_id = sm.create_session(name='test.ipynb', path='/path/to/',
kernel_name='ir')['id']
MinRK
review pass on Sessions API
r13101 self.assertRaises(TypeError, sm.update_session, session_id=session_id, bad_kw='test.ipynb') # Bad keyword
Zachary Sailer
session manager restructuring...
r13035
def test_delete_session(self):
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 sm = SessionManager(kernel_manager=DummyMKM())
sessions = [
sm.create_session(name='test1.ipynb', path='/path/to/1/', kernel_name='python'),
sm.create_session(name='test2.ipynb', path='/path/to/2/', kernel_name='python'),
sm.create_session(name='test3.ipynb', path='/path/to/3/', kernel_name='python'),
]
sm.delete_session(sessions[1]['id'])
new_sessions = sm.list_sessions()
expected = [{'id':sessions[0]['id'], 'notebook':{'name':u'test1.ipynb',
'path': u'/path/to/1/'}, 'kernel':{'id':u'A', 'name':'python'}},
{'id':sessions[2]['id'], 'notebook':{'name':u'test3.ipynb',
'path': u'/path/to/3/'}, 'kernel':{'id':u'C', 'name':'python'}}]
self.assertEqual(new_sessions, expected)
Zachary Sailer
session manager restructuring...
r13035
def test_bad_delete_session(self):
# try to delete a session that doesn't exist ~ raise error
Thomas Kluyver
Add kernel name to sessions REST API...
r17222 sm = SessionManager(kernel_manager=DummyMKM())
sm.create_session(name='test.ipynb', path='/path/to/', kernel_name='python')
MinRK
review pass on Sessions API
r13101 self.assertRaises(TypeError, sm.delete_session, bad_kwarg='23424') # Bad keyword
self.assertRaises(web.HTTPError, sm.delete_session, session_id='23424') # nonexistant
Zachary Sailer
session manager restructuring...
r13035