Mercurial > babel > old > babel-test
view babel/messages/tests/catalog.py @ 359:ad98cc9a7eec
Updated catalog test case for last commit, flags are now tested too in the clone test case.
author | aronacher |
---|---|
date | Tue, 17 Jun 2008 21:56:50 +0000 |
parents | 6ea52d9bdab1 |
children | b44a5936a889 |
line wrap: on
line source
# -*- coding: utf-8 -*- # # Copyright (C) 2007 Edgewall Software # All rights reserved. # # This software is licensed as described in the file COPYING, which # you should have received as part of this distribution. The terms # are also available at http://babel.edgewall.org/wiki/License. # # This software consists of voluntary contributions made by many # individuals. For the exact contribution history, see the revision # history and logs, available at http://babel.edgewall.org/log/. import doctest import unittest from babel.messages import catalog class MessageTestCase(unittest.TestCase): def test_python_format(self): assert catalog.PYTHON_FORMAT.search('foo %d bar') assert catalog.PYTHON_FORMAT.search('foo %s bar') assert catalog.PYTHON_FORMAT.search('foo %r bar') assert catalog.PYTHON_FORMAT.search('foo %(name).1f') assert catalog.PYTHON_FORMAT.search('foo %(name)3.3f') assert catalog.PYTHON_FORMAT.search('foo %(name)3f') assert catalog.PYTHON_FORMAT.search('foo %(name)06d') assert catalog.PYTHON_FORMAT.search('foo %(name)Li') assert catalog.PYTHON_FORMAT.search('foo %(name)#d') assert catalog.PYTHON_FORMAT.search('foo %(name)-4.4hs') assert catalog.PYTHON_FORMAT.search('foo %(name)*.3f') assert catalog.PYTHON_FORMAT.search('foo %(name).*f') assert catalog.PYTHON_FORMAT.search('foo %(name)3.*f') assert catalog.PYTHON_FORMAT.search('foo %(name)*.*f') assert catalog.PYTHON_FORMAT.search('foo %()s') def test_translator_comments(self): mess = catalog.Message('foo', user_comments=['Comment About `foo`']) self.assertEqual(mess.user_comments, ['Comment About `foo`']) mess = catalog.Message('foo', auto_comments=['Comment 1 About `foo`', 'Comment 2 About `foo`']) self.assertEqual(mess.auto_comments, ['Comment 1 About `foo`', 'Comment 2 About `foo`']) def test_clone_message_object(self): msg = catalog.Message('foo', locations=[('foo.py', 42)]) clone = msg.clone() clone.locations.append(('bar.py', 42)) self.assertEqual(msg.locations, [('foo.py', 42)]) msg.flags.add('fuzzy') assert not clone.fuzzy and msg.fuzzy class CatalogTestCase(unittest.TestCase): def test_two_messages_with_same_singular(self): cat = catalog.Catalog() cat.add('foo') cat.add(('foo', 'foos')) self.assertEqual(1, len(cat)) def test_duplicate_auto_comment(self): cat = catalog.Catalog() cat.add('foo', auto_comments=['A comment']) cat.add('foo', auto_comments=['A comment', 'Another comment']) self.assertEqual(['A comment', 'Another comment'], cat['foo'].auto_comments) def test_duplicate_user_comment(self): cat = catalog.Catalog() cat.add('foo', user_comments=['A comment']) cat.add('foo', user_comments=['A comment', 'Another comment']) self.assertEqual(['A comment', 'Another comment'], cat['foo'].user_comments) def test_duplicate_location(self): cat = catalog.Catalog() cat.add('foo', locations=[('foo.py', 1)]) cat.add('foo', locations=[('foo.py', 1)]) self.assertEqual([('foo.py', 1)], cat['foo'].locations) def test_update_message_changed_to_plural(self): cat = catalog.Catalog() cat.add(u'foo', u'Voh') tmpl = catalog.Catalog() tmpl.add((u'foo', u'foos')) cat.update(tmpl) self.assertEqual((u'Voh', ''), cat['foo'].string) assert cat['foo'].fuzzy def test_update_message_changed_to_simple(self): cat = catalog.Catalog() cat.add((u'foo' u'foos'), (u'Voh', u'Vöhs')) tmpl = catalog.Catalog() tmpl.add(u'foo') cat.update(tmpl) self.assertEqual(u'Voh', cat['foo'].string) assert cat['foo'].fuzzy def test_update_message_updates_comments(self): cat = catalog.Catalog() cat[u'foo'] = catalog.Message('foo', locations=[('main.py', 5)]) self.assertEqual(cat[u'foo'].auto_comments, []) self.assertEqual(cat[u'foo'].user_comments, []) # Update cat[u'foo'] with a new location and a comment cat[u'foo'] = catalog.Message('foo', locations=[('main.py', 7)], user_comments=['Foo Bar comment 1']) self.assertEqual(cat[u'foo'].user_comments, ['Foo Bar comment 1']) # now add yet another location with another comment cat[u'foo'] = catalog.Message('foo', locations=[('main.py', 9)], auto_comments=['Foo Bar comment 2']) self.assertEqual(cat[u'foo'].auto_comments, ['Foo Bar comment 2']) def test_update_fuzzy_matching_with_case_change(self): cat = catalog.Catalog() cat.add('foo', 'Voh') cat.add('bar', 'Bahr') tmpl = catalog.Catalog() tmpl.add('Foo') cat.update(tmpl) self.assertEqual(1, len(cat.obsolete)) assert 'foo' not in cat self.assertEqual('Voh', cat['Foo'].string) self.assertEqual(True, cat['Foo'].fuzzy) def test_update_fuzzy_matching_with_char_change(self): cat = catalog.Catalog() cat.add('fo', 'Voh') cat.add('bar', 'Bahr') tmpl = catalog.Catalog() tmpl.add('foo') cat.update(tmpl) self.assertEqual(1, len(cat.obsolete)) assert 'fo' not in cat self.assertEqual('Voh', cat['foo'].string) self.assertEqual(True, cat['foo'].fuzzy) def test_update_fuzzy_matching_no_msgstr(self): cat = catalog.Catalog() cat.add('fo', '') tmpl = catalog.Catalog() tmpl.add('fo') tmpl.add('foo') cat.update(tmpl) assert 'fo' in cat assert 'foo' in cat self.assertEqual('', cat['fo'].string) self.assertEqual(False, cat['fo'].fuzzy) self.assertEqual(None, cat['foo'].string) self.assertEqual(False, cat['foo'].fuzzy) def test_update_fuzzy_matching_with_new_context(self): cat = catalog.Catalog() cat.add('foo', 'Voh') cat.add('bar', 'Bahr') tmpl = catalog.Catalog() tmpl.add('Foo', context='Menu') cat.update(tmpl) self.assertEqual(1, len(cat.obsolete)) assert 'foo' not in cat message = cat.get('Foo', 'Menu') self.assertEqual('Voh', message.string) self.assertEqual(True, message.fuzzy) self.assertEqual('Menu', message.context) def test_update_fuzzy_matching_with_changed_context(self): cat = catalog.Catalog() cat.add('foo', 'Voh', context='Menu|File') cat.add('bar', 'Bahr', context='Menu|File') tmpl = catalog.Catalog() tmpl.add('Foo', context='Menu|Edit') cat.update(tmpl) self.assertEqual(1, len(cat.obsolete)) assert cat.get('Foo', 'Menu|File') is None message = cat.get('Foo', 'Menu|Edit') self.assertEqual('Voh', message.string) self.assertEqual(True, message.fuzzy) self.assertEqual('Menu|Edit', message.context) def test_update_fuzzy_matching_no_cascading(self): cat = catalog.Catalog() cat.add('fo', 'Voh') cat.add('foo', 'Vohe') tmpl = catalog.Catalog() tmpl.add('fo') tmpl.add('foo') tmpl.add('fooo') cat.update(tmpl) assert 'fo' in cat assert 'foo' in cat self.assertEqual('Voh', cat['fo'].string) self.assertEqual(False, cat['fo'].fuzzy) self.assertEqual('Vohe', cat['foo'].string) self.assertEqual(False, cat['foo'].fuzzy) self.assertEqual('Vohe', cat['fooo'].string) self.assertEqual(True, cat['fooo'].fuzzy) def test_update_without_fuzzy_matching(self): cat = catalog.Catalog() cat.add('fo', 'Voh') cat.add('bar', 'Bahr') tmpl = catalog.Catalog() tmpl.add('foo') cat.update(tmpl, no_fuzzy_matching=True) self.assertEqual(2, len(cat.obsolete)) def test_update_no_template_mutation(self): tmpl = catalog.Catalog() tmpl.add('foo') cat1 = catalog.Catalog() cat1.add('foo', 'Voh') cat1.update(tmpl) cat2 = catalog.Catalog() cat2.update(tmpl) self.assertEqual(None, cat2['foo'].string) self.assertEqual(False, cat2['foo'].fuzzy) def suite(): suite = unittest.TestSuite() suite.addTest(doctest.DocTestSuite(catalog, optionflags=doctest.ELLIPSIS)) suite.addTest(unittest.makeSuite(MessageTestCase)) suite.addTest(unittest.makeSuite(CatalogTestCase)) return suite if __name__ == '__main__': unittest.main(defaultTest='suite')