diff options
author | Lorry Tar Creator <lorry-tar-importer@baserock.org> | 2014-12-24 07:38:37 +0000 |
---|---|---|
committer | <> | 2015-02-02 12:02:29 +0000 |
commit | 482840e61f86ca321838a91e902c41d40c098bbb (patch) | |
tree | 01ea2e242fd2792d19fe192476601587901db794 /gettext-tools/tests/lang-python-1 | |
download | gettext-tarball-482840e61f86ca321838a91e902c41d40c098bbb.tar.gz |
Imported from /home/lorry/working-area/delta_gettext-tarball/gettext-0.19.4.tar.xz.gettext-0.19.4
Diffstat (limited to 'gettext-tools/tests/lang-python-1')
-rwxr-xr-x | gettext-tools/tests/lang-python-1 | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/gettext-tools/tests/lang-python-1 b/gettext-tools/tests/lang-python-1 new file mode 100755 index 0000000..f198780 --- /dev/null +++ b/gettext-tools/tests/lang-python-1 @@ -0,0 +1,115 @@ +#! /bin/sh +. "${srcdir=.}/init.sh"; path_prepend_ . ../src + +# Test of gettext facilities in the Python language. + +# Note: This test fails with Python 2.3, 2.4 when an UTF-8 locale is present. +# It looks like a bug in Python's gettext.py. This here is a quick workaround: +UTF8_LOCALE_UNSUPPORTED=yes + +cat <<\EOF > prog1.py +import gettext + +gettext.textdomain('prog') +gettext.bindtextdomain('prog', '.') + +print gettext.gettext("'Your command, please?', asked the waiter.") +print gettext.gettext("%(oldCurrency)s is replaced by %(newCurrency)s.") \ + % { 'oldCurrency': "FF", 'newCurrency' : "EUR" } +EOF + +: ${XGETTEXT=xgettext} +${XGETTEXT} -o prog.tmp --omit-header --no-location prog1.py || exit 1 +LC_ALL=C tr -d '\r' < prog.tmp > prog.pot || exit 1 + +cat <<EOF > prog.ok +msgid "'Your command, please?', asked the waiter." +msgstr "" + +#, python-format +msgid "%(oldCurrency)s is replaced by %(newCurrency)s." +msgstr "" +EOF + +: ${DIFF=diff} +${DIFF} prog.ok prog.pot || exit 1 + +cat <<\EOF > fr.po +msgid "" +msgstr "" +"Content-Type: text/plain; charset=ISO-8859-1\n" +"Plural-Forms: nplurals=2; plural=(n > 1);\n" + +msgid "'Your command, please?', asked the waiter." +msgstr "«Votre commande, s'il vous plait», dit le garçon." + +# Reverse the arguments. +#, python-format +msgid "%(oldCurrency)s is replaced by %(newCurrency)s." +msgstr "%(newCurrency)s remplace %(oldCurrency)s." +EOF + +: ${MSGMERGE=msgmerge} +${MSGMERGE} -q -o fr.po.tmp fr.po prog.pot || exit 1 +LC_ALL=C tr -d '\r' < fr.po.tmp > fr.po.new || exit 1 + +: ${DIFF=diff} +${DIFF} fr.po fr.po.new || exit 1 + +test -d fr || mkdir fr +test -d fr/LC_MESSAGES || mkdir fr/LC_MESSAGES + +: ${MSGFMT=msgfmt} +${MSGFMT} -o fr/LC_MESSAGES/prog.mo fr.po + +# Test for presence of python version 2.0 or newer. +(python -V) >/dev/null 2>/dev/null \ + || { echo "Skipping test: python not found"; exit 77; } +case `python -c 'import sys; print sys.hexversion >= 0x20000F0'` in + 1 | True) ;; + *) echo "Skipping test: python version too old"; exit 77;; +esac + +: ${DIFF=diff} +cat <<\EOF > prog.ok +«Votre commande, s'il vous plait», dit le garçon. +EUR remplace FF. +EOF +cat <<\EOF > prog.oku +«Votre commande, s'il vous plait», dit le garçon. +EUR remplace FF. +EOF + +: ${LOCALE_FR=fr_FR} +: ${LOCALE_FR_UTF8=fr_FR.UTF-8} +if test $LOCALE_FR != none; then + prepare_locale_ fr $LOCALE_FR + LANGUAGE= LC_ALL=$LOCALE_FR python prog1.py > prog.out || exit 1 + ${DIFF} prog.ok prog.out || exit 1 +fi +if test -z "$UTF8_LOCALE_UNSUPPORTED"; then + if test $LOCALE_FR_UTF8 != none; then + prepare_locale_ fr $LOCALE_FR_UTF8 + LANGUAGE= LC_ALL=$LOCALE_FR_UTF8 python prog1.py > prog.out || exit 1 + ${DIFF} prog.oku prog.out || exit 1 + fi + if test $LOCALE_FR = none && test $LOCALE_FR_UTF8 = none; then + if test -f /usr/bin/localedef; then + echo "Skipping test: no french locale is installed" + else + echo "Skipping test: no french locale is supported" + fi + exit 77 + fi +else + if test $LOCALE_FR = none; then + if test -f /usr/bin/localedef; then + echo "Skipping test: no traditional french locale is installed" + else + echo "Skipping test: no traditional french locale is supported" + fi + exit 77 + fi +fi + +exit 0 |