Squashed 'third_party/bazel-toolchain/' content from commit a912bb381
Change-Id: Ie1ff8ed3b3948cca1d1b6227097c95e5a048de86
git-subtree-dir: third_party/bazel-toolchain
git-subtree-split: a912bb381b36437be0eeb22de11f0ea198450b4e
Signed-off-by: Brian Silverman <bsilver16834@gmail.com>
diff --git a/tests/scripts/run_tests.sh b/tests/scripts/run_tests.sh
new file mode 100755
index 0000000..b411a08
--- /dev/null
+++ b/tests/scripts/run_tests.sh
@@ -0,0 +1,50 @@
+#!/bin/bash
+# Copyright 2018 The Bazel Authors.
+#
+# 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.
+
+set -euo pipefail
+
+toolchain_name=""
+
+while getopts "t:h" opt; do
+ case "$opt" in
+ "t") toolchain_name="$OPTARG";;
+ "h") echo "Usage:"
+ echo "-t - Toolchain name to use for testing; default is llvm_toolchain"
+ exit 2
+ ;;
+ "?") echo "invalid option: -$OPTARG"; exit 1;;
+ esac
+done
+
+source "$(dirname "${BASH_SOURCE[0]}")/bazel.sh"
+"${bazel}" version
+
+set -x
+test_args=(
+ --extra_toolchains="${toolchain_name}"
+ --copt=-v
+ --linkopt=-Wl,-t
+)
+if [[ "${TEST_MIGRATION:-}" ]]; then
+ # We can not use bazelisk to test migration because bazelisk does not allow
+ # us to selectively ignore a migration flag.
+ test_args+=("--all_incompatible_changes")
+ # This flag is not quite ready -- https://github.com/bazelbuild/bazel/issues/7347
+ test_args+=("--incompatible_disallow_struct_provider_syntax=false")
+ # the rules_rust repo included in the WORKSPACE is currently incompatible with
+ # '--incompatible_no_rule_outputs_param=true', setting this to false for now.
+ test_args+=("--incompatible_no_rule_outputs_param=false")
+fi
+"${bazel}" --bazelrc=/dev/null test "${common_test_args[@]}" "${test_args[@]}" //tests:all