pool.py

来自「SQLAlchemy. 经典的Python ORM框架。学习必看。」· Python 代码 · 共 43 行

PY
43
字号
import testenv; testenv.configure_for_tests()from sqlalchemy import *from testlib import *from sqlalchemy.pool import QueuePoolfrom sqlalchemy.databases import sqliteclass QueuePoolTest(TestBase, AssertsExecutionResults):    def setUp(self):        global pool        pool = QueuePool(creator = lambda: sqlite.SQLiteDialect.dbapi().connect(':memory:'), pool_size = 3, max_overflow = -1, use_threadlocal = True)    # the WeakValueDictionary used for the pool's "threadlocal" idea adds 1-6    # method calls to each of these.  however its just a lot easier stability    # wise than dealing with a strongly referencing dict of weakrefs.    # [ticket:754] immediately got opened when we tried a dict of weakrefs,    # and though the solution there is simple, it still doesn't solve the    # issue of "dead" weakrefs sitting in the dict taking up space    @profiling.profiled('pooltest_connect', call_range=(40, 50), always=True)    def test_first_connect(self):        conn = pool.connect()    def test_second_connect(self):        conn = pool.connect()        conn.close()        @profiling.profiled('pooltest_second_connect', call_range=(24, 24), always=True)        def go():            conn2 = pool.connect()            return conn2        c2 = go()    def test_second_samethread_connect(self):        conn = pool.connect()        @profiling.profiled('pooltest_samethread_connect', call_range=(4, 4), always=True)        def go():            return pool.connect()        c2 = go()if __name__ == '__main__':    testenv.main()

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?