blob: 9ed11f3d6878a55a7a018461ae6200c6c443b79c [file] [log] [blame]
// Copyright 2015 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.pkgcache;
import com.google.devtools.build.lib.packages.TestSize;
import com.google.devtools.build.lib.packages.TestTimeout;
import com.google.devtools.common.options.Converter;
import com.google.devtools.common.options.Converters.CommaSeparatedOptionListConverter;
import com.google.devtools.common.options.Option;
import com.google.devtools.common.options.OptionsBase;
import com.google.devtools.common.options.OptionsParsingException;
import java.util.List;
import java.util.Set;
/**
* Options that affect how command-line target patterns are resolved to individual targets.
*/
public class LoadingOptions extends OptionsBase {
@Option(name = "loading_phase_threads",
defaultValue = "-1",
category = "undocumented",
converter = LoadingPhaseThreadCountConverter.class,
help = "Number of parallel threads to use for the loading phase.")
public int loadingPhaseThreads;
@Option(name = "build_tests_only",
defaultValue = "false",
category = "what",
help = "If specified, only *_test and test_suite rules will be built "
+ "and other targets specified on the command line will be ignored. "
+ "By default everything that was requested will be built.")
public boolean buildTestsOnly;
@Option(name = "compile_one_dependency",
defaultValue = "false",
category = "what",
help = "Compile a single dependency of the argument files. "
+ "This is useful for syntax checking source files in IDEs, "
+ "for example, by rebuilding a single target that depends on "
+ "the source file to detect errors as early as possible in the "
+ "edit/build/test cycle. This argument affects the way all "
+ "non-flag arguments are interpreted; instead of being targets "
+ "to build they are source filenames. For each source filename "
+ "an arbitrary target that depends on it will be built.")
public boolean compileOneDependency;
@Option(name = "test_tag_filters",
converter = CommaSeparatedOptionListConverter.class,
defaultValue = "",
category = "what",
help = "Specifies a comma-separated list of test tags. Each tag can be optionally " +
"preceded with '-' to specify excluded tags. Only those test targets will be " +
"found that contain at least one included tag and do not contain any excluded " +
"tags. This option affects --build_tests_only behavior and the test command."
)
public List<String> testTagFilterList;
@Option(name = "test_size_filters",
converter = TestSize.TestSizeFilterConverter.class,
defaultValue = "",
category = "what",
help = "Specifies a comma-separated list of test sizes. Each size can be optionally " +
"preceded with '-' to specify excluded sizes. Only those test targets will be " +
"found that contain at least one included size and do not contain any excluded " +
"sizes. This option affects --build_tests_only behavior and the test command."
)
public Set<TestSize> testSizeFilterSet;
@Option(name = "test_timeout_filters",
converter = TestTimeout.TestTimeoutFilterConverter.class,
defaultValue = "",
category = "what",
help = "Specifies a comma-separated list of test timeouts. Each timeout can be " +
"optionally preceded with '-' to specify excluded timeouts. Only those test " +
"targets will be found that contain at least one included timeout and do not " +
"contain any excluded timeouts. This option affects --build_tests_only behavior " +
"and the test command."
)
public Set<TestTimeout> testTimeoutFilterSet;
@Option(name = "test_lang_filters",
converter = CommaSeparatedOptionListConverter.class,
defaultValue = "",
category = "what",
help = "Specifies a comma-separated list of test languages. Each language can be " +
"optionally preceded with '-' to specify excluded languages. Only those " +
"test targets will be found that are written in the specified languages. " +
"The name used for each language should be the same as the language prefix in the " +
"*_test rule, e.g. one of 'cc', 'java', 'py', etc." +
"This option affects --build_tests_only behavior and the test command."
)
public List<String> testLangFilterList;
// If this option is set, the value of experimental_interleave_loading_and_analysis is completely
// ignored. This enables a different LoadingPhaseRunner implementation which doesn't implement
// the loading phase at all, and therefore can't currently support the other flag. If we roll this
// out soonish, then we're never going to implement the legacy code path in the new
// implementation, making it a moot point.
@Option(name = "experimental_skyframe_target_pattern_evaluator",
defaultValue = "false",
category = "hidden",
help = "Use the Skyframe-based target pattern evaluator; implies "
+ "--experimental_interleave_loading_and_analysis.")
public boolean useSkyframeTargetPatternEvaluator;
/**
* A converter for loading phase thread count. Since the default is not a true constant, we
* create a converter here to implement the default logic.
*/
public static final class LoadingPhaseThreadCountConverter implements Converter<Integer> {
@Override
public Integer convert(String input) throws OptionsParsingException {
if ("-1".equals(input)) {
// Reduce thread count while running tests. Test cases are typically small, and large thread
// pools vying for a relatively small number of CPU cores may induce non-optimal
// performance.
return System.getenv("TEST_TMPDIR") == null ? 200 : 5;
}
try {
return Integer.decode(input);
} catch (NumberFormatException e) {
throw new OptionsParsingException("'" + input + "' is not an int");
}
}
@Override
public String getTypeDescription() {
return "an integer";
}
}
}