From d4cc4b6fec1d4a6c2f478628a8a985bcf6502253 Mon Sep 17 00:00:00 2001 From: vladmos Date: Fri, 14 Jul 2017 19:04:55 +0200 Subject: Clean up string representations for unknown objects Don't call the `toString` method on unknown objects as it potentially breaks hermeticity and determinism. Use a generic string like "" instead. PiperOrigin-RevId: 161970449 --- .../lib/skylark/SkylarkStringRepresentationsTest.java | 11 +++++++++++ .../devtools/build/lib/syntax/EvaluationTest.java | 19 ++++++------------- 2 files changed, 17 insertions(+), 13 deletions(-) (limited to 'src/test/java') diff --git a/src/test/java/com/google/devtools/build/lib/skylark/SkylarkStringRepresentationsTest.java b/src/test/java/com/google/devtools/build/lib/skylark/SkylarkStringRepresentationsTest.java index 82e2dfed90..8db33169eb 100644 --- a/src/test/java/com/google/devtools/build/lib/skylark/SkylarkStringRepresentationsTest.java +++ b/src/test/java/com/google/devtools/build/lib/skylark/SkylarkStringRepresentationsTest.java @@ -388,6 +388,17 @@ public class SkylarkStringRepresentationsTest extends SkylarkTestCase { } } + @Test + public void testStringRepresentationsOfUnknownObjects() throws Exception { + update("mock", new Object()); + + assertThat(eval("str(mock)")).isEqualTo(""); + assertThat(eval("repr(mock)")).isEqualTo(""); + assertThat(eval("'{}'.format(mock)")).isEqualTo(""); + assertThat(eval("'%s' % mock")).isEqualTo(""); + assertThat(eval("'%r' % mock")).isEqualTo(""); + } + @Test public void testLegacyStringRepresentations_Labels() throws Exception { setSkylarkSemanticsOptions("--incompatible_descriptive_string_representations=false"); diff --git a/src/test/java/com/google/devtools/build/lib/syntax/EvaluationTest.java b/src/test/java/com/google/devtools/build/lib/syntax/EvaluationTest.java index 53fdcaae23..057af394dd 100644 --- a/src/test/java/com/google/devtools/build/lib/syntax/EvaluationTest.java +++ b/src/test/java/com/google/devtools/build/lib/syntax/EvaluationTest.java @@ -618,15 +618,6 @@ public class EvaluationTest extends EvaluationTestCase { }; } - private Object createUnknownObj() { - return new Object() { - @Override - public String toString() { - return ""; - } - }; - } - @Test public void testPercOnObject() throws Exception { newTest("--incompatible_descriptive_string_representations=true") @@ -636,8 +627,8 @@ public class EvaluationTest extends EvaluationTestCase { .update("obj", createObjWithStr()) .testStatement("'%s' % obj", ""); newTest() - .update("unknown", createUnknownObj()) - .testStatement("'%s' % unknown", ""); + .update("unknown", new Object()) + .testStatement("'%s' % unknown", ""); } @Test @@ -649,8 +640,10 @@ public class EvaluationTest extends EvaluationTestCase { .update("obj", createObjWithStr()) .testStatement("'%s %s' % (obj, obj)", " "); newTest() - .update("unknown", createUnknownObj()) - .testStatement("'%s %s' % (unknown, unknown)", " "); + .update("unknown", new Object()) + .testStatement( + "'%s %s' % (unknown, unknown)", + " "); } @Test -- cgit v1.2.3