diff options
author | 2018-03-21 07:45:38 -0700 | |
---|---|---|
committer | 2018-03-21 07:46:49 -0700 | |
commit | 339b5e4c021a348f7c50cb2b2aaba4bb01644402 (patch) | |
tree | 74931b32d171e8f93e3cdc1ddfebc736f3ec6b1d /src/main | |
parent | 9276164ea7388a8a55e11a2a2a3e02d9a631ffaf (diff) |
Add behavior to NestedSetCodec to prevent it from running during testing.
PiperOrigin-RevId: 189906038
Diffstat (limited to 'src/main')
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; + } +} |