diff options
| author | Chris McDonough <chrism@agendaless.com> | 2010-01-13 15:14:03 +0000 |
|---|---|---|
| committer | Chris McDonough <chrism@agendaless.com> | 2010-01-13 15:14:03 +0000 |
| commit | 788748e2afedb3d1e180a3033e20ed2d995056a3 (patch) | |
| tree | 2deb7a16b37ce47341649ad82bdf136a37e751f2 /repoze | |
| parent | de449d91fafc0fd4bec6d552dab44845b0948784 (diff) | |
| download | pyramid-788748e2afedb3d1e180a3033e20ed2d995056a3.tar.gz pyramid-788748e2afedb3d1e180a3033e20ed2d995056a3.tar.bz2 pyramid-788748e2afedb3d1e180a3033e20ed2d995056a3.zip | |
- In ``bfg_routesalchemy``, ``bfg_alchemy`` and ``bfgwiki2`` tutorial,
clean up the SQLAlchemy connection by registering a
``repoze.tm.after_end`` callback instead of relying on a ``__del__``
method of a ``Cleanup`` class added to the WSFI environment. The
``__del__`` strategy was fragile and caused problems in the wild.
Thanks to Daniel Holth for testing.
Diffstat (limited to 'repoze')
| -rw-r--r-- | repoze/bfg/paster_templates/alchemy/+package+/run.py_tmpl | 14 | ||||
| -rw-r--r-- | repoze/bfg/paster_templates/routesalchemy/+package+/run.py_tmpl | 14 |
2 files changed, 14 insertions, 14 deletions
diff --git a/repoze/bfg/paster_templates/alchemy/+package+/run.py_tmpl b/repoze/bfg/paster_templates/alchemy/+package+/run.py_tmpl index c290431c0..6ce86371b 100644 --- a/repoze/bfg/paster_templates/alchemy/+package+/run.py_tmpl +++ b/repoze/bfg/paster_templates/alchemy/+package+/run.py_tmpl @@ -1,17 +1,17 @@ +import transaction + from repoze.bfg.configuration import Configurator +from repoze.tm import after_end +from repoze.tm import isActive from {{package}}.models import appmaker from {{package}}.models import DBSession -class Cleanup: - def __init__(self, cleaner): - self.cleaner = cleaner - def __del__(self): - self.cleaner() - def handle_teardown(event): environ = event.request.environ - environ['usermanager.sasession'] = Cleanup(DBSession.remove) + if isActive(environ): + t = transaction.get() + after_end.register(DBSession.remove, t) def app(global_config, **settings): """ This function returns a WSGI application. diff --git a/repoze/bfg/paster_templates/routesalchemy/+package+/run.py_tmpl b/repoze/bfg/paster_templates/routesalchemy/+package+/run.py_tmpl index 810040297..c4d37238a 100644 --- a/repoze/bfg/paster_templates/routesalchemy/+package+/run.py_tmpl +++ b/repoze/bfg/paster_templates/routesalchemy/+package+/run.py_tmpl @@ -1,17 +1,17 @@ +import transaction + from repoze.bfg.configuration import Configurator +from repoze.tm import after_end +from repoze.tm import isActive from {{package}}.models import DBSession from {{package}}.models import initialize_sql -class Cleanup: - def __init__(self, cleaner): - self.cleaner = cleaner - def __del__(self): - self.cleaner() - def handle_teardown(event): environ = event.request.environ - environ['{{package}}.sasession'] = Cleanup(DBSession.remove) + if isActive(environ): + t = transaction.get() + after_end.register(DBSession.remove, t) def app(global_config, **settings): """ This function returns a WSGI application. |
