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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
======================
Test Message Catalog
======================
The test message catalog "translates" test by simply outputing (in
unicode) the domain and message id in square-bracket markers:
>>> import zope.i18n.testmessagecatalog
>>> cat = zope.i18n.testmessagecatalog.TestMessageCatalog('foo.bar')
>>> cat.language, cat.domain
('test', 'foo.bar')
>>> print(cat.queryMessage('eek'))
[[foo.bar][eek]]
>>> print(cat.getMessage('eek'))
[[foo.bar][eek]]
>>> isinstance(cat.getMessage('eek'), str if bytes is not str else unicode)
True
>>> cat.getIdentifier()
'test'
>>> cat.reload()
If a message id has a default, it will be included in the output:
>>> id = zope.i18nmessageid.MessageFactory('foo.bar')('eek', default='Eek')
>>> print(cat.queryMessage(id))
[[foo.bar][eek (Eek)]]
>>> print(cat.getMessage(id))
[[foo.bar][eek (Eek)]]
If a message doesn't have a default, but a default is passed in to
queryMessage, the default will be used used:
>>> print(cat.queryMessage('eek', default='Eek'))
[[foo.bar][eek (Eek)]]
>>> print(cat.getMessage(id, default='Waaa'))
[[foo.bar][eek (Eek)]]
Fallback domains
================
The testmessagecatalog module also provide a fallback domain factory
that has the test catalog as it's only catalog:
>>> factory = zope.i18n.testmessagecatalog.TestMessageFallbackDomain
>>> import zope.i18n.interfaces
>>> zope.i18n.interfaces.IFallbackTranslationDomainFactory.providedBy(
... factory)
True
>>> domain = factory('foo.bar')
>>> print(domain.translate('eek'))
eek
>>> print(domain.translate('eek', target_language='test'))
[[foo.bar][eek]]
Note that if a default is padded in, it will be included in test
output:
>>> print(domain.translate('eek', target_language='test', default='Eek'))
[[foo.bar][eek (Eek)]]
|