diff options
author | Mike Bayer <mike_mp@zzzcomputing.com> | 2010-04-10 19:45:34 -0400 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2010-04-10 19:45:34 -0400 |
commit | cf9cac34ac8df5613ef2d24884030df8aa749580 (patch) | |
tree | c96e90ee2283b64b4fa84c12729316c28caeb41c /lib/sqlalchemy/test | |
parent | 44c67fef8cc578ffbca409ad95e6471b4cb4d02a (diff) | |
parent | 36c05de373f9cbb198573704f2bc28fea8ca9113 (diff) | |
download | sqlalchemy-cf9cac34ac8df5613ef2d24884030df8aa749580.tar.gz |
merge default
Diffstat (limited to 'lib/sqlalchemy/test')
-rw-r--r-- | lib/sqlalchemy/test/testing.py | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/lib/sqlalchemy/test/testing.py b/lib/sqlalchemy/test/testing.py index 771b8c90f..70ddc7ba2 100644 --- a/lib/sqlalchemy/test/testing.py +++ b/lib/sqlalchemy/test/testing.py @@ -546,6 +546,23 @@ def fixture(table, columns, *rows): for column_values in rows]) table.append_ddl_listener('after-create', onload) +def provide_metadata(fn): + """Provides a bound MetaData object for a single test, + drops it afterwards.""" + def maybe(*args, **kw): + metadata = schema.MetaData(db) + context = dict(fn.func_globals) + context['metadata'] = metadata + # jython bug #1034 + rebound = types.FunctionType( + fn.func_code, context, fn.func_name, fn.func_defaults, + fn.func_closure) + try: + return rebound(*args, **kw) + finally: + metadata.drop_all() + return function_named(maybe, fn.__name__) + def resolve_artifact_names(fn): """Decorator, augment function globals with tables and classes. |