1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
|
if __name__ == '__main__':
import sys
sys.path.insert(0, '..')
sys.path.insert(0, '../..')
from hamcrest.library.collection.isdict_containing import *
from hamcrest.core.core.isequal import equal_to
from hamcrest_unit_test.matcher_test import MatcherTest
from quasidict import QuasiDictionary
import unittest
__author__ = "Jon Reid"
__copyright__ = "Copyright 2011 hamcrest.org"
__license__ = "BSD, see License.txt"
class IsDictContainingTest(MatcherTest):
def testMatchesDictionaryContainingMatchingKeyAndValue(self):
dict = {'a': 1, 'b': 2}
self.assert_matches('has a:1', has_entry(equal_to('a'), equal_to(1)), dict)
self.assert_matches('has b:2', has_entry(equal_to('b'), equal_to(2)), dict)
self.assert_does_not_match('no c:3', has_entry(equal_to('c'), equal_to(3)), dict)
def testProvidesConvenientShortcutForMatchingWithEqualTo(self):
dict = {'a': 1, 'b': 2}
self.assert_matches('has a:1', has_entry('a', equal_to(1)), dict)
self.assert_matches('has b:2', has_entry(equal_to('b'), 2), dict)
self.assert_does_not_match('no c:3', has_entry('c', 3), dict)
def testMatchesAnyConformingDictionary(self):
self.assert_matches('quasi-dictionary', has_entry(1, '1'), QuasiDictionary())
self.assert_does_not_match('non-dictionary', has_entry(1, '1'), object())
def testHasReadableDescription(self):
self.assert_description("a dictionary containing ['a': <1>]",
has_entry('a', 1))
def testSuccessfulMatchDoesNotGenerateMismatchDescription(self):
self.assert_no_mismatch_description(has_entry('a', 1), {'a': 1})
def testMismatchDescriptionShowsActualArgument(self):
self.assert_mismatch_description("was 'bad'", has_entry('a', 1), 'bad')
def testDescribeMismatch(self):
self.assert_describe_mismatch("was 'bad'", has_entry('a', 1), 'bad')
if __name__ == '__main__':
unittest.main()
|