From: Bruno Haible Date: Mon, 16 Dec 2024 19:07:38 +0000 (+0100) Subject: Ruby: Add unit test for Ruby support. X-Git-Tag: v0.24~102 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=9646d7ef813ecbf371d06197765c3624f0b56866;p=thirdparty%2Fgettext.git Ruby: Add unit test for Ruby support. * gettext-tools/tests/lang-ruby: New file. * gettext-tools/tests/Makefile.am (TESTS): Add it. --- diff --git a/gettext-tools/tests/Makefile.am b/gettext-tools/tests/Makefile.am index 93dcc311b..6437b14e1 100644 --- a/gettext-tools/tests/Makefile.am +++ b/gettext-tools/tests/Makefile.am @@ -218,6 +218,7 @@ TESTS = gettext-1 gettext-2 \ lang-csharp \ lang-javascript \ lang-guile lang-clisp lang-elisp lang-librep \ + lang-ruby \ lang-sh lang-bash \ lang-gawk \ lang-lua \ diff --git a/gettext-tools/tests/lang-ruby b/gettext-tools/tests/lang-ruby new file mode 100644 index 000000000..cbfd928c7 --- /dev/null +++ b/gettext-tools/tests/lang-ruby @@ -0,0 +1,117 @@ +#! /bin/sh +. "${srcdir=.}/init.sh"; path_prepend_ . ../src + +# Test of gettext facilities in the Ruby language. +# Assumes an fr_FR locale is installed. +# Assumes the following packages are installed: ruby, ruby-gettext. + +cat <<\EOF > prog.rb +require 'gettext' +include GetText + +bindtextdomain("prog", :path => ".") + +puts _("'Your command, please?', asked the waiter.") +puts _("%{old} is replaced by %{new}.") % { :old => "FF", :new => "EUR" } +EOF + +: ${XGETTEXT=xgettext} +${XGETTEXT} -o prog.tmp --omit-header --no-location prog.rb || 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 "" + +#, ruby-format +msgid "%{old} is replaced by %{new}." +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" + +msgid "'Your command, please?', asked the waiter." +msgstr "«Votre commande, s'il vous plait», dit le garçon." + +# Reverse the arguments. +#, ruby-format +msgid "%{old} is replaced by %{new}." +msgstr "%{new} remplace %{old}." +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 ruby with gettext support. +(ruby --version) >/dev/null 2>/dev/null \ + || { echo "Skipping test: ruby not found"; Exit 77; } +(echo "require 'gettext'" | ruby -) >/dev/null 2>/dev/null \ + || { echo "Skipping test: ruby's gettext support is not installed"; Exit 77; } + +# Test which of the fr_FR locales are installed. +: ${LOCALE_FR=fr_FR} +: ${LOCALE_FR_UTF8=fr_FR.UTF-8} +if test $LOCALE_FR != none; then + LC_ALL=$LOCALE_FR ../testlocale + case $? in + 0) ;; + 77) LOCALE_FR=none;; + *) Exit 1;; + esac +fi +if test $LOCALE_FR_UTF8 != none; then + LC_ALL=$LOCALE_FR_UTF8 ../testlocale + case $? in + 0) ;; + 77) LOCALE_FR_UTF8=none;; + *) Exit 1;; + esac +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 + +: ${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 ruby prog.rb > prog.out || Exit 1 + ${DIFF} prog.ok prog.out || Exit 1 +fi +if test $LOCALE_FR_UTF8 != none; then + prepare_locale_ fr $LOCALE_FR_UTF8 + LANGUAGE= LC_ALL=$LOCALE_FR_UTF8 ruby prog.rb > prog.out || Exit 1 + ${DIFF} prog.oku prog.out || Exit 1 +fi + +Exit 0