Python中的单元测试 - 我们能在Python中模拟SQL查询结果吗?

6

摘要:我有一个方法想要进行测试。这个方法涉及连接数据库、提取结果(来自SQL查询)并将其保存到数据帧中。

我想知道,是否有办法模拟从SQL查询检索到的结果?

我尝试过unittest库,创建了一个类似于从SQL查询接收到的数据帧。但是我无法弄清楚如何在测试时将此变量传递给方法。

请分享您的见解。 我的方法类似于:

    try:
        db_connect = sqlite3.connect("address_zip.db")
        db_cur = db_connect.cursor()
        db_cur.execute(""" Select STD_ADDRESS,STD_CITY,STD_STATE from address""")
        sql_result=pd.read_sql_query(""" Select STD_ADDRESS,STD_CITY,STD_STATE from address""",db_connect)
        df = pd.DataFrame(sql_result, columns=['STD_ADDRESS', 'STD_CITY', 'STD_STATE'])
        print(f"The data from database is :\n {df}")
        db_cur.close()
        db_connect.close()
    except Exception as e:
        print(f"DB exception: {e}")

        return df

原始代码对变量"df"进行了几个操作,我的目的是模拟这个对象df

但我不知道如何做到? 抱歉,这可能是非常基础的问题,我刚开始学习Python。


你好,你已经尝试过哪些代码了? - Michelle
1个回答

0

让我们建议要测试的代码是

code_to_test.py

import sqlite3
import pandas as pd


def function_to_tets():
    df = None
    try:
        db_connect = sqlite3.connect("address_zip.db")
        db_cur = db_connect.cursor()
        db_cur.execute(""" Select STD_ADDRESS,STD_CITY,STD_STATE from address""")
        sql_result = pd.read_sql_query(""" Select STD_ADDRESS,STD_CITY,STD_STATE from address""", db_connect)
        df = pd.DataFrame(sql_result, columns=['STD_ADDRESS', 'STD_CITY', 'STD_STATE'])
        print(f"The data from database is :\n {df}")
        db_cur.close()
        db_connect.close()
    except Exception as e:
        print(f"DB exception: {e}")

    return df

所以,简单的解决方案是模拟来自sqlite3的任何调用链,并模拟pd.read_sql_query的返回值

tests/test_sql.py

from code_to_test import function_to_tets
from unittest import mock
import pandas as pd


@mock.patch('code_to_test.sqlite3')
@mock.patch('code_to_test.pd.read_sql_query')
def test_sql_query(read_sql_query_mock, sqlite_mock):
    read_sql_query_mock.return_value = pd.DataFrame({'STD_ADDRESS': ['address 1'],
                                                     'STD_CITY': ['city 1'],
                                                     'STD_STATE': ['state 1']})
    assert function_to_tets().to_dict(orient='list') == {'STD_ADDRESS': ['address 1'],
                                                         'STD_CITY': ['city 1'],
                                                         'STD_STATE': ['state 1']}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接