⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pool.py

📁 SQLAlchemy. 经典的Python ORM框架。学习必看。
💻 PY
字号:
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 + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -