模拟数据库连接python

时间:2020-04-19 13:31:21

标签: python python-unittest

我有一个名为redis_db.py的文件,该文件具有连接到Redis的代码

import os
import redis
import sys

class Database:
       def __init__(self, zset_name):
        redis_host = os.environ.get('REDIS_HOST', '127.0.0.1')
        redis_port = os.environ.get('REDIS_PORT', 6379)

        self.db = redis.StrictRedis(host=redis_host, port=redis_port)
        self.zset_name = zset_name

    def add(self, key):
        try:
            self.db.zadd(self.zset_name, {key: 0})
        except redis.exceptions.ConnectionError:
            print("Unable to connect to redis host.")
            sys.exit(0)

我还有一个名为app.py的文件,就像这样

from flask import Flask
from redis_db import Database

app = Flask(__name__)
db = Database('zset')

@app.route('/add_word/word=<word>')
def add_word(word):
   db.add(word)
   return ("{} added".format(word))

if __name__ == '__main__':
    app.run(host='0.0.0.0', port='8080')

现在我正在为这样的add_word函数编写单元测试

import unittest
import sys
import os
from unittest import mock

sys.path.append(os.path.dirname(os.path.realpath(__file__)) + "/../api/")
from api import app  # noqa: E402


class Testing(unittest.TestCase):

  def test_add_word(self):
      with mock.patch('app.Database') as mockdb:
         mockdb.return_value.add.return_value = ""
      result = app.add_word('shivam')
      self.assertEqual(result, 'shivam word added.')

我面临的问题是,尽管我正在模拟db方法调用,但它仍在类中调用实际方法,而不是返回模拟值,并且在测试过程中,消息Unable to connect to redis host.出现错误。

有人可以帮助我弄清楚如何模拟redis数据库调用。

我正在使用unittest模块

1 个答案:

答案 0 :(得分:1)

问题在于db是在模块导入时定义的,因此mock.patch不会影响db变量。您可以移动的实例化 db函数中的add_word(word),或者您修补db而不是Database,例如

def test_add_word():
    with mock.patch('api.app.db') as mockdb:
        mockdb.add = mock.MagicMock(return_value="your desired return value")
        result = app.add_word('shivam')
    print(result)

请注意,add_word的调用必须在with块中,否则将使用未模拟的版本。

相关问题