import sys,os # workdir=os.getcwd() # root_path=os.path.dirname(os.path.dirname(os.path.abspath(__file__))) # print ("root_path",root_path) # sys.path.append(root_path) from unittest.mock import Mock from ..index_manage.screenIndex import IndexManage from pandas import DataFrame import pandas as pd import psycopg2 import psycopg2.extras class FengClass(object): wfids = '0cb03afdc42e443e947506146edc80be,1004' # feng stime = '2020-04-19' etime = '2020-04-24' cols = "" class GuangClass(object): wfids = '57bacf6dc8b54b7e963385ec0598f6lp,1005' # guang stime = '2020-04-19' etime = '2020-04-24' cols = "" class GuangErrorClass(object): wfids = '57bacf6dc8b54b7e963385ec0598f6lp,1005' # guang stime = '2020-04-19' etime = '2020-04-24' cols = "sdf" class noWfidClass(object): wfids = '' # guang stime = '2020-04-19' etime = '2020-04-24' cols = "" class myCurs(object): def __enter__(self): return self def __exit__(self, exc_type, exc_val, exc_tb): pass def execute(self,sql): pass def fetchall(self): t = [11] * 96 t.insert(0, '2020-01-01') return [t] def fetchone(self): return "3eee6536043e44ecbadb525a6e072e95" class AccessDB(object): def __enter__(self): return self def __exit__(self, exc_type, exc_val, exc_tb): pass def close(self): pass def cursor(self): return myCurs() class Test_tool(): def setup_method(self): # 一开始用的setup_class,结果一个用例的mock影响了下个用例,因为这些用例共用了一个self.tstobj。现在改成setup_method后,每个用例执行前都重置self.tstobj的值 self.tstobj = IndexManage() def test_invalid_col(self): psycopg2.connect = Mock(return_value=None) self.tstobj.write_db = Mock(return_value=None) self.tstobj.get_neibs = Mock(return_value=['3eee6536043e44ecbadb525a6e072e95']) data_x = DataFrame({'x': [1, 2, 3, 4]}, index = pd.date_range('2020-02-04', periods=4, freq="15T")) data_y = DataFrame({'y': [2, 2, 4, 4]}, index = pd.date_range('2020-02-04', periods=4, freq="15T")) self.tstobj.get_value = Mock(side_effect=lambda _, x, *d: data_x if 'x' == x else data_y) ret = self.tstobj.corr(GuangErrorClass, None) assert "" == ret.ret def test_execute_batch_error(self): psycopg2.connect = Mock(return_value=AccessDB()) self.tstobj.get_neibs = Mock(return_value=['3eee6536043e44ecbadb525a6e072e95']) data_x = DataFrame({'x': [1, 2, 3, 4]}, index=pd.date_range('2020-02-04', periods=4, freq="15T")) data_y = DataFrame({'y': [2, 2, 4, 4]}, index=pd.date_range('2020-02-04', periods=4, freq="15T")) self.tstobj.get_value = Mock(side_effect=lambda _, x, *d: data_x if 'x' == x else data_y) ret = self.tstobj.corr(GuangClass, None) assert "" == ret.ret def test_get_value(self): psycopg2.connect = Mock(return_value=AccessDB()) psycopg2.extras.execute_batch = Mock(return_value = None) ret = self.tstobj.corr(GuangClass, None) assert "" == ret.ret def test_get_value_xnone(self): psycopg2.connect = Mock(return_value=None) self.tstobj.write_db = Mock(return_value=None) self.tstobj.get_neibs = Mock(return_value = ['3eee6536043e44ecbadb525a6e072e95']) data_x = DataFrame() data_y = DataFrame({'y': [2, 2, 4, 4]}, index=pd.date_range('2020-02-04', periods=4, freq="15T")) self.tstobj.get_value = Mock(side_effect=lambda _, x, *d: data_x if 'x' == x else data_y) # Mock(side_effect=lambda x: 0 if x<20 else 30) ret = self.tstobj.corr(FengClass, None) assert "" == ret.ret def test_get_value_ynone(self): psycopg2.connect = Mock(return_value=None) self.tstobj.write_db = Mock(return_value=None) self.tstobj.get_neibs = Mock(return_value = ['3eee6536043e44ecbadb525a6e072e95']) data_x = DataFrame({'x': [1, 2, 3, 4]}, index=pd.date_range('2020-02-04', periods=4, freq="15T")) data_y = DataFrame() self.tstobj.get_value = Mock(side_effect=lambda _, x, *d: data_x if 'x' == x else data_y) # Mock(side_effect=lambda x: 0 if x<20 else 30) ret = self.tstobj.corr(FengClass, None) assert "" == ret.ret def test_noWfidClass(self): psycopg2.connect = Mock(return_value=AccessDB()) psycopg2.extras.execute_batch = Mock(return_value=None) ret = self.tstobj.corr(noWfidClass, None) assert 'unexpect type' in ret.ret def test_feng_no_neibs(self): psycopg2.connect = Mock(return_value=None) self.tstobj.write_db = Mock(return_value=None) self.tstobj.get_neibs = Mock(return_value = None) ret = self.tstobj.corr(FengClass, None) assert "no neighbor" in ret.ret def test_feng(self): psycopg2.connect = Mock(return_value=None) self.tstobj.write_db = Mock(return_value=None) self.tstobj.get_neibs = Mock(return_value = ['3eee6536043e44ecbadb525a6e072e95']) data_x = DataFrame({'x': [1, 2, 3, 4]}, index=pd.date_range('2020-02-04', periods=4, freq="15T")) data_y = DataFrame({'y': [2, 2, 4, 4]}, index=pd.date_range('2020-02-04', periods=4, freq="15T")) self.tstobj.get_value = Mock(side_effect=lambda _, x, *d: data_x if 'x' == x else data_y) # Mock(side_effect=lambda x: 0 if x<20 else 30) ret = self.tstobj.corr(FengClass, None) assert "" == ret.ret def test_guang(self): psycopg2.connect = Mock(return_value=None) self.tstobj.write_db = Mock(return_value=None) self.tstobj.get_neibs = Mock(return_value=['3eee6536043e44ecbadb525a6e072e95']) data_x = DataFrame({'x': [1, 2, 3, 4]}, index = pd.date_range('2020-02-04', periods=4, freq="15T")) data_y = DataFrame({'y': [2, 2, 4, 4]}, index = pd.date_range('2020-02-04', periods=4, freq="15T")) self.tstobj.get_value = Mock(side_effect=lambda _, x, *d: data_x if 'x' == x else data_y) ret = self.tstobj.corr(GuangClass, None) assert "" == ret.ret