Skip to content
This repository has been archived by the owner on Jan 3, 2019. It is now read-only.

Commit

Permalink
Creating a restart function for storage classes to fix broken or lost…
Browse files Browse the repository at this point in the history
… database connections
  • Loading branch information
rich-hart committed Feb 11, 2015
1 parent 737a36c commit 50b8f31
Show file tree
Hide file tree
Showing 5 changed files with 53 additions and 2 deletions.
4 changes: 4 additions & 0 deletions cnxauthoring/storage/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,3 +40,7 @@ def search(self, **kwargs):
"""Retrieve any ``Document`` objects from storage that matches the
search terms."""
raise NotImplementedError()

def restart(self):
"""Restart the storage interface """
raise NotImplementedError()
5 changes: 4 additions & 1 deletion cnxauthoring/storage/memory.py
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,10 @@ def persist(self):
def abort(self):
"""Persist/commit the changes."""
pass


def restart(self):
"""Restart the interface"""
pass

def search(self, limits, type_=Document, submitter_id=None):
"""Retrieve any ``Document`` objects from storage that matches the
Expand Down
4 changes: 4 additions & 0 deletions cnxauthoring/storage/postgresql.py
Original file line number Diff line number Diff line change
Expand Up @@ -366,3 +366,7 @@ def search(self, limits, type_=Document, submitter_id=None):
for item in res:
yield self._reassemble_model_from_document_entry(**item)
raise StopIteration

def restart(self):
"""Restart the interface"""
self.conn = psycopg2.connect(self.conn.dsn)
35 changes: 35 additions & 0 deletions cnxauthoring/tests/test_functional.py
Original file line number Diff line number Diff line change
Expand Up @@ -2799,6 +2799,33 @@ def test_user_contents_hide_documents_inside_binders(self):
},
})

def test_db_restart(self):
'''
Test to see if the database resets itself after a broken
connection
'''
import psycopg2
from ..storage import storage

self.addCleanup(setattr, storage, 'conn',
psycopg2.connect(storage.conn.dsn))

storage.conn.close()

response = self.testapp.post_json(
'/users/contents',
{'title': u'My document タイトル'},
status=503,
expect_errors=True)
self.assertEqual(response.status, '503 Service Unavailable')

response = self.testapp.post_json(
'/users/contents',
{'title': u'My document タイトル'},
status=201,
expect_errors=True)
self.assertEqual(response.status, '201 Created')

def test_service_unavailable_response(self):
'''
Test service unavailable response when a request is made during a
Expand All @@ -2819,25 +2846,33 @@ def test_service_unavailable_response(self):
expect_errors=True)
self.assertEqual(response.status, '503 Service Unavailable')

storage.conn.close()

response = self.testapp.get(
'/resources/1234abcde',
status=503,
expect_errors=True)
self.assertEqual(response.status, '503 Service Unavailable')

storage.conn.close()

response = self.testapp.put_json(
'/contents/[email protected]',
{},
status=503,
expect_errors=True)
self.assertEqual(response.status, '503 Service Unavailable')

storage.conn.close()

response = self.testapp.get(
'/search',
status=503,
expect_errors=True)
self.assertEqual(response.status, '503 Service Unavailable')

storage.conn.close()

response = self.testapp.delete(
'/contents/{}@draft'.format(id),
status=503,
Expand Down
7 changes: 6 additions & 1 deletion cnxauthoring/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,12 @@ def wrapper(*args, **kwargs):
storage.abort()
except storage.Error:
logger.exception('Storage failed to abort')
raise httpexceptions.HTTPServiceUnavailable()
try:
storage.restart()
except storage.Error:
logger.exception('Storage failed to restart')
finally:
raise httpexceptions.HTTPServiceUnavailable()
return wrapper


Expand Down

0 comments on commit 50b8f31

Please sign in to comment.