/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_cache_utf8.py

  • Committer: Robert Collins
  • Date: 2007-04-19 02:27:44 UTC
  • mto: This revision was merged to the branch mainline in revision 2426.
  • Revision ID: robertc@robertcollins.net-20070419022744-pfdqz42kp1wizh43
``make docs`` now creates a man page at ``man1/bzr.1`` fixing bug 107388.
(Robert Collins)

Show diffs side-by-side

added added

removed removed

Lines of Context:
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
17
"""Tests for utf8 caching."""
18
18
 
19
 
from .. import (
 
19
from bzrlib import (
20
20
    cache_utf8,
21
21
    )
22
 
from . import TestCase
 
22
from bzrlib.tests import TestCase
23
23
 
24
24
 
25
25
class TestEncodeCache(TestCase):
26
 
 
 
26
    
27
27
    def setUp(self):
28
28
        super(TestEncodeCache, self).setUp()
29
29
        cache_utf8.clear_encoding_cache()
31
31
 
32
32
    def check_encode(self, rev_id):
33
33
        rev_id_utf8 = rev_id.encode('utf-8')
34
 
        self.assertFalse(rev_id in cache_utf8._unicode_to_utf8_map)
35
 
        self.assertFalse(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
 
34
        self.failIf(rev_id in cache_utf8._unicode_to_utf8_map)
 
35
        self.failIf(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
36
36
 
37
37
        # After a single encode, the mapping should exist for
38
38
        # both directions
39
39
        self.assertEqual(rev_id_utf8, cache_utf8.encode(rev_id))
40
 
        self.assertTrue(rev_id in cache_utf8._unicode_to_utf8_map)
41
 
        self.assertTrue(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
 
40
        self.failUnless(rev_id in cache_utf8._unicode_to_utf8_map)
 
41
        self.failUnless(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
42
42
 
43
43
        self.assertEqual(rev_id, cache_utf8.decode(rev_id_utf8))
44
44
 
45
45
        cache_utf8.clear_encoding_cache()
46
 
        self.assertFalse(rev_id in cache_utf8._unicode_to_utf8_map)
47
 
        self.assertFalse(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
 
46
        self.failIf(rev_id in cache_utf8._unicode_to_utf8_map)
 
47
        self.failIf(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
48
48
 
49
49
    def check_decode(self, rev_id):
50
50
        rev_id_utf8 = rev_id.encode('utf-8')
51
 
        self.assertFalse(rev_id in cache_utf8._unicode_to_utf8_map)
52
 
        self.assertFalse(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
 
51
        self.failIf(rev_id in cache_utf8._unicode_to_utf8_map)
 
52
        self.failIf(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
53
53
 
54
54
        # After a single decode, the mapping should exist for
55
55
        # both directions
56
56
        self.assertEqual(rev_id, cache_utf8.decode(rev_id_utf8))
57
 
        self.assertTrue(rev_id in cache_utf8._unicode_to_utf8_map)
58
 
        self.assertTrue(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
 
57
        self.failUnless(rev_id in cache_utf8._unicode_to_utf8_map)
 
58
        self.failUnless(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
59
59
 
60
60
        self.assertEqual(rev_id_utf8, cache_utf8.encode(rev_id))
61
61
        cache_utf8.clear_encoding_cache()
62
62
 
63
 
        self.assertFalse(rev_id in cache_utf8._unicode_to_utf8_map)
64
 
        self.assertFalse(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
 
63
        self.failIf(rev_id in cache_utf8._unicode_to_utf8_map)
 
64
        self.failIf(rev_id_utf8 in cache_utf8._utf8_to_unicode_map)
65
65
 
66
66
    def test_ascii(self):
67
67
        self.check_decode(u'all_ascii_characters123123123')
72
72
        self.check_decode(u'some_\xb5_unicode_\xe5_chars')
73
73
 
74
74
    def test_cached_unicode(self):
75
 
        # Note that this is intentionally split, to prevent Python from
76
 
        # assigning x and y to the same object
77
 
        z = u'\xe5zz'
78
 
        x = u'\xb5yy' + z
79
 
        y = u'\xb5yy' + z
80
 
        self.assertIsNot(x, y)
 
75
        x = u'\xb5yy' + u'\xe5zz'
 
76
        y = u'\xb5yy' + u'\xe5zz'
 
77
        self.failIf(x is y)
81
78
        xp = cache_utf8.get_cached_unicode(x)
82
79
        yp = cache_utf8.get_cached_unicode(y)
83
80
 
87
84
    def test_cached_utf8(self):
88
85
        x = u'\xb5yy\xe5zz'.encode('utf8')
89
86
        y = u'\xb5yy\xe5zz'.encode('utf8')
90
 
        self.assertFalse(x is y)
 
87
        self.failIf(x is y)
91
88
        xp = cache_utf8.get_cached_utf8(x)
92
89
        yp = cache_utf8.get_cached_utf8(y)
93
90
 
95
92
        self.assertIs(xp, yp)
96
93
 
97
94
    def test_cached_ascii(self):
98
 
        x = b'%s %s' % (b'simple', b'text')
99
 
        y = b'%s %s' % (b'simple', b'text')
100
 
        self.assertIsNot(x, y)
 
95
        x = '%s %s' % ('simple', 'text')
 
96
        y = '%s %s' % ('simple', 'text')
 
97
        self.failIf(x is y)
101
98
        xp = cache_utf8.get_cached_ascii(x)
102
99
        yp = cache_utf8.get_cached_ascii(y)
103
100
 
108
105
        # objects.
109
106
        uni_x = cache_utf8.decode(x)
110
107
        self.assertEqual(u'simple text', uni_x)
111
 
        self.assertIsInstance(uni_x, str)
 
108
        self.assertIsInstance(uni_x, unicode)
112
109
 
113
110
        utf8_x = cache_utf8.encode(uni_x)
114
111
        self.assertIs(utf8_x, x)
115
112
 
116
113
    def test_decode_with_None(self):
117
114
        self.assertEqual(None, cache_utf8._utf8_decode_with_None(None))
118
 
        self.assertEqual(u'foo', cache_utf8._utf8_decode_with_None(b'foo'))
 
115
        self.assertEqual(u'foo', cache_utf8._utf8_decode_with_None('foo'))
119
116
        self.assertEqual(u'f\xb5',
120
 
                         cache_utf8._utf8_decode_with_None(b'f\xc2\xb5'))
 
117
                         cache_utf8._utf8_decode_with_None('f\xc2\xb5'))