我想模拟一个python对象-psycopg2 - 来测试我的类。
当我打印对象 - dir(conn)
时,我会看到所有列出的连接,附加内容等。
conn = mock.MagicMock(psycopg2.connect)
结果:
['BINARY', 'Binary', 'DATETIME', 'DataError', 'DatabaseError', 'Date',
'DateFromTicks', 'Error', 'IntegrityError', 'InterfaceError',
'InternalError', 'NUMBER', 'NotSupportedError', 'OperationalError',
'ProgrammingError', 'ROWID', 'STRING', 'Time', 'TimeFromTicks',
'Timestamp', 'TimestampFromTicks', 'Warning', '__builtins__',
'__doc__', '__file__', '__libpq_version__', '__name__', '__package__',
'__path__', '__version__', '__warningregistry__', '_connect', '_ext',
'_ipaddress', '_json', '_psycopg', '_range', 'apilevel',
'assert_any_call', 'assert_called', 'assert_called_once',
'assert_called_once_with', 'assert_called_with', 'assert_has_calls',
'assert_not_called', 'attach_mock', 'call_args', 'call_args_list',
'call_count', 'called', 'configure_mock', 'connect', 'extensions',
'extras', 'method_calls', 'mock_add_spec', 'mock_calls', 'paramstyle',
'reset_mock', 'return_value', 'side_effect', 'threadsafety', 'tz',
'warn']
现在,当我想设置execute方法返回值的side_effect时。
conn.cursor().execute().side_effect = psycopg2.DatabaseError
我收到此错误:
AttributeError: Mock object has no attribute 'cursor'
新代码: -
pg = mock.MagicMock(psycopg2)
print dir(pg())
print dir(pg.connect)
pg.connect()
输出
AttributeError: Mock object has no attribute 'cursor'
答案 0 :(得分:0)
您需要配置conn
的返回值,而不是conn
本身,因为您正在模拟函数connect
。
conn().cursor().execute().side_effect = psycopg2.DatabaseError