aboutsummaryrefslogtreecommitdiff
path: root/src/ProtocolBuffers.Test
diff options
context:
space:
mode:
authorJon Skeet <skeet@pobox.com>2009-05-11 19:42:18 +0100
committerJon Skeet <skeet@pobox.com>2009-05-11 19:42:18 +0100
commitd33bff04b3efb651ff0ec53a5fa35e406b41db6f (patch)
tree9cd8339a10e714e0bfae443a10118c87340580e6 /src/ProtocolBuffers.Test
parent7a66a6d3f4e2bb7dadb8415a79b2f540e9d23524 (diff)
downloadprotobuf-d33bff04b3efb651ff0ec53a5fa35e406b41db6f.tar.gz
protobuf-d33bff04b3efb651ff0ec53a5fa35e406b41db6f.tar.bz2
protobuf-d33bff04b3efb651ff0ec53a5fa35e406b41db6f.zip
Fixed i18n issues with numbers
Diffstat (limited to 'src/ProtocolBuffers.Test')
-rw-r--r--src/ProtocolBuffers.Test/GeneratedMessageTest.cs12
-rw-r--r--src/ProtocolBuffers.Test/TestUtil.cs16
-rw-r--r--src/ProtocolBuffers.Test/TextFormatTest.cs16
3 files changed, 35 insertions, 9 deletions
diff --git a/src/ProtocolBuffers.Test/GeneratedMessageTest.cs b/src/ProtocolBuffers.Test/GeneratedMessageTest.cs
index 610078f2..ecf07b6a 100644
--- a/src/ProtocolBuffers.Test/GeneratedMessageTest.cs
+++ b/src/ProtocolBuffers.Test/GeneratedMessageTest.cs
@@ -228,8 +228,10 @@ namespace Google.ProtocolBuffers {
[Test]
public void ReflectionDefaults() {
- reflectionTester.AssertClearViaReflection(TestAllTypes.DefaultInstance);
- reflectionTester.AssertClearViaReflection(TestAllTypes.CreateBuilder().Build());
+ TestUtil.TestInMultipleCultures(() => {
+ reflectionTester.AssertClearViaReflection(TestAllTypes.DefaultInstance);
+ reflectionTester.AssertClearViaReflection(TestAllTypes.CreateBuilder().Build());
+ });
}
// =================================================================
// Extensions.
@@ -296,8 +298,10 @@ namespace Google.ProtocolBuffers {
[Test]
public void ExtensionReflectionDefaults() {
- extensionsReflectionTester.AssertClearViaReflection(TestAllExtensions.DefaultInstance);
- extensionsReflectionTester.AssertClearViaReflection(TestAllExtensions.CreateBuilder().Build());
+ TestUtil.TestInMultipleCultures(() => {
+ extensionsReflectionTester.AssertClearViaReflection(TestAllExtensions.DefaultInstance);
+ extensionsReflectionTester.AssertClearViaReflection(TestAllExtensions.CreateBuilder().Build());
+ });
}
[Test]
diff --git a/src/ProtocolBuffers.Test/TestUtil.cs b/src/ProtocolBuffers.Test/TestUtil.cs
index 3e89dd75..84756397 100644
--- a/src/ProtocolBuffers.Test/TestUtil.cs
+++ b/src/ProtocolBuffers.Test/TestUtil.cs
@@ -31,10 +31,12 @@
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
using System;
using System.Collections.Generic;
+using System.Globalization;
using System.IO;
using System.Text;
using Google.ProtocolBuffers.TestProtos;
using NUnit.Framework;
+using System.Threading;
namespace Google.ProtocolBuffers {
internal static class TestUtil {
@@ -1577,6 +1579,20 @@ namespace Google.ProtocolBuffers {
}
return goldenPackedFieldsMessage;
}
+
+ private static readonly string[] TestCultures = { "en-US", "en-GB", "fr-FR", "de-DE" };
+
+ public static void TestInMultipleCultures(Action test) {
+ CultureInfo originalCulture = Thread.CurrentThread.CurrentCulture;
+ foreach (string culture in TestCultures) {
+ try {
+ Thread.CurrentThread.CurrentCulture = new CultureInfo(culture);
+ test();
+ } finally {
+ Thread.CurrentThread.CurrentCulture = originalCulture;
+ }
+ }
+ }
/// <summary>
/// Helper to construct a byte array from a bunch of bytes.
diff --git a/src/ProtocolBuffers.Test/TextFormatTest.cs b/src/ProtocolBuffers.Test/TextFormatTest.cs
index a8e0de4d..d0664a0c 100644
--- a/src/ProtocolBuffers.Test/TextFormatTest.cs
+++ b/src/ProtocolBuffers.Test/TextFormatTest.cs
@@ -34,6 +34,8 @@ using System.IO;
using System.Text;
using Google.ProtocolBuffers.TestProtos;
using NUnit.Framework;
+using System.Globalization;
+using System.Threading;
namespace Google.ProtocolBuffers {
[TestFixture]
@@ -82,8 +84,10 @@ namespace Google.ProtocolBuffers {
/// </summary>
[Test]
public void PrintMessage() {
- string text = TextFormat.PrintToString(TestUtil.GetAllSet());
- Assert.AreEqual(AllFieldsSetText.Replace("\r\n", "\n"), text.Replace("\r\n", "\n"));
+ TestUtil.TestInMultipleCultures(() => {
+ string text = TextFormat.PrintToString(TestUtil.GetAllSet());
+ Assert.AreEqual(AllFieldsSetText.Replace("\r\n", "\n"), text.Replace("\r\n", "\n"));
+ });
}
/// <summary>
@@ -213,9 +217,11 @@ namespace Google.ProtocolBuffers {
[Test]
public void Parse() {
- TestAllTypes.Builder builder = TestAllTypes.CreateBuilder();
- TextFormat.Merge(AllFieldsSetText, builder);
- TestUtil.AssertAllFieldsSet(builder.Build());
+ TestUtil.TestInMultipleCultures(() => {
+ TestAllTypes.Builder builder = TestAllTypes.CreateBuilder();
+ TextFormat.Merge(AllFieldsSetText, builder);
+ TestUtil.AssertAllFieldsSet(builder.Build());
+ });
}
[Test]