You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
71 lines
2.4 KiB
71 lines
2.4 KiB
3 years ago
|
# UserString is a wrapper around the native builtin string type.
|
||
|
# UserString instances should behave similar to builtin string objects.
|
||
|
|
||
|
import unittest
|
||
|
from test import string_tests
|
||
|
|
||
|
from collections import UserString
|
||
|
|
||
|
class UserStringTest(
|
||
|
string_tests.CommonTest,
|
||
|
string_tests.MixinStrUnicodeUserStringTest,
|
||
|
unittest.TestCase
|
||
|
):
|
||
|
|
||
|
type2test = UserString
|
||
|
|
||
|
# Overwrite the three testing methods, because UserString
|
||
|
# can't cope with arguments propagated to UserString
|
||
|
# (and we don't test with subclasses)
|
||
|
def checkequal(self, result, object, methodname, *args, **kwargs):
|
||
|
result = self.fixtype(result)
|
||
|
object = self.fixtype(object)
|
||
|
# we don't fix the arguments, because UserString can't cope with it
|
||
|
realresult = getattr(object, methodname)(*args, **kwargs)
|
||
|
self.assertEqual(
|
||
|
result,
|
||
|
realresult
|
||
|
)
|
||
|
|
||
|
def checkraises(self, exc, obj, methodname, *args):
|
||
|
obj = self.fixtype(obj)
|
||
|
# we don't fix the arguments, because UserString can't cope with it
|
||
|
with self.assertRaises(exc) as cm:
|
||
|
getattr(obj, methodname)(*args)
|
||
|
self.assertNotEqual(str(cm.exception), '')
|
||
|
|
||
|
def checkcall(self, object, methodname, *args):
|
||
|
object = self.fixtype(object)
|
||
|
# we don't fix the arguments, because UserString can't cope with it
|
||
|
getattr(object, methodname)(*args)
|
||
|
|
||
|
def test_rmod(self):
|
||
|
class ustr2(UserString):
|
||
|
pass
|
||
|
|
||
|
class ustr3(ustr2):
|
||
|
def __rmod__(self, other):
|
||
|
return super().__rmod__(other)
|
||
|
|
||
|
fmt2 = ustr2('value is %s')
|
||
|
str3 = ustr3('TEST')
|
||
|
self.assertEqual(fmt2 % str3, 'value is TEST')
|
||
|
|
||
|
def test_encode_default_args(self):
|
||
|
self.checkequal(b'hello', 'hello', 'encode')
|
||
|
# Check that encoding defaults to utf-8
|
||
|
self.checkequal(b'\xf0\xa3\x91\x96', '\U00023456', 'encode')
|
||
|
# Check that errors defaults to 'strict'
|
||
|
self.checkraises(UnicodeError, '\ud800', 'encode')
|
||
|
|
||
|
def test_encode_explicit_none_args(self):
|
||
|
self.checkequal(b'hello', 'hello', 'encode', None, None)
|
||
|
# Check that encoding defaults to utf-8
|
||
|
self.checkequal(b'\xf0\xa3\x91\x96', '\U00023456', 'encode', None, None)
|
||
|
# Check that errors defaults to 'strict'
|
||
|
self.checkraises(UnicodeError, '\ud800', 'encode', None, None)
|
||
|
|
||
|
|
||
|
if __name__ == "__main__":
|
||
|
unittest.main()
|