diff --git a/context/src/main/java/io/grpc/Deadline.java b/context/src/main/java/io/grpc/Deadline.java index c7b50e0929..73c8760595 100644 --- a/context/src/main/java/io/grpc/Deadline.java +++ b/context/src/main/java/io/grpc/Deadline.java @@ -17,6 +17,7 @@ package io.grpc; import java.util.Arrays; +import java.util.Locale; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.ScheduledFuture; import java.util.concurrent.TimeUnit; @@ -206,7 +207,7 @@ public final class Deadline implements Comparable { } buf.append(seconds); if (nanos > 0) { - buf.append(String.format(".%09d", nanos)); + buf.append(String.format(Locale.US, ".%09d", nanos)); } buf.append("s from now"); if (ticker != SYSTEM_TICKER) { diff --git a/core/src/main/java/io/grpc/internal/ClientCallImpl.java b/core/src/main/java/io/grpc/internal/ClientCallImpl.java index 3c3a222778..86ec0575ad 100644 --- a/core/src/main/java/io/grpc/internal/ClientCallImpl.java +++ b/core/src/main/java/io/grpc/internal/ClientCallImpl.java @@ -54,6 +54,7 @@ import io.perfmark.PerfMark; import io.perfmark.Tag; import java.io.InputStream; import java.nio.charset.Charset; +import java.util.Locale; import java.util.concurrent.CancellationException; import java.util.concurrent.Executor; import java.util.concurrent.ScheduledExecutorService; @@ -441,7 +442,7 @@ final class ClientCallImpl extends ClientCall { buf.append('-'); } buf.append(seconds); - buf.append(String.format(".%09d", nanos)); + buf.append(String.format(Locale.US, ".%09d", nanos)); buf.append("s. "); buf.append(insight); stream.cancel(DEADLINE_EXCEEDED.augmentDescription(buf.toString())); diff --git a/core/src/main/java/io/grpc/internal/DelayedClientCall.java b/core/src/main/java/io/grpc/internal/DelayedClientCall.java index c3d3823ed1..41f672af34 100644 --- a/core/src/main/java/io/grpc/internal/DelayedClientCall.java +++ b/core/src/main/java/io/grpc/internal/DelayedClientCall.java @@ -30,6 +30,7 @@ import io.grpc.Metadata; import io.grpc.Status; import java.util.ArrayList; import java.util.List; +import java.util.Locale; import java.util.concurrent.Executor; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.ScheduledFuture; @@ -117,7 +118,7 @@ class DelayedClientCall extends ClientCall { buf.append("Deadline exceeded after "); } buf.append(seconds); - buf.append(String.format(".%09d", nanos)); + buf.append(String.format(Locale.US, ".%09d", nanos)); buf.append("s. "); /** Cancels the call if deadline exceeded prior to the real call being set. */ class DeadlineExceededRunnable implements Runnable {