blob: 65b6c44586ee8a43681c38beb1619c1a0805a5b0 [file] [log] [blame] [edit]
#!/bin/bash
#
# Copyright 2017 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.
#
# --- begin runfiles.bash initialization ---
set -euo pipefail
if [[ ! -d "${RUNFILES_DIR:-/dev/null}" && ! -f "${RUNFILES_MANIFEST_FILE:-/dev/null}" ]]; then
if [[ -f "$0.runfiles_manifest" ]]; then
export RUNFILES_MANIFEST_FILE="$0.runfiles_manifest"
elif [[ -f "$0.runfiles/MANIFEST" ]]; then
export RUNFILES_MANIFEST_FILE="$0.runfiles/MANIFEST"
elif [[ -f "$0.runfiles/bazel_tools/tools/bash/runfiles/runfiles.bash" ]]; then
export RUNFILES_DIR="$0.runfiles"
fi
fi
if [[ -f "${RUNFILES_DIR:-/dev/null}/bazel_tools/tools/bash/runfiles/runfiles.bash" ]]; then
source "${RUNFILES_DIR}/bazel_tools/tools/bash/runfiles/runfiles.bash"
elif [[ -f "${RUNFILES_MANIFEST_FILE:-/dev/null}" ]]; then
source "$(grep -m1 "^bazel_tools/tools/bash/runfiles/runfiles.bash " \
"$RUNFILES_MANIFEST_FILE" | cut -d ' ' -f 2-)"
else
echo >&2 "ERROR: cannot find @bazel_tools//tools/bash/runfiles:runfiles.bash"
exit 1
fi
# --- end runfiles.bash initialization ---
source "$(rlocation "io_bazel/src/test/shell/integration_test_setup.sh")" \
|| { echo "integration_test_setup.sh not found!" >&2; exit 1; }
case "$(uname -s | tr [:upper:] [:lower:])" in
msys*|mingw*|cygwin*)
declare -r is_windows=true
;;
*)
declare -r is_windows=false
;;
esac
if "$is_windows"; then
export MSYS_NO_PATHCONV=1
export MSYS2_ARG_CONV_EXCL="*"
declare -r EXE_EXT=".exe"
else
declare -r EXE_EXT=""
fi
#### TESTS #############################################################
# Tests in this file cannot invoke a real Python 3 runtime. This is because this
# file is shared by both Bazel's public test suite and Google's internal tests,
# and the internal tests do not have a Python 3 environment.
#
# - If you only need a real Python 2 environment and do not use Python 3 at
# all, you can place your test in this file.
#
# - If you need to check Bazel's behavior concerning the *selection* of a
# Python 2 or 3 runtime, but do not actually need the runtime itself, then
# you may put your test in python_stub_test.sh (in this directory) instead.
#
# - Otherwise, put your test in //src/test/shell/bazel. That suite can invoke
# actual Python 2 and 3 interpreters.
# Python's import system distinguishes between "regular files" and other files
# in some cases (e.g. /dev/null). Here, we are trying to verify that a generated
# __init__.py file passes the isfile() check that the import logic performs and
# would fail for a "character device" (e.g. symlinked to /dev/null). For more
# info, see:
# * https://github.com/bazelbuild/bazel/issues/1458
# * https://github.com/bazelbuild/bazel/issues/2394
# * https://bugs.python.org/issue28425
function test_python_binary_empty_files_in_runfiles_are_regular_files() {
mkdir -p test/mypackage
cat > test/BUILD <<'EOF'
py_test(
name = "a",
srcs = [
"a.py",
"mypackage/b.py",
],
main = "a.py"
)
EOF
cat >test/a.py <<'EOF'
from __future__ import print_function
import os.path
import sys
print("This is my name: %s" % __file__)
print("This is my working directory: %s" % os.getcwd())
os.chdir(os.path.dirname(__file__))
print("This is my new working directory: %s" % os.getcwd())
file_to_check = "mypackage/__init__.py"
if not os.path.exists(file_to_check):
print("mypackage/__init__.py does not exist")
sys.exit(1)
# Symlinks to regular files are OK.
realpath = os.path.realpath(file_to_check)
print("{} realpath is: {}".format(file_to_check, realpath))
if not os.path.isfile(realpath):
print("mypackage/__init__.py is not a regular file")
sys.exit(1)
print("OK")
EOF
touch test/mypackage/b.py
bazel test --test_output=streamed //test:a &> $TEST_log || fail "test failed"
}
function test_building_transitive_py_binary_runfiles_trees() {
touch main.py script.sh
chmod u+x script.sh
cat > BUILD <<'EOF'
py_binary(
name = 'py-tool',
srcs = ['main.py'],
main = 'main.py',
)
sh_binary(
name = 'sh-tool',
srcs = ['script.sh'],
data = [':py-tool'],
)
EOF
# Stamping is disabled so that the invocation doesn't time out. What
# happens is Google has stamping enabled by default, which causes the
# Starlark rule implementation to run an action, which then tries to run
# remotely, but network access is disabled by default, so it times out.
# The upcoming Starlark implementation doesn't support this behavior.
# This feature is planned for removal.
# See https://github.com/bazelbuild/bazel/issues/16303
if [[ "$PRODUCT_NAME" == "bazel" ]]; then
bazel build --experimental_build_transitive_python_runfiles --nostamp :sh-tool
[ -d "bazel-bin/py-tool${EXE_EXT}.runfiles" ] || fail "py_binary runfiles tree not built"
bazel clean
fi
bazel build --noexperimental_build_transitive_python_runfiles --nostamp :sh-tool
[ ! -e "bazel-bin/py-tool${EXE_EXT}.runfiles" ] || fail "py_binary runfiles tree built"
}
run_suite "Tests for the Python rules"