123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593 |
- # Copyright (C) 2007-2012 Michael Foord & the mock team
- # E-mail: fuzzyman AT voidspace DOT org DOT uk
- # http://www.voidspace.org.uk/python/mock/
-
- import copy
- import pickle
- import sys
- import tempfile
-
- import six
- import unittest2 as unittest
-
- import mock
- from mock import (
- call, DEFAULT, patch, sentinel,
- MagicMock, Mock, NonCallableMock,
- NonCallableMagicMock,
- create_autospec
- )
- from mock.mock import _CallList
- from mock.tests.support import (
- callable, is_instance, next
- )
-
-
- try:
- unicode
- except NameError:
- unicode = str
-
-
- class Iter(object):
- def __init__(self):
- self.thing = iter(['this', 'is', 'an', 'iter'])
-
- def __iter__(self):
- return self
-
- def next(self):
- return next(self.thing)
-
- __next__ = next
-
-
- class Something(object):
- def meth(self, a, b, c, d=None):
- pass
-
- @classmethod
- def cmeth(cls, a, b, c, d=None):
- pass
-
- @staticmethod
- def smeth(a, b, c, d=None):
- pass
-
-
- class Subclass(MagicMock):
- pass
-
-
- class Thing(object):
- attribute = 6
- foo = 'bar'
-
-
-
- class MockTest(unittest.TestCase):
-
- def test_all(self):
- # if __all__ is badly defined then import * will raise an error
- # We have to exec it because you can't import * inside a method
- # in Python 3
- exec("from mock import *")
-
-
- def test_constructor(self):
- mock = Mock()
-
- self.assertFalse(mock.called, "called not initialised correctly")
- self.assertEqual(mock.call_count, 0,
- "call_count not initialised correctly")
- self.assertTrue(is_instance(mock.return_value, Mock),
- "return_value not initialised correctly")
-
- self.assertEqual(mock.call_args, None,
- "call_args not initialised correctly")
- self.assertEqual(mock.call_args_list, [],
- "call_args_list not initialised correctly")
- self.assertEqual(mock.method_calls, [],
- "method_calls not initialised correctly")
-
- # Can't use hasattr for this test as it always returns True on a mock
- self.assertNotIn('_items', mock.__dict__,
- "default mock should not have '_items' attribute")
-
- self.assertIsNone(mock._mock_parent,
- "parent not initialised correctly")
- self.assertIsNone(mock._mock_methods,
- "methods not initialised correctly")
- self.assertEqual(mock._mock_children, {},
- "children not initialised incorrectly")
-
-
- def test_return_value_in_constructor(self):
- mock = Mock(return_value=None)
- self.assertIsNone(mock.return_value,
- "return value in constructor not honoured")
-
-
- def test_repr(self):
- mock = Mock(name='foo')
- self.assertIn('foo', repr(mock))
- self.assertIn("'%s'" % id(mock), repr(mock))
-
- mocks = [(Mock(), 'mock'), (Mock(name='bar'), 'bar')]
- for mock, name in mocks:
- self.assertIn('%s.bar' % name, repr(mock.bar))
- self.assertIn('%s.foo()' % name, repr(mock.foo()))
- self.assertIn('%s.foo().bing' % name, repr(mock.foo().bing))
- self.assertIn('%s()' % name, repr(mock()))
- self.assertIn('%s()()' % name, repr(mock()()))
- self.assertIn('%s()().foo.bar.baz().bing' % name,
- repr(mock()().foo.bar.baz().bing))
-
-
- def test_repr_with_spec(self):
- class X(object):
- pass
-
- mock = Mock(spec=X)
- self.assertIn(" spec='X' ", repr(mock))
-
- mock = Mock(spec=X())
- self.assertIn(" spec='X' ", repr(mock))
-
- mock = Mock(spec_set=X)
- self.assertIn(" spec_set='X' ", repr(mock))
-
- mock = Mock(spec_set=X())
- self.assertIn(" spec_set='X' ", repr(mock))
-
- mock = Mock(spec=X, name='foo')
- self.assertIn(" spec='X' ", repr(mock))
- self.assertIn(" name='foo' ", repr(mock))
-
- mock = Mock(name='foo')
- self.assertNotIn("spec", repr(mock))
-
- mock = Mock()
- self.assertNotIn("spec", repr(mock))
-
- mock = Mock(spec=['foo'])
- self.assertNotIn("spec", repr(mock))
-
-
- def test_side_effect(self):
- mock = Mock()
-
- def effect(*args, **kwargs):
- raise SystemError('kablooie')
-
- mock.side_effect = effect
- self.assertRaises(SystemError, mock, 1, 2, fish=3)
- mock.assert_called_with(1, 2, fish=3)
-
- results = [1, 2, 3]
- def effect():
- return results.pop()
- mock.side_effect = effect
-
- self.assertEqual([mock(), mock(), mock()], [3, 2, 1],
- "side effect not used correctly")
-
- mock = Mock(side_effect=sentinel.SideEffect)
- self.assertEqual(mock.side_effect, sentinel.SideEffect,
- "side effect in constructor not used")
-
- def side_effect():
- return DEFAULT
- mock = Mock(side_effect=side_effect, return_value=sentinel.RETURN)
- self.assertEqual(mock(), sentinel.RETURN)
-
- def test_autospec_side_effect(self):
- # Test for issue17826
- results = [1, 2, 3]
- def effect():
- return results.pop()
- def f():
- pass
-
- mock = create_autospec(f)
- mock.side_effect = [1, 2, 3]
- self.assertEqual([mock(), mock(), mock()], [1, 2, 3],
- "side effect not used correctly in create_autospec")
- # Test where side effect is a callable
- results = [1, 2, 3]
- mock = create_autospec(f)
- mock.side_effect = effect
- self.assertEqual([mock(), mock(), mock()], [3, 2, 1],
- "callable side effect not used correctly")
-
- def test_autospec_side_effect_exception(self):
- # Test for issue 23661
- def f():
- pass
-
- mock = create_autospec(f)
- mock.side_effect = ValueError('Bazinga!')
- self.assertRaisesRegex(ValueError, 'Bazinga!', mock)
-
- @unittest.skipUnless('java' in sys.platform,
- 'This test only applies to Jython')
- def test_java_exception_side_effect(self):
- import java
- mock = Mock(side_effect=java.lang.RuntimeException("Boom!"))
-
- # can't use assertRaises with java exceptions
- try:
- mock(1, 2, fish=3)
- except java.lang.RuntimeException:
- pass
- else:
- self.fail('java exception not raised')
- mock.assert_called_with(1,2, fish=3)
-
-
- def test_reset_mock(self):
- parent = Mock()
- spec = ["something"]
- mock = Mock(name="child", parent=parent, spec=spec)
- mock(sentinel.Something, something=sentinel.SomethingElse)
- something = mock.something
- mock.something()
- mock.side_effect = sentinel.SideEffect
- return_value = mock.return_value
- return_value()
-
- mock.reset_mock()
-
- self.assertEqual(mock._mock_name, "child",
- "name incorrectly reset")
- self.assertEqual(mock._mock_parent, parent,
- "parent incorrectly reset")
- self.assertEqual(mock._mock_methods, spec,
- "methods incorrectly reset")
-
- self.assertFalse(mock.called, "called not reset")
- self.assertEqual(mock.call_count, 0, "call_count not reset")
- self.assertEqual(mock.call_args, None, "call_args not reset")
- self.assertEqual(mock.call_args_list, [], "call_args_list not reset")
- self.assertEqual(mock.method_calls, [],
- "method_calls not initialised correctly: %r != %r" %
- (mock.method_calls, []))
- self.assertEqual(mock.mock_calls, [])
-
- self.assertEqual(mock.side_effect, sentinel.SideEffect,
- "side_effect incorrectly reset")
- self.assertEqual(mock.return_value, return_value,
- "return_value incorrectly reset")
- self.assertFalse(return_value.called, "return value mock not reset")
- self.assertEqual(mock._mock_children, {'something': something},
- "children reset incorrectly")
- self.assertEqual(mock.something, something,
- "children incorrectly cleared")
- self.assertFalse(mock.something.called, "child not reset")
-
-
- def test_reset_mock_recursion(self):
- mock = Mock()
- mock.return_value = mock
-
- # used to cause recursion
- mock.reset_mock()
-
- def test_reset_mock_on_mock_open_issue_18622(self):
- a = mock.mock_open()
- a.reset_mock()
-
- def test_call(self):
- mock = Mock()
- self.assertTrue(is_instance(mock.return_value, Mock),
- "Default return_value should be a Mock")
-
- result = mock()
- self.assertEqual(mock(), result,
- "different result from consecutive calls")
- mock.reset_mock()
-
- ret_val = mock(sentinel.Arg)
- self.assertTrue(mock.called, "called not set")
- self.assertEqual(mock.call_count, 1, "call_count incoreect")
- self.assertEqual(mock.call_args, ((sentinel.Arg,), {}),
- "call_args not set")
- self.assertEqual(mock.call_args_list, [((sentinel.Arg,), {})],
- "call_args_list not initialised correctly")
-
- mock.return_value = sentinel.ReturnValue
- ret_val = mock(sentinel.Arg, key=sentinel.KeyArg)
- self.assertEqual(ret_val, sentinel.ReturnValue,
- "incorrect return value")
-
- self.assertEqual(mock.call_count, 2, "call_count incorrect")
- self.assertEqual(mock.call_args,
- ((sentinel.Arg,), {'key': sentinel.KeyArg}),
- "call_args not set")
- self.assertEqual(mock.call_args_list, [
- ((sentinel.Arg,), {}),
- ((sentinel.Arg,), {'key': sentinel.KeyArg})
- ],
- "call_args_list not set")
-
-
- def test_call_args_comparison(self):
- mock = Mock()
- mock()
- mock(sentinel.Arg)
- mock(kw=sentinel.Kwarg)
- mock(sentinel.Arg, kw=sentinel.Kwarg)
- self.assertEqual(mock.call_args_list, [
- (),
- ((sentinel.Arg,),),
- ({"kw": sentinel.Kwarg},),
- ((sentinel.Arg,), {"kw": sentinel.Kwarg})
- ])
- self.assertEqual(mock.call_args,
- ((sentinel.Arg,), {"kw": sentinel.Kwarg}))
-
- # Comparing call_args to a long sequence should not raise
- # an exception. See issue 24857.
- self.assertFalse(mock.call_args == "a long sequence")
-
- def test_assert_called_with(self):
- mock = Mock()
- mock()
-
- # Will raise an exception if it fails
- mock.assert_called_with()
- self.assertRaises(AssertionError, mock.assert_called_with, 1)
-
- mock.reset_mock()
- self.assertRaises(AssertionError, mock.assert_called_with)
-
- mock(1, 2, 3, a='fish', b='nothing')
- mock.assert_called_with(1, 2, 3, a='fish', b='nothing')
-
-
- def test_assert_called_with_function_spec(self):
- def f(a, b, c, d=None):
- pass
-
- mock = Mock(spec=f)
-
- mock(1, b=2, c=3)
- mock.assert_called_with(1, 2, 3)
- mock.assert_called_with(a=1, b=2, c=3)
- self.assertRaises(AssertionError, mock.assert_called_with,
- 1, b=3, c=2)
- # Expected call doesn't match the spec's signature
- with self.assertRaises(AssertionError) as cm:
- mock.assert_called_with(e=8)
- if hasattr(cm.exception, '__cause__'):
- self.assertIsInstance(cm.exception.__cause__, TypeError)
-
-
- def test_assert_called_with_method_spec(self):
- def _check(mock):
- mock(1, b=2, c=3)
- mock.assert_called_with(1, 2, 3)
- mock.assert_called_with(a=1, b=2, c=3)
- self.assertRaises(AssertionError, mock.assert_called_with,
- 1, b=3, c=2)
-
- mock = Mock(spec=Something().meth)
- _check(mock)
- mock = Mock(spec=Something.cmeth)
- _check(mock)
- mock = Mock(spec=Something().cmeth)
- _check(mock)
- mock = Mock(spec=Something.smeth)
- _check(mock)
- mock = Mock(spec=Something().smeth)
- _check(mock)
-
-
- def test_assert_called_once_with(self):
- mock = Mock()
- mock()
-
- # Will raise an exception if it fails
- mock.assert_called_once_with()
-
- mock()
- self.assertRaises(AssertionError, mock.assert_called_once_with)
-
- mock.reset_mock()
- self.assertRaises(AssertionError, mock.assert_called_once_with)
-
- mock('foo', 'bar', baz=2)
- mock.assert_called_once_with('foo', 'bar', baz=2)
-
- mock.reset_mock()
- mock('foo', 'bar', baz=2)
- self.assertRaises(
- AssertionError,
- lambda: mock.assert_called_once_with('bob', 'bar', baz=2)
- )
-
-
- def test_assert_called_once_with_function_spec(self):
- def f(a, b, c, d=None):
- pass
-
- mock = Mock(spec=f)
-
- mock(1, b=2, c=3)
- mock.assert_called_once_with(1, 2, 3)
- mock.assert_called_once_with(a=1, b=2, c=3)
- self.assertRaises(AssertionError, mock.assert_called_once_with,
- 1, b=3, c=2)
- # Expected call doesn't match the spec's signature
- with self.assertRaises(AssertionError) as cm:
- mock.assert_called_once_with(e=8)
- if hasattr(cm.exception, '__cause__'):
- self.assertIsInstance(cm.exception.__cause__, TypeError)
- # Mock called more than once => always fails
- mock(4, 5, 6)
- self.assertRaises(AssertionError, mock.assert_called_once_with,
- 1, 2, 3)
- self.assertRaises(AssertionError, mock.assert_called_once_with,
- 4, 5, 6)
-
-
- def test_attribute_access_returns_mocks(self):
- mock = Mock()
- something = mock.something
- self.assertTrue(is_instance(something, Mock), "attribute isn't a mock")
- self.assertEqual(mock.something, something,
- "different attributes returned for same name")
-
- # Usage example
- mock = Mock()
- mock.something.return_value = 3
-
- self.assertEqual(mock.something(), 3, "method returned wrong value")
- self.assertTrue(mock.something.called,
- "method didn't record being called")
-
-
- def test_attributes_have_name_and_parent_set(self):
- mock = Mock()
- something = mock.something
-
- self.assertEqual(something._mock_name, "something",
- "attribute name not set correctly")
- self.assertEqual(something._mock_parent, mock,
- "attribute parent not set correctly")
-
-
- def test_method_calls_recorded(self):
- mock = Mock()
- mock.something(3, fish=None)
- mock.something_else.something(6, cake=sentinel.Cake)
-
- self.assertEqual(mock.something_else.method_calls,
- [("something", (6,), {'cake': sentinel.Cake})],
- "method calls not recorded correctly")
- self.assertEqual(mock.method_calls, [
- ("something", (3,), {'fish': None}),
- ("something_else.something", (6,), {'cake': sentinel.Cake})
- ],
- "method calls not recorded correctly")
-
-
- def test_method_calls_compare_easily(self):
- mock = Mock()
- mock.something()
- self.assertEqual(mock.method_calls, [('something',)])
- self.assertEqual(mock.method_calls, [('something', (), {})])
-
- mock = Mock()
- mock.something('different')
- self.assertEqual(mock.method_calls, [('something', ('different',))])
- self.assertEqual(mock.method_calls,
- [('something', ('different',), {})])
-
- mock = Mock()
- mock.something(x=1)
- self.assertEqual(mock.method_calls, [('something', {'x': 1})])
- self.assertEqual(mock.method_calls, [('something', (), {'x': 1})])
-
- mock = Mock()
- mock.something('different', some='more')
- self.assertEqual(mock.method_calls, [
- ('something', ('different',), {'some': 'more'})
- ])
-
-
- def test_only_allowed_methods_exist(self):
- for spec in ['something'], ('something',):
- for arg in 'spec', 'spec_set':
- mock = Mock(**{arg: spec})
-
- # this should be allowed
- mock.something
- self.assertRaisesRegex(
- AttributeError,
- "Mock object has no attribute 'something_else'",
- getattr, mock, 'something_else'
- )
-
-
- def test_from_spec(self):
- class Something(object):
- x = 3
- __something__ = None
- def y(self):
- pass
-
- def test_attributes(mock):
- # should work
- mock.x
- mock.y
- mock.__something__
- self.assertRaisesRegex(
- AttributeError,
- "Mock object has no attribute 'z'",
- getattr, mock, 'z'
- )
- self.assertRaisesRegex(
- AttributeError,
- "Mock object has no attribute '__foobar__'",
- getattr, mock, '__foobar__'
- )
-
- test_attributes(Mock(spec=Something))
- test_attributes(Mock(spec=Something()))
-
-
- def test_wraps_calls(self):
- real = Mock()
-
- mock = Mock(wraps=real)
- self.assertEqual(mock(), real())
-
- real.reset_mock()
-
- mock(1, 2, fish=3)
- real.assert_called_with(1, 2, fish=3)
-
-
- def test_wraps_call_with_nondefault_return_value(self):
- real = Mock()
-
- mock = Mock(wraps=real)
- mock.return_value = 3
-
- self.assertEqual(mock(), 3)
- self.assertFalse(real.called)
-
-
- def test_wraps_attributes(self):
- class Real(object):
- attribute = Mock()
-
- real = Real()
-
- mock = Mock(wraps=real)
- self.assertEqual(mock.attribute(), real.attribute())
- self.assertRaises(AttributeError, lambda: mock.fish)
-
- self.assertNotEqual(mock.attribute, real.attribute)
- result = mock.attribute.frog(1, 2, fish=3)
- Real.attribute.frog.assert_called_with(1, 2, fish=3)
- self.assertEqual(result, Real.attribute.frog())
-
-
- def test_exceptional_side_effect(self):
- mock = Mock(side_effect=AttributeError)
- self.assertRaises(AttributeError, mock)
-
- mock = Mock(side_effect=AttributeError('foo'))
- self.assertRaises(AttributeError, mock)
-
-
- def test_baseexceptional_side_effect(self):
- mock = Mock(side_effect=KeyboardInterrupt)
- self.assertRaises(KeyboardInterrupt, mock)
-
- mock = Mock(side_effect=KeyboardInterrupt('foo'))
- self.assertRaises(KeyboardInterrupt, mock)
-
-
- def test_assert_called_with_message(self):
- mock = Mock()
- self.assertRaisesRegex(AssertionError, 'Not called',
- mock.assert_called_with)
-
-
- def test_assert_called_once_with_message(self):
- mock = Mock(name='geoffrey')
- self.assertRaisesRegex(AssertionError,
- r"Expected 'geoffrey' to be called once\.",
- mock.assert_called_once_with)
-
-
- def test__name__(self):
- mock = Mock()
- self.assertRaises(AttributeError, lambda: mock.__name__)
-
- mock.__name__ = 'foo'
- self.assertEqual(mock.__name__, 'foo')
-
-
- def test_spec_list_subclass(self):
- class Sub(list):
- pass
- mock = Mock(spec=Sub(['foo']))
-
- mock.append(3)
- mock.append.assert_called_with(3)
- self.assertRaises(AttributeError, getattr, mock, 'foo')
-
-
- def test_spec_class(self):
- class X(object):
- pass
-
- mock = Mock(spec=X)
- self.assertIsInstance(mock, X)
-
- mock = Mock(spec=X())
- self.assertIsInstance(mock, X)
-
- self.assertIs(mock.__class__, X)
- self.assertEqual(Mock().__class__.__name__, 'Mock')
-
- mock = Mock(spec_set=X)
- self.assertIsInstance(mock, X)
-
- mock = Mock(spec_set=X())
- self.assertIsInstance(mock, X)
-
-
- def test_setting_attribute_with_spec_set(self):
- class X(object):
- y = 3
-
- mock = Mock(spec=X)
- mock.x = 'foo'
-
- mock = Mock(spec_set=X)
- def set_attr():
- mock.x = 'foo'
-
- mock.y = 'foo'
- self.assertRaises(AttributeError, set_attr)
-
-
- def test_copy(self):
- current = sys.getrecursionlimit()
- self.addCleanup(sys.setrecursionlimit, current)
-
- # can't use sys.maxint as this doesn't exist in Python 3
- sys.setrecursionlimit(int(10e8))
- # this segfaults without the fix in place
- copy.copy(Mock())
-
-
- @unittest.skipIf(six.PY3, "no old style classes in Python 3")
- def test_spec_old_style_classes(self):
- class Foo:
- bar = 7
-
- mock = Mock(spec=Foo)
- mock.bar = 6
- self.assertRaises(AttributeError, lambda: mock.foo)
-
- mock = Mock(spec=Foo())
- mock.bar = 6
- self.assertRaises(AttributeError, lambda: mock.foo)
-
-
- @unittest.skipIf(six.PY3, "no old style classes in Python 3")
- def test_spec_set_old_style_classes(self):
- class Foo:
- bar = 7
-
- mock = Mock(spec_set=Foo)
- mock.bar = 6
- self.assertRaises(AttributeError, lambda: mock.foo)
-
- def _set():
- mock.foo = 3
- self.assertRaises(AttributeError, _set)
-
- mock = Mock(spec_set=Foo())
- mock.bar = 6
- self.assertRaises(AttributeError, lambda: mock.foo)
-
- def _set():
- mock.foo = 3
- self.assertRaises(AttributeError, _set)
-
-
- def test_subclass_with_properties(self):
- class SubClass(Mock):
- def _get(self):
- return 3
- def _set(self, value):
- raise NameError('strange error')
- some_attribute = property(_get, _set)
-
- s = SubClass(spec_set=SubClass)
- self.assertEqual(s.some_attribute, 3)
-
- def test():
- s.some_attribute = 3
- self.assertRaises(NameError, test)
-
- def test():
- s.foo = 'bar'
- self.assertRaises(AttributeError, test)
-
-
- def test_setting_call(self):
- mock = Mock()
- def __call__(self, a):
- return self._mock_call(a)
-
- type(mock).__call__ = __call__
- mock('one')
- mock.assert_called_with('one')
-
- self.assertRaises(TypeError, mock, 'one', 'two')
-
-
- def test_dir(self):
- mock = Mock()
- attrs = set(dir(mock))
- type_attrs = set([m for m in dir(Mock) if not m.startswith('_')])
-
- # all public attributes from the type are included
- self.assertEqual(set(), type_attrs - attrs)
-
- # creates these attributes
- mock.a, mock.b
- self.assertIn('a', dir(mock))
- self.assertIn('b', dir(mock))
-
- # instance attributes
- mock.c = mock.d = None
- self.assertIn('c', dir(mock))
- self.assertIn('d', dir(mock))
-
- # magic methods
- mock.__iter__ = lambda s: iter([])
- self.assertIn('__iter__', dir(mock))
-
-
- def test_dir_from_spec(self):
- mock = Mock(spec=unittest.TestCase)
- testcase_attrs = set(dir(unittest.TestCase))
- attrs = set(dir(mock))
-
- # all attributes from the spec are included
- self.assertEqual(set(), testcase_attrs - attrs)
-
- # shadow a sys attribute
- mock.version = 3
- self.assertEqual(dir(mock).count('version'), 1)
-
-
- def test_filter_dir(self):
- patcher = patch.object(mock, 'FILTER_DIR', False)
- patcher.start()
- try:
- attrs = set(dir(Mock()))
- type_attrs = set(dir(Mock))
-
- # ALL attributes from the type are included
- self.assertEqual(set(), type_attrs - attrs)
- finally:
- patcher.stop()
-
-
- def test_configure_mock(self):
- mock = Mock(foo='bar')
- self.assertEqual(mock.foo, 'bar')
-
- mock = MagicMock(foo='bar')
- self.assertEqual(mock.foo, 'bar')
-
- kwargs = {'side_effect': KeyError, 'foo.bar.return_value': 33,
- 'foo': MagicMock()}
- mock = Mock(**kwargs)
- self.assertRaises(KeyError, mock)
- self.assertEqual(mock.foo.bar(), 33)
- self.assertIsInstance(mock.foo, MagicMock)
-
- mock = Mock()
- mock.configure_mock(**kwargs)
- self.assertRaises(KeyError, mock)
- self.assertEqual(mock.foo.bar(), 33)
- self.assertIsInstance(mock.foo, MagicMock)
-
-
- def assertRaisesWithMsg(self, exception, message, func, *args, **kwargs):
- # needed because assertRaisesRegex doesn't work easily with newlines
- try:
- func(*args, **kwargs)
- except:
- instance = sys.exc_info()[1]
- self.assertIsInstance(instance, exception)
- else:
- self.fail('Exception %r not raised' % (exception,))
-
- msg = str(instance)
- self.assertEqual(msg, message)
-
-
- def test_assert_called_with_failure_message(self):
- mock = NonCallableMock()
-
- expected = "mock(1, '2', 3, bar='foo')"
- message = 'Expected call: %s\nNot called'
- self.assertRaisesWithMsg(
- AssertionError, message % (expected,),
- mock.assert_called_with, 1, '2', 3, bar='foo'
- )
-
- mock.foo(1, '2', 3, foo='foo')
-
-
- asserters = [
- mock.foo.assert_called_with, mock.foo.assert_called_once_with
- ]
- for meth in asserters:
- actual = "foo(1, '2', 3, foo='foo')"
- expected = "foo(1, '2', 3, bar='foo')"
- message = 'Expected call: %s\nActual call: %s'
- self.assertRaisesWithMsg(
- AssertionError, message % (expected, actual),
- meth, 1, '2', 3, bar='foo'
- )
-
- # just kwargs
- for meth in asserters:
- actual = "foo(1, '2', 3, foo='foo')"
- expected = "foo(bar='foo')"
- message = 'Expected call: %s\nActual call: %s'
- self.assertRaisesWithMsg(
- AssertionError, message % (expected, actual),
- meth, bar='foo'
- )
-
- # just args
- for meth in asserters:
- actual = "foo(1, '2', 3, foo='foo')"
- expected = "foo(1, 2, 3)"
- message = 'Expected call: %s\nActual call: %s'
- self.assertRaisesWithMsg(
- AssertionError, message % (expected, actual),
- meth, 1, 2, 3
- )
-
- # empty
- for meth in asserters:
- actual = "foo(1, '2', 3, foo='foo')"
- expected = "foo()"
- message = 'Expected call: %s\nActual call: %s'
- self.assertRaisesWithMsg(
- AssertionError, message % (expected, actual), meth
- )
-
-
- def test_mock_calls(self):
- mock = MagicMock()
-
- # need to do this because MagicMock.mock_calls used to just return
- # a MagicMock which also returned a MagicMock when __eq__ was called
- self.assertIs(mock.mock_calls == [], True)
-
- mock = MagicMock()
- mock()
- expected = [('', (), {})]
- self.assertEqual(mock.mock_calls, expected)
-
- mock.foo()
- expected.append(call.foo())
- self.assertEqual(mock.mock_calls, expected)
- # intermediate mock_calls work too
- self.assertEqual(mock.foo.mock_calls, [('', (), {})])
-
- mock = MagicMock()
- mock().foo(1, 2, 3, a=4, b=5)
- expected = [
- ('', (), {}), ('().foo', (1, 2, 3), dict(a=4, b=5))
- ]
- self.assertEqual(mock.mock_calls, expected)
- self.assertEqual(mock.return_value.foo.mock_calls,
- [('', (1, 2, 3), dict(a=4, b=5))])
- self.assertEqual(mock.return_value.mock_calls,
- [('foo', (1, 2, 3), dict(a=4, b=5))])
-
- mock = MagicMock()
- mock().foo.bar().baz()
- expected = [
- ('', (), {}), ('().foo.bar', (), {}),
- ('().foo.bar().baz', (), {})
- ]
- self.assertEqual(mock.mock_calls, expected)
- self.assertEqual(mock().mock_calls,
- call.foo.bar().baz().call_list())
-
- for kwargs in dict(), dict(name='bar'):
- mock = MagicMock(**kwargs)
- int(mock.foo)
- expected = [('foo.__int__', (), {})]
- self.assertEqual(mock.mock_calls, expected)
-
- mock = MagicMock(**kwargs)
- mock.a()()
- expected = [('a', (), {}), ('a()', (), {})]
- self.assertEqual(mock.mock_calls, expected)
- self.assertEqual(mock.a().mock_calls, [call()])
-
- mock = MagicMock(**kwargs)
- mock(1)(2)(3)
- self.assertEqual(mock.mock_calls, call(1)(2)(3).call_list())
- self.assertEqual(mock().mock_calls, call(2)(3).call_list())
- self.assertEqual(mock()().mock_calls, call(3).call_list())
-
- mock = MagicMock(**kwargs)
- mock(1)(2)(3).a.b.c(4)
- self.assertEqual(mock.mock_calls,
- call(1)(2)(3).a.b.c(4).call_list())
- self.assertEqual(mock().mock_calls,
- call(2)(3).a.b.c(4).call_list())
- self.assertEqual(mock()().mock_calls,
- call(3).a.b.c(4).call_list())
-
- mock = MagicMock(**kwargs)
- int(mock().foo.bar().baz())
- last_call = ('().foo.bar().baz().__int__', (), {})
- self.assertEqual(mock.mock_calls[-1], last_call)
- self.assertEqual(mock().mock_calls,
- call.foo.bar().baz().__int__().call_list())
- self.assertEqual(mock().foo.bar().mock_calls,
- call.baz().__int__().call_list())
- self.assertEqual(mock().foo.bar().baz.mock_calls,
- call().__int__().call_list())
-
-
- def test_subclassing(self):
- class Subclass(Mock):
- pass
-
- mock = Subclass()
- self.assertIsInstance(mock.foo, Subclass)
- self.assertIsInstance(mock(), Subclass)
-
- class Subclass(Mock):
- def _get_child_mock(self, **kwargs):
- return Mock(**kwargs)
-
- mock = Subclass()
- self.assertNotIsInstance(mock.foo, Subclass)
- self.assertNotIsInstance(mock(), Subclass)
-
-
- def test_arg_lists(self):
- mocks = [
- Mock(),
- MagicMock(),
- NonCallableMock(),
- NonCallableMagicMock()
- ]
-
- def assert_attrs(mock):
- names = 'call_args_list', 'method_calls', 'mock_calls'
- for name in names:
- attr = getattr(mock, name)
- self.assertIsInstance(attr, _CallList)
- self.assertIsInstance(attr, list)
- self.assertEqual(attr, [])
-
- for mock in mocks:
- assert_attrs(mock)
-
- if callable(mock):
- mock()
- mock(1, 2)
- mock(a=3)
-
- mock.reset_mock()
- assert_attrs(mock)
-
- mock.foo()
- mock.foo.bar(1, a=3)
- mock.foo(1).bar().baz(3)
-
- mock.reset_mock()
- assert_attrs(mock)
-
-
- def test_call_args_two_tuple(self):
- mock = Mock()
- mock(1, a=3)
- mock(2, b=4)
-
- self.assertEqual(len(mock.call_args), 2)
- args, kwargs = mock.call_args
- self.assertEqual(args, (2,))
- self.assertEqual(kwargs, dict(b=4))
-
- expected_list = [((1,), dict(a=3)), ((2,), dict(b=4))]
- for expected, call_args in zip(expected_list, mock.call_args_list):
- self.assertEqual(len(call_args), 2)
- self.assertEqual(expected[0], call_args[0])
- self.assertEqual(expected[1], call_args[1])
-
-
- def test_side_effect_iterator(self):
- mock = Mock(side_effect=iter([1, 2, 3]))
- self.assertEqual([mock(), mock(), mock()], [1, 2, 3])
- self.assertRaises(StopIteration, mock)
-
- mock = MagicMock(side_effect=['a', 'b', 'c'])
- self.assertEqual([mock(), mock(), mock()], ['a', 'b', 'c'])
- self.assertRaises(StopIteration, mock)
-
- mock = Mock(side_effect='ghi')
- self.assertEqual([mock(), mock(), mock()], ['g', 'h', 'i'])
- self.assertRaises(StopIteration, mock)
-
- class Foo(object):
- pass
- mock = MagicMock(side_effect=Foo)
- self.assertIsInstance(mock(), Foo)
-
- mock = Mock(side_effect=Iter())
- self.assertEqual([mock(), mock(), mock(), mock()],
- ['this', 'is', 'an', 'iter'])
- self.assertRaises(StopIteration, mock)
-
-
- def test_side_effect_setting_iterator(self):
- mock = Mock()
- mock.side_effect = iter([1, 2, 3])
- self.assertEqual([mock(), mock(), mock()], [1, 2, 3])
- self.assertRaises(StopIteration, mock)
- side_effect = mock.side_effect
- self.assertIsInstance(side_effect, type(iter([])))
-
- mock.side_effect = ['a', 'b', 'c']
- self.assertEqual([mock(), mock(), mock()], ['a', 'b', 'c'])
- self.assertRaises(StopIteration, mock)
- side_effect = mock.side_effect
- self.assertIsInstance(side_effect, type(iter([])))
-
- this_iter = Iter()
- mock.side_effect = this_iter
- self.assertEqual([mock(), mock(), mock(), mock()],
- ['this', 'is', 'an', 'iter'])
- self.assertRaises(StopIteration, mock)
- self.assertIs(mock.side_effect, this_iter)
-
-
- def test_side_effect_iterator_exceptions(self):
- for Klass in Mock, MagicMock:
- iterable = (ValueError, 3, KeyError, 6)
- m = Klass(side_effect=iterable)
- self.assertRaises(ValueError, m)
- self.assertEqual(m(), 3)
- self.assertRaises(KeyError, m)
- self.assertEqual(m(), 6)
-
-
- def test_side_effect_iterator_default(self):
- mock = Mock(return_value=2)
- mock.side_effect = iter([1, DEFAULT])
- self.assertEqual([mock(), mock()], [1, 2])
-
- def test_assert_has_calls_any_order(self):
- mock = Mock()
- mock(1, 2)
- mock(a=3)
- mock(3, 4)
- mock(b=6)
- mock(b=6)
-
- kalls = [
- call(1, 2), ({'a': 3},),
- ((3, 4),), ((), {'a': 3}),
- ('', (1, 2)), ('', {'a': 3}),
- ('', (1, 2), {}), ('', (), {'a': 3})
- ]
- for kall in kalls:
- mock.assert_has_calls([kall], any_order=True)
-
- for kall in call(1, '2'), call(b=3), call(), 3, None, 'foo':
- self.assertRaises(
- AssertionError, mock.assert_has_calls,
- [kall], any_order=True
- )
-
- kall_lists = [
- [call(1, 2), call(b=6)],
- [call(3, 4), call(1, 2)],
- [call(b=6), call(b=6)],
- ]
-
- for kall_list in kall_lists:
- mock.assert_has_calls(kall_list, any_order=True)
-
- kall_lists = [
- [call(b=6), call(b=6), call(b=6)],
- [call(1, 2), call(1, 2)],
- [call(3, 4), call(1, 2), call(5, 7)],
- [call(b=6), call(3, 4), call(b=6), call(1, 2), call(b=6)],
- ]
- for kall_list in kall_lists:
- self.assertRaises(
- AssertionError, mock.assert_has_calls,
- kall_list, any_order=True
- )
-
- def test_assert_has_calls(self):
- kalls1 = [
- call(1, 2), ({'a': 3},),
- ((3, 4),), call(b=6),
- ('', (1,), {'b': 6}),
- ]
- kalls2 = [call.foo(), call.bar(1)]
- kalls2.extend(call.spam().baz(a=3).call_list())
- kalls2.extend(call.bam(set(), foo={}).fish([1]).call_list())
-
- mocks = []
- for mock in Mock(), MagicMock():
- mock(1, 2)
- mock(a=3)
- mock(3, 4)
- mock(b=6)
- mock(1, b=6)
- mocks.append((mock, kalls1))
-
- mock = Mock()
- mock.foo()
- mock.bar(1)
- mock.spam().baz(a=3)
- mock.bam(set(), foo={}).fish([1])
- mocks.append((mock, kalls2))
-
- for mock, kalls in mocks:
- for i in range(len(kalls)):
- for step in 1, 2, 3:
- these = kalls[i:i+step]
- mock.assert_has_calls(these)
-
- if len(these) > 1:
- self.assertRaises(
- AssertionError,
- mock.assert_has_calls,
- list(reversed(these))
- )
-
-
- def test_assert_has_calls_with_function_spec(self):
- def f(a, b, c, d=None):
- pass
-
- mock = Mock(spec=f)
-
- mock(1, b=2, c=3)
- mock(4, 5, c=6, d=7)
- mock(10, 11, c=12)
- calls = [
- ('', (1, 2, 3), {}),
- ('', (4, 5, 6), {'d': 7}),
- ((10, 11, 12), {}),
- ]
- mock.assert_has_calls(calls)
- mock.assert_has_calls(calls, any_order=True)
- mock.assert_has_calls(calls[1:])
- mock.assert_has_calls(calls[1:], any_order=True)
- mock.assert_has_calls(calls[:-1])
- mock.assert_has_calls(calls[:-1], any_order=True)
- # Reversed order
- calls = list(reversed(calls))
- with self.assertRaises(AssertionError):
- mock.assert_has_calls(calls)
- mock.assert_has_calls(calls, any_order=True)
- with self.assertRaises(AssertionError):
- mock.assert_has_calls(calls[1:])
- mock.assert_has_calls(calls[1:], any_order=True)
- with self.assertRaises(AssertionError):
- mock.assert_has_calls(calls[:-1])
- mock.assert_has_calls(calls[:-1], any_order=True)
-
-
- def test_assert_any_call(self):
- mock = Mock()
- mock(1, 2)
- mock(a=3)
- mock(1, b=6)
-
- mock.assert_any_call(1, 2)
- mock.assert_any_call(a=3)
- mock.assert_any_call(1, b=6)
-
- self.assertRaises(
- AssertionError,
- mock.assert_any_call
- )
- self.assertRaises(
- AssertionError,
- mock.assert_any_call,
- 1, 3
- )
- self.assertRaises(
- AssertionError,
- mock.assert_any_call,
- a=4
- )
-
-
- def test_assert_any_call_with_function_spec(self):
- def f(a, b, c, d=None):
- pass
-
- mock = Mock(spec=f)
-
- mock(1, b=2, c=3)
- mock(4, 5, c=6, d=7)
- mock.assert_any_call(1, 2, 3)
- mock.assert_any_call(a=1, b=2, c=3)
- mock.assert_any_call(4, 5, 6, 7)
- mock.assert_any_call(a=4, b=5, c=6, d=7)
- self.assertRaises(AssertionError, mock.assert_any_call,
- 1, b=3, c=2)
- # Expected call doesn't match the spec's signature
- with self.assertRaises(AssertionError) as cm:
- mock.assert_any_call(e=8)
- if hasattr(cm.exception, '__cause__'):
- self.assertIsInstance(cm.exception.__cause__, TypeError)
-
-
- def test_mock_calls_create_autospec(self):
- def f(a, b):
- pass
- obj = Iter()
- obj.f = f
-
- funcs = [
- create_autospec(f),
- create_autospec(obj).f
- ]
- for func in funcs:
- func(1, 2)
- func(3, 4)
-
- self.assertEqual(
- func.mock_calls, [call(1, 2), call(3, 4)]
- )
-
- #Issue21222
- def test_create_autospec_with_name(self):
- m = mock.create_autospec(object(), name='sweet_func')
- self.assertIn('sweet_func', repr(m))
-
- #Issue21238
- def test_mock_unsafe(self):
- m = Mock()
- with self.assertRaises(AttributeError):
- m.assert_foo_call()
- with self.assertRaises(AttributeError):
- m.assret_foo_call()
- m = Mock(unsafe=True)
- m.assert_foo_call()
- m.assret_foo_call()
-
- #Issue21262
- def test_assert_not_called(self):
- m = Mock()
- m.hello.assert_not_called()
- m.hello()
- with self.assertRaises(AssertionError):
- m.hello.assert_not_called()
-
- def test_assert_called(self):
- m = Mock()
- with self.assertRaises(AssertionError):
- m.hello.assert_called()
- m.hello()
- m.hello.assert_called()
-
- m.hello()
- m.hello.assert_called()
-
- def test_assert_called_once(self):
- m = Mock()
- with self.assertRaises(AssertionError):
- m.hello.assert_called_once()
- m.hello()
- m.hello.assert_called_once()
-
- m.hello()
- with self.assertRaises(AssertionError):
- m.hello.assert_called_once()
-
- #Issue21256 printout of keyword args should be in deterministic order
- def test_sorted_call_signature(self):
- m = Mock()
- m.hello(name='hello', daddy='hero')
- text = "call(daddy='hero', name='hello')"
- self.assertEqual(repr(m.hello.call_args), text)
-
- #Issue21270 overrides tuple methods for mock.call objects
- def test_override_tuple_methods(self):
- c = call.count()
- i = call.index(132,'hello')
- m = Mock()
- m.count()
- m.index(132,"hello")
- self.assertEqual(m.method_calls[0], c)
- self.assertEqual(m.method_calls[1], i)
-
- def test_mock_add_spec(self):
- class _One(object):
- one = 1
- class _Two(object):
- two = 2
- class Anything(object):
- one = two = three = 'four'
-
- klasses = [
- Mock, MagicMock, NonCallableMock, NonCallableMagicMock
- ]
- for Klass in list(klasses):
- klasses.append(lambda K=Klass: K(spec=Anything))
- klasses.append(lambda K=Klass: K(spec_set=Anything))
-
- for Klass in klasses:
- for kwargs in dict(), dict(spec_set=True):
- mock = Klass()
- #no error
- mock.one, mock.two, mock.three
-
- for One, Two in [(_One, _Two), (['one'], ['two'])]:
- for kwargs in dict(), dict(spec_set=True):
- mock.mock_add_spec(One, **kwargs)
-
- mock.one
- self.assertRaises(
- AttributeError, getattr, mock, 'two'
- )
- self.assertRaises(
- AttributeError, getattr, mock, 'three'
- )
- if 'spec_set' in kwargs:
- self.assertRaises(
- AttributeError, setattr, mock, 'three', None
- )
-
- mock.mock_add_spec(Two, **kwargs)
- self.assertRaises(
- AttributeError, getattr, mock, 'one'
- )
- mock.two
- self.assertRaises(
- AttributeError, getattr, mock, 'three'
- )
- if 'spec_set' in kwargs:
- self.assertRaises(
- AttributeError, setattr, mock, 'three', None
- )
- # note that creating a mock, setting an instance attribute, and
- # *then* setting a spec doesn't work. Not the intended use case
-
-
- def test_mock_add_spec_magic_methods(self):
- for Klass in MagicMock, NonCallableMagicMock:
- mock = Klass()
- int(mock)
-
- mock.mock_add_spec(object)
- self.assertRaises(TypeError, int, mock)
-
- mock = Klass()
- mock['foo']
- mock.__int__.return_value =4
-
- mock.mock_add_spec(int)
- self.assertEqual(int(mock), 4)
- self.assertRaises(TypeError, lambda: mock['foo'])
-
-
- def test_adding_child_mock(self):
- for Klass in NonCallableMock, Mock, MagicMock, NonCallableMagicMock:
- mock = Klass()
-
- mock.foo = Mock()
- mock.foo()
-
- self.assertEqual(mock.method_calls, [call.foo()])
- self.assertEqual(mock.mock_calls, [call.foo()])
-
- mock = Klass()
- mock.bar = Mock(name='name')
- mock.bar()
- self.assertEqual(mock.method_calls, [])
- self.assertEqual(mock.mock_calls, [])
-
- # mock with an existing _new_parent but no name
- mock = Klass()
- mock.baz = MagicMock()()
- mock.baz()
- self.assertEqual(mock.method_calls, [])
- self.assertEqual(mock.mock_calls, [])
-
-
- def test_adding_return_value_mock(self):
- for Klass in Mock, MagicMock:
- mock = Klass()
- mock.return_value = MagicMock()
-
- mock()()
- self.assertEqual(mock.mock_calls, [call(), call()()])
-
-
- def test_manager_mock(self):
- class Foo(object):
- one = 'one'
- two = 'two'
- manager = Mock()
- p1 = patch.object(Foo, 'one')
- p2 = patch.object(Foo, 'two')
-
- mock_one = p1.start()
- self.addCleanup(p1.stop)
- mock_two = p2.start()
- self.addCleanup(p2.stop)
-
- manager.attach_mock(mock_one, 'one')
- manager.attach_mock(mock_two, 'two')
-
- Foo.two()
- Foo.one()
-
- self.assertEqual(manager.mock_calls, [call.two(), call.one()])
-
-
- def test_magic_methods_mock_calls(self):
- for Klass in Mock, MagicMock:
- m = Klass()
- m.__int__ = Mock(return_value=3)
- m.__float__ = MagicMock(return_value=3.0)
- int(m)
- float(m)
-
- self.assertEqual(m.mock_calls, [call.__int__(), call.__float__()])
- self.assertEqual(m.method_calls, [])
-
- def test_mock_open_reuse_issue_21750(self):
- mocked_open = mock.mock_open(read_data='data')
- f1 = mocked_open('a-name')
- f1_data = f1.read()
- f2 = mocked_open('another-name')
- f2_data = f2.read()
- self.assertEqual(f1_data, f2_data)
-
- def test_mock_open_write(self):
- # Test exception in file writing write()
- mock_namedtemp = mock.mock_open(mock.MagicMock(name='JLV'))
- with mock.patch('tempfile.NamedTemporaryFile', mock_namedtemp):
- mock_filehandle = mock_namedtemp.return_value
- mock_write = mock_filehandle.write
- mock_write.side_effect = OSError('Test 2 Error')
- def attempt():
- tempfile.NamedTemporaryFile().write('asd')
- self.assertRaises(OSError, attempt)
-
- def test_mock_open_alter_readline(self):
- mopen = mock.mock_open(read_data='foo\nbarn')
- mopen.return_value.readline.side_effect = lambda *args:'abc'
- first = mopen().readline()
- second = mopen().readline()
- self.assertEqual('abc', first)
- self.assertEqual('abc', second)
-
- def test_mock_parents(self):
- for Klass in Mock, MagicMock:
- m = Klass()
- original_repr = repr(m)
- m.return_value = m
- self.assertIs(m(), m)
- self.assertEqual(repr(m), original_repr)
-
- m.reset_mock()
- self.assertIs(m(), m)
- self.assertEqual(repr(m), original_repr)
-
- m = Klass()
- m.b = m.a
- self.assertIn("name='mock.a'", repr(m.b))
- self.assertIn("name='mock.a'", repr(m.a))
- m.reset_mock()
- self.assertIn("name='mock.a'", repr(m.b))
- self.assertIn("name='mock.a'", repr(m.a))
-
- m = Klass()
- original_repr = repr(m)
- m.a = m()
- m.a.return_value = m
-
- self.assertEqual(repr(m), original_repr)
- self.assertEqual(repr(m.a()), original_repr)
-
-
- def test_attach_mock(self):
- classes = Mock, MagicMock, NonCallableMagicMock, NonCallableMock
- for Klass in classes:
- for Klass2 in classes:
- m = Klass()
-
- m2 = Klass2(name='foo')
- m.attach_mock(m2, 'bar')
-
- self.assertIs(m.bar, m2)
- self.assertIn("name='mock.bar'", repr(m2))
-
- m.bar.baz(1)
- self.assertEqual(m.mock_calls, [call.bar.baz(1)])
- self.assertEqual(m.method_calls, [call.bar.baz(1)])
-
-
- def test_attach_mock_return_value(self):
- classes = Mock, MagicMock, NonCallableMagicMock, NonCallableMock
- for Klass in Mock, MagicMock:
- for Klass2 in classes:
- m = Klass()
-
- m2 = Klass2(name='foo')
- m.attach_mock(m2, 'return_value')
-
- self.assertIs(m(), m2)
- self.assertIn("name='mock()'", repr(m2))
-
- m2.foo()
- self.assertEqual(m.mock_calls, call().foo().call_list())
-
-
- def test_attribute_deletion(self):
- for mock in (Mock(), MagicMock(), NonCallableMagicMock(),
- NonCallableMock()):
- self.assertTrue(hasattr(mock, 'm'))
-
- del mock.m
- self.assertFalse(hasattr(mock, 'm'))
-
- del mock.f
- self.assertFalse(hasattr(mock, 'f'))
- self.assertRaises(AttributeError, getattr, mock, 'f')
-
-
- def test_class_assignable(self):
- for mock in Mock(), MagicMock():
- self.assertNotIsInstance(mock, int)
-
- mock.__class__ = int
- self.assertIsInstance(mock, int)
- mock.foo
-
-
- @unittest.expectedFailure
- def test_pickle(self):
- for Klass in (MagicMock, Mock, Subclass, NonCallableMagicMock):
- mock = Klass(name='foo', attribute=3)
- mock.foo(1, 2, 3)
- data = pickle.dumps(mock)
- new = pickle.loads(data)
-
- new.foo.assert_called_once_with(1, 2, 3)
- self.assertFalse(new.called)
- self.assertTrue(is_instance(new, Klass))
- self.assertIsInstance(new, Thing)
- self.assertIn('name="foo"', repr(new))
- self.assertEqual(new.attribute, 3)
-
-
- if __name__ == '__main__':
- unittest.main()
|