From: Bruno Haible Date: Thu, 8 Jan 2004 11:49:04 +0000 (+0000) Subject: Integration test for C#. X-Git-Tag: v0.14~82 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d37a00de068f8aa624b60b6401bae95d43cf4e44;p=thirdparty%2Fgettext.git Integration test for C#. --- diff --git a/gettext-tools/tests/lang-csharp b/gettext-tools/tests/lang-csharp new file mode 100755 index 000000000..e05cc2fbf --- /dev/null +++ b/gettext-tools/tests/lang-csharp @@ -0,0 +1,124 @@ +#! /bin/sh + +# Test of gettext facilities in the C# language. +# Assumes an fr_FR locale is installed. +# Assumes the following packages are installed: pnet, pnetlib. + +# Note: This test fails with mono-0.28 because the CultureInfo.Parent pointers +# are wrong for locales containing a language and a territory. + +tmpfiles="" +trap 'rm -fr $tmpfiles' 1 2 3 15 + +# Test whether we can build and test C# programs. +test "${TESTCSHARP}" = yes || exit 77 + +tmpfiles="$tmpfiles program.cs" +cat <<\EOF > program.cs +using System; +using GNU.Gettext; +class Program { + static void Main (String[] args) { +#if not_yet_needed + // Some systems don't set CurrentCulture and CurrentUICulture as specified + // by LC_ALL. So set it by hand. + System.Threading.Thread.CurrentThread.CurrentCulture = + System.Threading.Thread.CurrentThread.CurrentUICulture = + new System.Globalization.CultureInfo("fr-FR"); +#endif + int n = Int32.Parse(args[0]); + GettextResourceManager catalog = new GettextResourceManager("prog"); + Console.WriteLine(catalog.GetString("'Your command, please?', asked the waiter.")); + Console.WriteLine(String.Format(catalog.GetPluralString("a piece of cake","{0} pieces of cake",n), n)); + Console.WriteLine(String.Format(catalog.GetString("{0} is replaced by {1}."), "FF", "EUR")); + } +} +EOF + +tmpfiles="$tmpfiles program.exe" +: ${CSHARPCOMP="/bin/sh ../lib/csharpcomp.sh"} +${CSHARPCOMP} -o program.exe -L ../../gettext-runtime/intl-csharp -l GNU.Gettext program.cs || exit 1 + +tmpfiles="$tmpfiles prog.pot" +: ${XGETTEXT=xgettext} +${XGETTEXT} -o prog.pot --omit-header --no-location program.cs + +tmpfiles="$tmpfiles prog.ok" +cat < prog.ok +msgid "'Your command, please?', asked the waiter." +msgstr "" + +#, csharp-format +msgid "a piece of cake" +msgid_plural "{0} pieces of cake" +msgstr[0] "" +msgstr[1] "" + +#, csharp-format +msgid "{0} is replaced by {1}." +msgstr "" +EOF + +: ${DIFF=diff} +${DIFF} prog.ok prog.pot || exit 1 + +tmpfiles="$tmpfiles fr.po" +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." + +# Les gateaux allemands sont les meilleurs du monde. +#, csharp-format +msgid "a piece of cake" +msgid_plural "{0} pieces of cake" +msgstr[0] "un morceau de gateau" +msgstr[1] "{0} morceaux de gateau" + +# Reverse the arguments. +#, csharp-format +msgid "{0} is replaced by {1}." +msgstr "{1} remplace {0}." +EOF + +tmpfiles="$tmpfiles fr.po.new" +: ${MSGMERGE=msgmerge} +${MSGMERGE} -q -o fr.po.new fr.po prog.pot + +: ${DIFF=diff} +${DIFF} fr.po fr.po.new || exit 1 + +tmpfiles="$tmpfiles fr/prog.dll" +: ${MSGFMT=msgfmt} +GETTEXTCSHARPLIBDIR=../../gettext-runtime/intl-csharp \ +${MSGFMT} --csharp -d . -r prog -l fr fr.po || exit 1 + +# Test whether the fr_FR locale is installed. +: ${LOCALE_FR=fr_FR} +LC_ALL=$LOCALE_FR ./testlocale +case $? in + 0) ;; + 77) rm -fr $tmpfiles; exit 77;; + *) exit 1;; +esac + +tmpfiles="$tmpfiles prog.ok prog.out" +: ${DIFF=diff} +cat <<\EOF > prog.ok +«Votre commande, s'il vous plait», dit le garçon. +2 morceaux de gateau +EUR remplace FF. +EOF + +: ${LOCALE_FR=fr_FR} +: ${CSHARPEXEC="/bin/sh ../lib/csharpexec.sh"} +LANGUAGE= LC_ALL=$LOCALE_FR ${CSHARPEXEC} -L ../../gettext-runtime/intl-csharp program.exe 2 > prog.out || exit 1 +${DIFF} prog.ok prog.out || exit 1 + +rm -fr $tmpfiles + +exit 0