本文整理匯總了Python中sqlalchemy.exc.ResourceClosedError方法的典型用法代碼示例。如果您正苦於以下問題:Python exc.ResourceClosedError方法的具體用法?Python exc.ResourceClosedError怎麽用?Python exc.ResourceClosedError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類sqlalchemy.exc
的用法示例。
在下文中一共展示了exc.ResourceClosedError方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_used_with_begin_nested
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def test_used_with_begin_nested(self, session, assert_session):
@transaction(session)
def create_user(commit_inner):
with session.begin_nested():
user = User(username='test1', email='1@b.com', password='1')
session.add(user)
with session.begin_nested():
user = User(username='test2', email='2@b.com', password='1')
session.add(user)
if commit_inner:
session.commit()
create_user(commit_inner=False)
assert len(assert_session.query(User).all()) == 2
self.clear_user()
msg = 'This transaction is closed'
with pytest.raises(ResourceClosedError, match=msg):
create_user(commit_inner=True)
assert len(assert_session.query(User).all()) == 0
示例2: test_nested_self_raise
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def test_nested_self_raise(self, session, assert_session):
@transaction(session)
def create_user():
user = User(username='test1', email='1@b.com', password='1')
db.session.add(user)
@transaction(session)
def view_func():
user = User(username='test2', email='2@b.com', password='1')
db.session.add(user)
create_user()
if session.autocommit is False:
msg = 'This transaction is closed'
with pytest.raises(ResourceClosedError, match=msg):
view_func()
else:
msg = r'A transaction is already begun.*'
with pytest.raises(InvalidRequestError, match=msg):
view_func()
assert len(assert_session.query(User).all()) == 0
示例3: test_connectionless_autoclose_no_metadata
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def test_connectionless_autoclose_no_metadata(self):
# TODO: deprecate for 2.0
result = testing.db.execute(text("update users set user_id=5"))
connection = result.connection
assert connection.closed
assert_raises_message(
exc.ResourceClosedError,
"This result object does not return rows.",
result.fetchone,
)
assert_raises_message(
exc.ResourceClosedError,
"This result object does not return rows.",
result.keys,
)
示例4: update_repo_directory
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def update_repo_directory(ctx, repo_directory):
"""
Update Facade worker repo cloning directory
"""
app = ctx.obj
db = get_db_connection(app)
updateRepoDirectorySQL = s.sql.text("""
UPDATE augur_data.settings SET VALUE = :repo_directory WHERE setting='repo_directory';
""")
try:
pd.read_sql(updateRepoDirectorySQL, db, params={'repo_directory': repo_directory})
except exc.ResourceClosedError as error:
print(f"Successfully updated the Facade worker repo directory.")
# pd.read_sql() will throw an AttributeError when it can't sucessfully "fetch" any rows from the result.
# Since there's no rows to fetch after a successful insert, this is how we know it worked.
# I know it's weird, sue me (jk please don't)
# get_db_version is a helper function to print_db_version and upgrade_db_version
示例5: test_used_with_commit_raised
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def test_used_with_commit_raised(self, session, assert_session):
@transaction(session)
def create_user():
user = User(username='test1', email='1@b.com', password='1')
session.add(user)
session.commit()
msg = 'This transaction is closed'
with pytest.raises(ResourceClosedError, match=msg):
create_user()
assert assert_session.query(User).all() == []
示例6: test_nested_self_with_nested_arg_is_true_commit_raise
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def test_nested_self_with_nested_arg_is_true_commit_raise(
self, session, assert_session):
@transaction(session, nested=True)
def create_user():
user = User(username='test1', email='1@b.com', password='1')
session.add(user)
session.commit()
@transaction(session)
def view_func():
create_user()
msg = r'This transaction is closed'
with pytest.raises(ResourceClosedError, match=msg):
view_func()
示例7: test_notautocommit_use_nested_alone_commit_raise
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def test_notautocommit_use_nested_alone_commit_raise(self, db_session):
@transaction(db_session, nested=True)
def create_user():
user = User(username='test1', email='1@b.com', password='1')
db_session.add(user)
db_session.commit()
msg = 'This transaction is closed'
with pytest.raises(ResourceClosedError, match=msg):
create_user()
示例8: get_version
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def get_version(sql):
table_info = "PRAGMA table_info('migrations')"
from sqlalchemy.exc import ResourceClosedError
try:
if not sql.execute(table_info).fetchall():
return 0
except ResourceClosedError as e:
if 'does not return rows' in str(e):
return 0
version_query = "SELECT version from migrations"
version = sql.execute(version_query).fetchone()
return version and version[0] or 0
示例9: get_connection
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def get_connection(self):
"""Get a connection to this Database. Connections are retrieved from a
pool.
"""
if not self.open:
raise exc.ResourceClosedError('Database closed.')
return Connection(self._engine.connect())
示例10: do_exec
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def do_exec(args):
msg, sql = args
with log_duration(msg):
with engine.begin() as trans:
res = trans.execute(sql)
try:
logger.info(f"SQL result", job=msg, result=res.fetchall())
except ResourceClosedError:
pass # Nothing to do here
except Exception as exc:
logger.error("Hit an issue.", exc=exc)
raise exc
示例11: do_exec
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def do_exec(args):
msg, sql = args
with log_duration(msg):
started = datetime.datetime.now()
with engine.begin() as trans:
res = trans.execute(sql)
try:
logger.info(f"Ran", job=msg, result=res.fetchall())
except ResourceClosedError:
pass # Nothing to do here
示例12: validate
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def validate(self, max_retries=0):
"""Performs basic **connection** validation of a sqlalchemy engine."""
def _retry_on_exception(exc):
LOG.warning("Engine connection (validate) failed due to '%s'", exc)
if isinstance(exc, sa_exc.OperationalError) and \
_is_db_connection_error(six.text_type(exc.args[0])):
# We may be able to fix this by retrying...
return True
if isinstance(exc, (sa_exc.TimeoutError,
sa_exc.ResourceClosedError,
sa_exc.DisconnectionError)):
# We may be able to fix this by retrying...
return True
# Other failures we likely can't fix by retrying...
return False
@tenacity.retry(
stop=tenacity.stop_after_attempt(max(0, int(max_retries))),
wait=tenacity.wait_exponential(),
reraise=True,
retry=tenacity.retry_if_exception(_retry_on_exception)
)
def _try_connect(engine):
# See if we can make a connection happen.
#
# NOTE(harlowja): note that even though we are connecting
# once it does not mean that we will be able to connect in
# the future, so this is more of a sanity test and is not
# complete connection insurance.
with contextlib.closing(engine.connect()):
pass
_try_connect(self._engine)
示例13: test_graceful_fetch_on_non_rows
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def test_graceful_fetch_on_non_rows(self):
"""test that calling fetchone() etc. on a result that doesn't
return rows fails gracefully.
"""
# these proxies don't work with no cursor.description present.
# so they don't apply to this test at the moment.
# result.FullyBufferedCursorResult,
# result.BufferedRowCursorResult,
# result.BufferedColumnCursorResult
users = self.tables.users
conn = testing.db.connect()
for meth in [
lambda r: r.fetchone(),
lambda r: r.fetchall(),
lambda r: r.first(),
lambda r: r.scalar(),
lambda r: r.fetchmany(),
lambda r: r._getter("user"),
lambda r: r.keys(),
lambda r: r.columns("user"),
lambda r: r.cursor_strategy.fetchone(r, r.cursor),
]:
trans = conn.begin()
result = conn.execute(users.insert(), user_id=1)
assert_raises_message(
exc.ResourceClosedError,
"This result object does not return rows. "
"It has been closed automatically.",
meth,
result,
)
trans.rollback()
示例14: test_fetchone_til_end
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def test_fetchone_til_end(self, connection):
result = connection.exec_driver_sql("select * from users")
eq_(result.fetchone(), None)
eq_(result.fetchone(), None)
eq_(result.fetchone(), None)
result.close()
assert_raises_message(
exc.ResourceClosedError,
"This result object is closed.",
result.fetchone,
)
示例15: _assert_result_closed
# 需要導入模塊: from sqlalchemy import exc [as 別名]
# 或者: from sqlalchemy.exc import ResourceClosedError [as 別名]
def _assert_result_closed(self, r):
assert_raises_message(
sa_exc.ResourceClosedError, "object is closed", r.fetchone
)
assert_raises_message(
sa_exc.ResourceClosedError, "object is closed", r.fetchmany, 2
)
assert_raises_message(
sa_exc.ResourceClosedError, "object is closed", r.fetchall
)