#!/usr/bin/env bash # Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information # regarding copyright ownership. The ASF licenses this file # to you 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 -e # place ourselves in the directory containing the hbase and yetus checkouts cd "$(dirname "$0")/../.." echo "executing from $(pwd)" if [[ "true" = "${DEBUG}" ]]; then set -x printenv 2>&1 | sort fi declare -i missing_env=0 declare -a required_envs=( # these ENV variables define the required API with Jenkinsfile_GitHub "ARCHIVE_PATTERN_LIST" "BUILD_URL_ARTIFACTS" "DOCKERFILE" "GITHUB_PASSWORD" "GITHUB_USER" "PATCHDIR" "PLUGINS" "SET_JAVA_HOME" "SOURCEDIR" "TESTS_FILTER" "YETUSDIR" ) # Validate params for required_env in "${required_envs[@]}"; do if [ -z "${!required_env}" ]; then echo "[ERROR] Required environment variable '${required_env}' is not set." missing_env=${missing_env}+1 fi done if [ ${missing_env} -gt 0 ]; then echo "[ERROR] Please set the required environment variables before invoking. If this error is " \ "on Jenkins, then please file a JIRA about the error." exit 1 fi # TODO (HBASE-23900): cannot assume test-patch runs directly from sources TESTPATCHBIN="${YETUSDIR}/precommit/src/main/shell/test-patch.sh" # this must be clean for every run rm -rf "${PATCHDIR}" mkdir -p "${PATCHDIR}" # Checking on H* machine nonsense mkdir "${PATCHDIR}/machine" "${SOURCEDIR}/dev-support/gather_machine_environment.sh" "${PATCHDIR}/machine" # If CHANGE_URL is set (e.g., Github Branch Source plugin), process it. # Otherwise exit, because we don't want HBase to do a # full build. We wouldn't normally do this check for smaller # projects. :) if [[ -z "${CHANGE_URL}" ]]; then echo "Full build skipped" > "${PATCHDIR}/report.html" exit 0 fi # enable debug output for yetus if [[ "true" = "${DEBUG}" ]]; then YETUS_ARGS+=("--debug") fi # If we're doing docker, make sure we don't accidentally pollute the image with a host java path if [ -n "${JAVA_HOME}" ]; then unset JAVA_HOME fi YETUS_ARGS+=("--ignore-unknown-options=true") YETUS_ARGS+=("--patch-dir=${PATCHDIR}") # where the source is located YETUS_ARGS+=("--basedir=${SOURCEDIR}") # our project defaults come from a personality file # which will get loaded automatically by setting the project name YETUS_ARGS+=("--project=hbase") # lots of different output formats YETUS_ARGS+=("--brief-report-file=${PATCHDIR}/brief.txt") YETUS_ARGS+=("--console-report-file=${PATCHDIR}/console.txt") YETUS_ARGS+=("--html-report-file=${PATCHDIR}/report.html") # enable writing back to Github YETUS_ARGS+=("--github-password=${GITHUB_PASSWORD}") YETUS_ARGS+=("--github-user=${GITHUB_USER}") # auto-kill any surefire stragglers during unit test runs YETUS_ARGS+=("--reapermode=kill") # set relatively high limits for ASF machines # changing these to higher values may cause problems # with other jobs on systemd-enabled machines YETUS_ARGS+=("--dockermemlimit=20g") # -1 spotbugs issues that show up prior to the patch being applied YETUS_ARGS+=("--spotbugs-strict-precheck") # rsync these files back into the archive dir YETUS_ARGS+=("--archive-list=${ARCHIVE_PATTERN_LIST}") # URL for user-side presentation in reports and such to our artifacts YETUS_ARGS+=("--build-url-artifacts=${BUILD_URL_ARTIFACTS}") # plugins to enable YETUS_ARGS+=("--plugins=${PLUGINS},-findbugs") # run in docker mode and specifically point to our # Dockerfile since we don't want to use the auto-pulled version. YETUS_ARGS+=("--docker") YETUS_ARGS+=("--dockerfile=${DOCKERFILE}") YETUS_ARGS+=("--mvn-custom-repos") YETUS_ARGS+=("--java-home=${SET_JAVA_HOME}") YETUS_ARGS+=("--whitespace-eol-ignore-list=.*/generated/.*") YETUS_ARGS+=("--whitespace-tabs-ignore-list=.*/generated/.*") YETUS_ARGS+=("--tests-filter=${TESTS_FILTER}") YETUS_ARGS+=("--personality=${SOURCEDIR}/dev-support/hbase-personality.sh") YETUS_ARGS+=("--quick-hadoopcheck") if [[ "${SKIP_ERRORPRONE}" = "true" ]]; then # skip error prone YETUS_ARGS+=("--skip-errorprone") fi # effectively treat dev-support as a custom maven module YETUS_ARGS+=("--skip-dirs=dev-support") # For testing with specific hadoop version. Activates corresponding profile in maven runs. if [[ -n "${HADOOP_PROFILE}" ]]; then # Master has only Hadoop3 support. We don't need to activate any profile. # The Jenkinsfile should not attempt to run any Hadoop2 tests. if [[ "${BRANCH_NAME}" =~ branch-2* ]]; then YETUS_ARGS+=("--hadoop-profile=${HADOOP_PROFILE}") fi fi if [[ -n "${EXCLUDE_TESTS_URL}" ]]; then YETUS_ARGS+=("--exclude-tests-url=${EXCLUDE_TESTS_URL}") fi # help keep the ASF boxes clean YETUS_ARGS+=("--sentinel") # use emoji vote so it is easier to find the broken line YETUS_ARGS+=("--github-use-emoji-vote") echo "Launching yetus with command line:" echo "${TESTPATCHBIN} ${YETUS_ARGS[*]}" /usr/bin/env bash "${TESTPATCHBIN}" "${YETUS_ARGS[@]}"