- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
对依赖于 pyodbc 进行的 SQL 查询的函数进行正确单元测试的 pythonic 方法是什么?据我了解,最好的方法是模拟从 SQL Server 返回输出的函数。问题是模拟应该返回什么?
我的设置:在 lib1 中:
def selectSQL(connection, query):
cursor = connection.cursor()
cursor.execute(query)
return cursor.fetchall()
在 lib2 中:
def function_to_be_tested(cxnx):
my_query = "SELECT r1, r2 FROM t1"
rows = lib1.selectSQL(cxnx, my_query)
# do someting with the rows like:
a = 0
for row in rows
a += row.r1 * row.r2
return a
我提出了以下解决方案:
,
out_tuple = namedtuple('out1', ["r1", "r2"])
printed_data = [(1,2),(2,3)]
out = [out_tuple(*row) for row in printed_data]
def test_mockSelectSQL(self):
piotrSQL.selectSQL = MagicMock()
piotrSQL.selectSQL.side_effect = [out]
self.assertEqual(lib2.function_to_be_tested(True), 7)
我唯一担心的是模拟返回 namedtuple 而不是像原始函数那样的 pyodbc.Row。我检查了以下站点以搜索有关如何正确创建 pyodbc.Row 的信息:
在 pyodbc 的单元测试中,没有 if 的构造函数——我也没有在源代码中找到它(但我是新手,所以我可能忽略了它)……但是我在 Row 文档中找到了以下信息:
However, there are some pyodbc additions that make them very convenient:
Values can be accessed by column name.
The Cursor.description values can be accessed even after the cursor is closed.
Values can be replaced.
Rows from the same select statement share memory.
所以看起来 namedtuple 实际上的行为方式与 pyodbc.Row 相同(在访问值时)。在 pyodbc.Row 上进行单元测试是否有更 pythonic 的方法?可以假设这是一个很好的 Mock 吗?
最佳答案
根据@Nullman 在对该问题的评论中提出的建议,如果您想使用内存数据库,您可以尝试使用 SQLite ODBC 驱动程序,这样您就可以返回实际的 pyodbc.Row
像这样的对象:
import pyodbc
conn_str = 'Driver=SQLite3 ODBC Driver;Database=:memory:'
cnxn = pyodbc.connect(conn_str, autocommit=True)
crsr = cnxn.cursor()
# create test data
crsr.execute("CREATE TABLE table1 (id INTEGER PRIMARY KEY, dtm DATETIME)")
crsr.execute("INSERT INTO table1 (dtm) VALUES ('2017-07-26 08:08:08')")
# test retrieval
crsr.execute("SELECT * FROM table1")
print(crsr.fetchall())
# prints:
# [(1, datetime.datetime(2017, 7, 26, 8, 8, 8))]
crsr.close()
cnxn.close()
我刚刚对其进行了测试,它适用于 Windows 上的 PyCharm。
关于模拟 pyodbc.Row 的 Pythonic 方式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45326478/
如果你有一个简单的程序名 pyodbcTest.py import pyodbc print "pass" 然后使用 cx_freeze 编译它 cxfreeze --targe-dir=cxTest
我有一个 FileMaker db 在 Mac Mini 上的 FileMaker Server 14 上运行,我正在尝试使用 pyodbc 来获取它。进展不顺利。 首先,什么有效: telnet 1
这里有点菜鸟。我正在尝试创建一个 python 脚本来对基于 SQL 的数据库进行压力测试。 我一直在尝试使用 pyodbc 连接到数据库,但是我在 pyodbc.connect(connection
我想使用 pyodbc 和 freetds 从 Python 连接到 SQL SERVER 数据库。 我的连接正常。 我的代码: class GetSystems(Resource): def get
我正在尝试将 pyodbc 库导入 google colab,但出现此错误。 以防万一,我在我的笔记本中安装了 Anaconda,而且我从来没有遇到过 pyodbc 的问题。 你能帮我吗? 太棒了!
我最近跑了pip install pyodbc 。这表明它在cmd上成功安装了pyodbc。 但是当我这样做时 import pyodbc在 IDLE 中,我收到一条错误消息“没有名为 pyodbc
我写了一个简短的 python 脚本,它试图导入 pyodbc 扩展包,以便我可以访问我的 SQL 表。 import pyodbc as pyodbc cnxn = pyodbc.connect('
我正在尝试使用列表作为值的源将数据插入到 Access mdb 文件中。 cursor.execute("select * from Components") cursor.executemany("
我使用 pyodbc 的时间很短,现在面临着从文件中应用 sql 脚本来执行一些 View 创建的问题。为了应用 sql 文件,我使用另一个线程中的示例 - Follow up: Execute .s
我传递给 pyodbc.connect(conn_str) 的 conn_str 是: conn_str = str("DRIVER={{ODBC Driver 13 for SQL Server}}
好的,我已经在 mac 上安装了 python3.8,分别安装了多个 odbcdrivers。 我创建了一个新的虚拟环境,并在该环境中运行: >>> import pyodbc >>> pyodbc.
我有一个在Mac Mini上的FileMaker Server 14上运行的FileMaker db,我试图通过pyodbc来解决。不好 首先,什么有效: telnet 192.169.19.3 23
我可以按照以下说明确定是否安装了 suds: checking suds version in python 即通过在 Python 控制台中运行以下命令: >>>> import suds >>>>
我可以按照以下说明确定是否安装了 suds: checking suds version in python 即通过在 Python 控制台中运行以下命令: >>>> import suds >>>>
当我使用 pyodbc 查询 SQL 服务器时,我只得到我请求的字段的名称(而不是值本身)。 import pyodbc conn = pyodbc.connect(connection_string
我尝试使用以下代码查询 SQL Server 2012 数据库: import pyodbc class sqlserverConnector: def __init__(self, conn
我目前正在编写一个程序,该程序将从 Excel 电子表格中获取数据并将其插入到我在程序中创建的 SQL Server 表中。 我之前已将日期时间列指定为 nvarchar(250) ,以便使整个程序正
如果有人能指出我正确的方向,我会很感兴趣。 我有一个很长的存储过程(其中还包含对其中其他存储过程的调用),用于更新各种表。 如果我在管理工作室中运行存储过程,它运行良好。如果我从 pyodbc 调用它
你好,我有一个带有 SQL 的 Python 脚本,我使用 fecthall() 方法提取我想要的元素,直到那里一切都很好,因为我想将两列(datetime.date 和 datetime.time)
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我是一名优秀的程序员,十分优秀!