aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/main
diff options
context:
space:
mode:
authorGravatar cpeyser <cpeyser@google.com>2018-03-21 07:45:38 -0700
committerGravatar Copybara-Service <copybara-piper@google.com>2018-03-21 07:46:49 -0700
commit339b5e4c021a348f7c50cb2b2aaba4bb01644402 (patch)
tree74931b32d171e8f93e3cdc1ddfebc736f3ec6b1d /src/main
parent9276164ea7388a8a55e11a2a2a3e02d9a631ffaf (diff)
Add behavior to NestedSetCodec to prevent it from running during testing.
PiperOrigin-RevId: 189906038
Diffstat (limited to 'src/main')
-rw-r--r--src/main/java/com/google/devtools/build/lib/collect/nestedset/NestedSetCodec.java11
-rw-r--r--src/main/java/com/google/devtools/build/lib/skyframe/serialization/SerializationConstants.java47
2 files changed, 58 insertions, 0 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/collect/nestedset/NestedSetCodec.java b/src/main/java/com/google/devtools/build/lib/collect/nestedset/NestedSetCodec.java
index 255456139a..a4954ab740 100644
--- a/src/main/java/com/google/devtools/build/lib/collect/nestedset/NestedSetCodec.java
+++ b/src/main/java/com/google/devtools/build/lib/collect/nestedset/NestedSetCodec.java
@@ -19,6 +19,7 @@ import com.google.common.hash.HashingOutputStream;
import com.google.devtools.build.lib.skyframe.serialization.DeserializationContext;
import com.google.devtools.build.lib.skyframe.serialization.EnumCodec;
import com.google.devtools.build.lib.skyframe.serialization.ObjectCodec;
+import com.google.devtools.build.lib.skyframe.serialization.SerializationConstants;
import com.google.devtools.build.lib.skyframe.serialization.SerializationContext;
import com.google.devtools.build.lib.skyframe.serialization.SerializationException;
import com.google.protobuf.ByteString;
@@ -54,6 +55,11 @@ public class NestedSetCodec<T> implements ObjectCodec<NestedSet<T>> {
@Override
public void serialize(SerializationContext context, NestedSet<T> obj, CodedOutputStream codedOut)
throws SerializationException, IOException {
+ if (!SerializationConstants.shouldSerializeNestedSet) {
+ // Don't perform NestedSet serialization in testing
+ return;
+ }
+
// Topo sort the nested set to ensure digests are available for children at time of writing
Collection<Object> topoSortedChildren = getTopologicallySortedChildren(obj);
Map<Object, byte[]> childToDigest = new IdentityHashMap<>();
@@ -67,6 +73,11 @@ public class NestedSetCodec<T> implements ObjectCodec<NestedSet<T>> {
@Override
public NestedSet<T> deserialize(DeserializationContext context, CodedInputStream codedIn)
throws SerializationException, IOException {
+ if (!SerializationConstants.shouldSerializeNestedSet) {
+ // Don't perform NestedSet deserialization in testing
+ return NestedSetBuilder.emptySet(Order.STABLE_ORDER);
+ }
+
Map<ByteString, Object> digestToChild = new HashMap<>();
int nestedSetCount = codedIn.readInt32();
Preconditions.checkState(
diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/serialization/SerializationConstants.java b/src/main/java/com/google/devtools/build/lib/skyframe/serialization/SerializationConstants.java
new file mode 100644
index 0000000000..e3886dd276
--- /dev/null
+++ b/src/main/java/com/google/devtools/build/lib/skyframe/serialization/SerializationConstants.java
@@ -0,0 +1,47 @@
+// Copyright 2018 The Bazel Authors. All rights reserved.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package com.google.devtools.build.lib.skyframe.serialization;
+
+/**
+ * Some static constants for deciding serialization behavior.
+ */
+public class SerializationConstants {
+
+ /**
+ * If true, we attempt to to serialize ConfiguredTargetValue in testing.
+ */
+ public static final boolean VALIDATE_CONFIGURED_TARGET_VALUE =
+ System.getenv("DONT_VALIDATE_CONFIGURED_TARGET_VALUE") == null;
+
+ private static final boolean IN_TEST = System.getenv("TEST_TMPDIR") != null;
+ private static final boolean CHECK_SERIALIZATION =
+ System.getenv("DONT_SANITY_CHECK_SERIALIZATION") == null;
+
+ private static final boolean TEST_NESTED_SET_SERIALIZATION =
+ System.getenv("TEST_NESTED_SET_SERIALIZATION") != null;
+
+ /**
+ * If true, serialization should include NestedSet. Non-final so tests can opt-in to NestedSet
+ * serialization.
+ */
+ public static boolean shouldSerializeNestedSet = TEST_NESTED_SET_SERIALIZATION || !IN_TEST;
+
+ /**
+ * Returns true if serialization should be validated on all Skyframe writes.
+ */
+ public static boolean shouldCheckSerializationBecauseInTest() {
+ return IN_TEST && CHECK_SERIALIZATION;
+ }
+}