2015-01-12 21:46:10 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
2015-05-01 16:19:44 +00:00
|
|
|
# Copyright 2015 The Kubernetes Authors All rights reserved.
|
2015-01-12 21:46:10 +00:00
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
2015-12-30 22:39:31 +00:00
|
|
|
# Sets up environment variables for an e2e test specified in JOB_NAME, then
|
|
|
|
# runs e2e-runner.sh.
|
2015-01-12 21:46:10 +00:00
|
|
|
|
|
|
|
set -o errexit
|
|
|
|
set -o nounset
|
|
|
|
set -o pipefail
|
|
|
|
|
2015-07-15 06:50:09 +00:00
|
|
|
# Join all args with |
|
2015-07-23 11:30:01 +00:00
|
|
|
# Example: join_regex_allow_empty a b "c d" e => a|b|c d|e
|
|
|
|
function join_regex_allow_empty() {
|
2015-07-15 06:50:09 +00:00
|
|
|
local IFS="|"
|
|
|
|
echo "$*"
|
|
|
|
}
|
|
|
|
|
2015-07-23 11:30:01 +00:00
|
|
|
# Join all args with |, butin case of empty result prints "EMPTY\sSET" instead.
|
|
|
|
# Example: join_regex_no_empty a b "c d" e => a|b|c d|e
|
|
|
|
# join_regex_no_empty => EMPTY\sSET
|
|
|
|
function join_regex_no_empty() {
|
|
|
|
local IFS="|"
|
|
|
|
if [ -z "$*" ]; then
|
|
|
|
echo "EMPTY\sSET"
|
|
|
|
else
|
|
|
|
echo "$*"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2015-11-25 00:16:00 +00:00
|
|
|
# Properly configure globals for an upgrade step in a GKE or GCE upgrade suite
|
|
|
|
#
|
|
|
|
# These suites:
|
|
|
|
# step1: launch a cluster at $old_version,
|
2015-12-08 23:32:08 +00:00
|
|
|
# step2: runs $new_version Kubectl e2es,
|
|
|
|
# step3: upgrades the master to $new_version,
|
|
|
|
# step4: runs $old_version e2es,
|
|
|
|
# step5: upgrades the rest of the cluster,
|
|
|
|
# step6: runs $old_version e2es again, then
|
|
|
|
# step7: runs $new_version e2es and tears down the cluster.
|
2015-11-25 00:16:00 +00:00
|
|
|
#
|
|
|
|
# Assumes globals:
|
|
|
|
# $JOB_NAME
|
|
|
|
# $KUBERNETES_PROVIDER
|
|
|
|
# $GKE_DEFAULT_SKIP_TESTS
|
|
|
|
# $GCE_DEFAULT_SKIP_TESTS
|
|
|
|
# $GCE_FLAKY_TESTS
|
|
|
|
# $GCE_SLOW_TESTS
|
|
|
|
#
|
|
|
|
# Args:
|
|
|
|
# $1 old_version: the version to deploy a cluster at, and old e2e tests to run
|
|
|
|
# against the upgraded cluster (should be something like
|
|
|
|
# 'release/latest', to work with JENKINS_PUBLISHED_VERSION logic)
|
|
|
|
# $2 new_version: the version to upgrade the cluster to, and new e2e tests to run
|
|
|
|
# against the upgraded cluster (should be something like
|
|
|
|
# 'ci/latest', to work with JENKINS_PUBLISHED_VERSION logic)
|
|
|
|
# $3 cluster_name: determines E2E_CLUSTER_NAME and E2E_NETWORK
|
|
|
|
# $4 project: determines PROJECT
|
|
|
|
|
|
|
|
function configure_upgrade_step() {
|
|
|
|
local -r old_version="$1"
|
|
|
|
local -r new_version="$2"
|
|
|
|
local -r cluster_name="$3"
|
|
|
|
local -r project="$4"
|
|
|
|
|
2015-12-09 22:29:55 +00:00
|
|
|
[[ "${JOB_NAME}" =~ .*-(step[1-7])-.* ]] || {
|
2015-11-25 00:16:00 +00:00
|
|
|
echo "JOB_NAME ${JOB_NAME} is not a valid upgrade job name, could not parse"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
local -r step="${BASH_REMATCH[1]}"
|
|
|
|
|
|
|
|
local -r gce_test_args="--ginkgo.skip=$(join_regex_allow_empty \
|
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
|
|
|
${GCE_SLOW_TESTS[@]:+${GCE_SLOW_TESTS[@]}} \
|
|
|
|
)"
|
|
|
|
local -r gke_test_args="--ginkgo.skip=$(join_regex_allow_empty \
|
|
|
|
${GKE_DEFAULT_SKIP_TESTS[@]:+${GKE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
|
|
|
${GCE_SLOW_TESTS[@]:+${GCE_SLOW_TESTS[@]}} \
|
|
|
|
)"
|
|
|
|
|
2015-12-08 00:47:03 +00:00
|
|
|
if [[ "${KUBERNETES_PROVIDER}" == "gce" ]]; then
|
2015-12-17 19:42:45 +00:00
|
|
|
KUBE_GCE_INSTANCE_PREFIX="$cluster_name"
|
2015-12-16 22:52:47 +00:00
|
|
|
NUM_NODES=5
|
|
|
|
KUBE_ENABLE_DEPLOYMENTS=true
|
|
|
|
KUBE_ENABLE_DAEMONSETS=true
|
2015-11-25 00:16:00 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
E2E_CLUSTER_NAME="$cluster_name"
|
|
|
|
E2E_NETWORK="$cluster_name"
|
|
|
|
PROJECT="$project"
|
|
|
|
|
|
|
|
case $step in
|
|
|
|
step1)
|
|
|
|
# Deploy at old version
|
|
|
|
JENKINS_PUBLISHED_VERSION="${old_version}"
|
|
|
|
|
|
|
|
E2E_UP="true"
|
|
|
|
E2E_TEST="false"
|
|
|
|
E2E_DOWN="false"
|
|
|
|
|
|
|
|
if [[ "${KUBERNETES_PROVIDER}" == "gke" ]]; then
|
|
|
|
E2E_SET_CLUSTER_API_VERSION=y
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
|
|
|
step2)
|
2015-12-08 23:32:08 +00:00
|
|
|
# Run new e2e kubectl tests
|
|
|
|
JENKINS_PUBLISHED_VERSION="${new_version}"
|
|
|
|
JENKINS_FORCE_GET_TARS=y
|
|
|
|
|
|
|
|
E2E_OPT="--check_version_skew=false"
|
|
|
|
E2E_UP="false"
|
|
|
|
E2E_TEST="true"
|
|
|
|
E2E_DOWN="false"
|
|
|
|
GINKGO_TEST_ARGS="--ginkgo.focus=Kubectl"
|
|
|
|
;;
|
|
|
|
|
|
|
|
step3)
|
2015-11-25 00:16:00 +00:00
|
|
|
# Use upgrade logic of version we're upgrading to.
|
|
|
|
JENKINS_PUBLISHED_VERSION="${new_version}"
|
|
|
|
JENKINS_FORCE_GET_TARS=y
|
|
|
|
|
|
|
|
E2E_OPT="--check_version_skew=false"
|
|
|
|
E2E_UP="false"
|
|
|
|
E2E_TEST="true"
|
|
|
|
E2E_DOWN="false"
|
|
|
|
GINKGO_TEST_ARGS="--ginkgo.focus=Cluster\sUpgrade.*upgrade-master --upgrade-target=${new_version}"
|
|
|
|
;;
|
|
|
|
|
2015-12-08 23:32:08 +00:00
|
|
|
step4)
|
2015-11-25 00:16:00 +00:00
|
|
|
# Run old e2es
|
|
|
|
JENKINS_PUBLISHED_VERSION="${old_version}"
|
|
|
|
JENKINS_FORCE_GET_TARS=y
|
|
|
|
|
|
|
|
E2E_OPT="--check_version_skew=false"
|
|
|
|
E2E_UP="false"
|
|
|
|
E2E_TEST="true"
|
|
|
|
E2E_DOWN="false"
|
|
|
|
|
|
|
|
if [[ "${KUBERNETES_PROVIDER}" == "gke" ]]; then
|
|
|
|
GINKGO_TEST_ARGS="${gke_test_args}"
|
|
|
|
else
|
|
|
|
GINKGO_TEST_ARGS="${gce_test_args}"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
2015-12-08 23:32:08 +00:00
|
|
|
step5)
|
2015-11-25 00:16:00 +00:00
|
|
|
# Use upgrade logic of version we're upgrading to.
|
|
|
|
JENKINS_PUBLISHED_VERSION="${new_version}"
|
|
|
|
JENKINS_FORCE_GET_TARS=y
|
|
|
|
|
|
|
|
E2E_OPT="--check_version_skew=false"
|
|
|
|
E2E_UP="false"
|
|
|
|
E2E_TEST="true"
|
|
|
|
E2E_DOWN="false"
|
|
|
|
GINKGO_TEST_ARGS="--ginkgo.focus=Cluster\sUpgrade.*upgrade-cluster --upgrade-target=${new_version}"
|
|
|
|
;;
|
|
|
|
|
2015-12-08 23:32:08 +00:00
|
|
|
step6)
|
2015-11-25 00:16:00 +00:00
|
|
|
# Run old e2es
|
|
|
|
JENKINS_PUBLISHED_VERSION="${old_version}"
|
|
|
|
JENKINS_FORCE_GET_TARS=y
|
|
|
|
|
|
|
|
E2E_OPT="--check_version_skew=false"
|
|
|
|
E2E_UP="false"
|
|
|
|
E2E_TEST="true"
|
|
|
|
E2E_DOWN="false"
|
|
|
|
|
|
|
|
if [[ "${KUBERNETES_PROVIDER}" == "gke" ]]; then
|
|
|
|
GINKGO_TEST_ARGS="${gke_test_args}"
|
|
|
|
else
|
|
|
|
GINKGO_TEST_ARGS="${gce_test_args}"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
2015-12-08 23:32:08 +00:00
|
|
|
step7)
|
2015-11-25 00:16:00 +00:00
|
|
|
# Run new e2es
|
|
|
|
JENKINS_PUBLISHED_VERSION="${new_version}"
|
|
|
|
JENKINS_FORCE_GET_TARS=y
|
|
|
|
|
|
|
|
# TODO(15011): these really shouldn't be (very) version skewed, but
|
|
|
|
# because we have to get ci/latest again, it could get slightly out of
|
|
|
|
# whack.
|
|
|
|
E2E_OPT="--check_version_skew=false"
|
|
|
|
E2E_UP="false"
|
|
|
|
E2E_TEST="true"
|
|
|
|
E2E_DOWN="true"
|
|
|
|
|
|
|
|
if [[ "${KUBERNETES_PROVIDER}" == "gke" ]]; then
|
|
|
|
GINKGO_TEST_ARGS="${gke_test_args}"
|
|
|
|
else
|
|
|
|
GINKGO_TEST_ARGS="${gce_test_args}"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
}
|
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
echo "--------------------------------------------------------------------------------"
|
|
|
|
echo "Initial Environment:"
|
|
|
|
printenv | sort
|
|
|
|
echo "--------------------------------------------------------------------------------"
|
|
|
|
|
2015-02-11 17:45:27 +00:00
|
|
|
if [[ "${CIRCLECI:-}" == "true" ]]; then
|
|
|
|
JOB_NAME="circleci-${CIRCLE_PROJECT_USERNAME}-${CIRCLE_PROJECT_REPONAME}"
|
|
|
|
BUILD_NUMBER=${CIRCLE_BUILD_NUM}
|
|
|
|
WORKSPACE=`pwd`
|
|
|
|
else
|
|
|
|
# Jenkins?
|
|
|
|
export HOME=${WORKSPACE} # Nothing should want Jenkins $HOME
|
2015-01-12 21:46:10 +00:00
|
|
|
fi
|
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# Additional parameters that are passed to hack/e2e.go
|
|
|
|
E2E_OPT=${E2E_OPT:-""}
|
2015-04-13 09:33:43 +00:00
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# Set environment variables shared for all of the GCE Jenkins projects.
|
|
|
|
if [[ ${JOB_NAME} =~ ^kubernetes-.*-gce ]]; then
|
|
|
|
KUBERNETES_PROVIDER="gce"
|
2015-07-23 22:22:02 +00:00
|
|
|
: ${E2E_MIN_STARTUP_PODS:="1"}
|
2015-06-09 22:45:15 +00:00
|
|
|
: ${E2E_ZONE:="us-central1-f"}
|
2015-11-24 03:06:18 +00:00
|
|
|
: ${NUM_NODES_PARALLEL:="6"} # Number of nodes required to run all of the tests in parallel
|
2015-09-03 17:02:47 +00:00
|
|
|
|
|
|
|
elif [[ ${JOB_NAME} =~ ^kubernetes-.*-gke ]]; then
|
|
|
|
KUBERNETES_PROVIDER="gke"
|
|
|
|
: ${E2E_ZONE:="us-central1-f"}
|
2015-12-08 00:47:03 +00:00
|
|
|
# By default, GKE tests run against the GKE test endpoint using CI Cloud SDK.
|
|
|
|
# Release jobs (e.g. prod, staging, and test) override these two variables.
|
|
|
|
: ${CLOUDSDK_BUCKET:="gs://cloud-sdk-build/testing/staging"}
|
|
|
|
: ${GKE_API_ENDPOINT:="https://test-container.sandbox.googleapis.com/"}
|
2015-10-06 18:52:37 +00:00
|
|
|
elif [[ ${JOB_NAME} =~ ^kubernetes-.*-aws ]]; then
|
|
|
|
KUBERNETES_PROVIDER="aws"
|
|
|
|
: ${E2E_MIN_STARTUP_PODS:="1"}
|
|
|
|
: ${E2E_ZONE:="us-east-1a"}
|
2015-11-24 03:06:18 +00:00
|
|
|
: ${NUM_NODES_PARALLEL:="6"} # Number of nodes required to run all of the tests in parallel
|
2015-04-13 09:33:43 +00:00
|
|
|
fi
|
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
if [[ "${KUBERNETES_PROVIDER}" == "aws" ]]; then
|
|
|
|
if [[ "${PERFORMANCE:-}" == "true" ]]; then
|
|
|
|
: ${MASTER_SIZE:="m3.xlarge"}
|
2015-11-24 03:06:36 +00:00
|
|
|
: ${NUM_NODES:="100"}
|
2015-11-12 22:30:06 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=\[Performance\]"}
|
2015-06-09 22:45:15 +00:00
|
|
|
else
|
2016-01-07 19:15:41 +00:00
|
|
|
: ${MASTER_SIZE:="m3.medium"}
|
|
|
|
: ${NODE_SIZE:="m3.medium"}
|
2015-11-24 03:06:36 +00:00
|
|
|
: ${NUM_NODES:="3"}
|
2015-06-09 22:45:15 +00:00
|
|
|
fi
|
|
|
|
fi
|
2015-04-13 09:33:43 +00:00
|
|
|
|
2015-11-23 19:14:00 +00:00
|
|
|
# CURRENT_RELEASE_PUBLISHED_VERSION is the JENKINS_PUBLISHED_VERSION for the
|
|
|
|
# release we are currently pointing our release testing infrastructure at.
|
|
|
|
# When 1.2.0-beta.0 comes out, e.g., this will become "ci/latest-1.2"
|
|
|
|
CURRENT_RELEASE_PUBLISHED_VERSION="ci/latest-1.1"
|
|
|
|
|
2015-09-03 17:02:47 +00:00
|
|
|
# Specialized tests which should be skipped by default for projects.
|
|
|
|
GCE_DEFAULT_SKIP_TESTS=(
|
2016-01-05 20:29:14 +00:00
|
|
|
"\[Example\]" # previously in REBOOT_SKIP_TESTS..., dates back before version control (#10078)
|
2015-11-24 10:23:48 +00:00
|
|
|
"\[Skipped\]"
|
2016-01-08 19:35:30 +00:00
|
|
|
"\[Feature:.+\]"
|
2015-09-23 13:15:55 +00:00
|
|
|
)
|
2015-09-03 17:02:47 +00:00
|
|
|
|
2016-01-05 20:29:14 +00:00
|
|
|
# PROVIDER SKIPS --------------------------------------
|
|
|
|
|
2015-09-03 17:02:47 +00:00
|
|
|
# Tests which cannot be run on GKE, e.g. because they require
|
2015-11-03 19:21:00 +00:00
|
|
|
# master ssh access.
|
2015-09-03 17:02:47 +00:00
|
|
|
GKE_REQUIRED_SKIP_TESTS=(
|
|
|
|
"Nodes"
|
|
|
|
"Etcd\sFailure"
|
|
|
|
"MasterCerts"
|
2015-12-07 23:26:30 +00:00
|
|
|
"experimental\sresource\susage\stracking" # Expect --max-pods=110
|
2015-10-30 22:14:04 +00:00
|
|
|
"ServiceLoadBalancer" # issue: #16602
|
2015-10-06 16:28:18 +00:00
|
|
|
"Shell"
|
2015-11-19 18:48:48 +00:00
|
|
|
# Alpha features, remove from skip when these move to beta
|
|
|
|
"Daemon\sset"
|
|
|
|
"Deployment"
|
2015-09-03 17:02:47 +00:00
|
|
|
)
|
|
|
|
|
2015-11-03 19:21:00 +00:00
|
|
|
# Specialized tests which should be skipped by default for GKE.
|
|
|
|
GKE_DEFAULT_SKIP_TESTS=(
|
2015-11-19 18:48:48 +00:00
|
|
|
# Perf test, slow by design
|
|
|
|
"resource\susage\stracking"
|
2015-11-03 19:21:00 +00:00
|
|
|
"${GKE_REQUIRED_SKIP_TESTS[@]}"
|
|
|
|
)
|
|
|
|
|
2015-10-01 17:46:46 +00:00
|
|
|
# Tests which cannot be run on AWS.
|
|
|
|
AWS_REQUIRED_SKIP_TESTS=(
|
2015-12-07 23:26:30 +00:00
|
|
|
"experimental\sresource\susage\stracking" # Expect --max-pods=110
|
2015-10-26 01:01:02 +00:00
|
|
|
"GCE\sL7\sLoadBalancer\sController" # GCE L7 loadbalancing
|
2015-10-01 17:46:46 +00:00
|
|
|
)
|
|
|
|
|
2016-01-05 20:29:14 +00:00
|
|
|
# END PROVIDER SKIPS --------------------------------------
|
2015-10-15 18:34:08 +00:00
|
|
|
|
|
|
|
# Tests which kills or restarts components and/or nodes.
|
|
|
|
DISRUPTIVE_TESTS=(
|
2015-12-18 18:41:33 +00:00
|
|
|
"\[Disruptive\]"
|
2015-10-15 18:34:08 +00:00
|
|
|
)
|
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# The following tests are known to be flaky, and are thus run only in their own
|
|
|
|
# -flaky- build variants.
|
2015-08-10 07:41:58 +00:00
|
|
|
GCE_FLAKY_TESTS=(
|
2015-12-22 20:19:57 +00:00
|
|
|
"\[Flaky\]"
|
2015-08-10 07:41:58 +00:00
|
|
|
)
|
2015-07-15 06:27:41 +00:00
|
|
|
|
2015-08-28 20:24:55 +00:00
|
|
|
# The following tests are known to be slow running (> 2 min), and are
|
|
|
|
# thus run only in their own -slow- build variants. Note that tests
|
|
|
|
# can be slow by explicit design (e.g. some soak tests), or slow
|
|
|
|
# through poor implementation. Please indicate which applies in the
|
|
|
|
# comments below, and for poorly implemented tests, please quote the
|
|
|
|
# issue number tracking speed improvements.
|
|
|
|
GCE_SLOW_TESTS=(
|
2015-12-22 20:19:57 +00:00
|
|
|
"\[Slow\]"
|
2015-08-28 20:24:55 +00:00
|
|
|
)
|
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# Tests which are not able to be run in parallel.
|
2015-12-18 18:41:33 +00:00
|
|
|
#
|
|
|
|
# TODO(ihmccreery) I'd like to get these combined with DISRUPTIVE_TESTS.
|
2015-07-15 06:50:09 +00:00
|
|
|
GCE_PARALLEL_SKIP_TESTS=(
|
2015-12-18 18:41:33 +00:00
|
|
|
"\[Serial\]"
|
|
|
|
"\[Disruptive\]"
|
|
|
|
)
|
2015-07-15 06:50:09 +00:00
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# Define environment variables based on the Jenkins project name.
|
2015-11-25 00:36:27 +00:00
|
|
|
# NOTE: Not all jobs are defined here. The hack/jenkins/e2e.sh in master and
|
|
|
|
# release branches defines relevant jobs for that particular version of
|
|
|
|
# Kubernetes.
|
2015-06-09 22:45:15 +00:00
|
|
|
case ${JOB_NAME} in
|
2015-08-28 20:24:55 +00:00
|
|
|
# Runs all non-flaky, non-slow tests on GCE, sequentially.
|
2015-06-09 22:45:15 +00:00
|
|
|
kubernetes-e2e-gce)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e"}
|
2015-12-10 17:11:48 +00:00
|
|
|
: ${E2E_PUBLISH_GREEN_VERSION:="true"}
|
2015-06-09 22:45:15 +00:00
|
|
|
: ${E2E_NETWORK:="e2e-gce"}
|
2015-07-23 11:30:01 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
2015-07-15 06:50:09 +00:00
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2015-08-28 20:24:55 +00:00
|
|
|
${GCE_SLOW_TESTS[@]:+${GCE_SLOW_TESTS[@]}} \
|
2015-07-15 06:50:09 +00:00
|
|
|
)"}
|
2015-06-09 22:45:15 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX="e2e-gce"}
|
|
|
|
: ${PROJECT:="k8s-jkns-e2e-gce"}
|
2015-09-24 18:16:17 +00:00
|
|
|
: ${ENABLE_DEPLOYMENTS:=true}
|
2015-10-21 01:47:38 +00:00
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2015-06-09 22:45:15 +00:00
|
|
|
;;
|
|
|
|
|
2015-10-06 18:52:37 +00:00
|
|
|
# Runs all non-flaky, non-slow tests on AWS, sequentially.
|
|
|
|
kubernetes-e2e-aws)
|
2015-12-07 22:17:16 +00:00
|
|
|
: ${E2E_PUBLISH_GREEN_VERSION:=true}
|
2015-10-06 18:52:37 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-aws-e2e"}
|
2015-12-07 22:17:16 +00:00
|
|
|
: ${E2E_ZONE:="us-west-2a"}
|
|
|
|
: ${ZONE:="us-west-2a"}
|
2015-10-06 18:52:37 +00:00
|
|
|
: ${E2E_NETWORK:="e2e-aws"}
|
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
|
|
|
${GCE_SLOW_TESTS[@]:+${GCE_SLOW_TESTS[@]}} \
|
|
|
|
${AWS_REQUIRED_SKIP_TESTS[@]:+${AWS_REQUIRED_SKIP_TESTS[@]}} \
|
|
|
|
)"}
|
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX="e2e-aws"}
|
|
|
|
: ${PROJECT:="k8s-jkns-e2e-aws"}
|
|
|
|
: ${ENABLE_DEPLOYMENTS:=true}
|
2015-12-07 22:17:16 +00:00
|
|
|
: ${AWS_CONFIG_FILE:='/var/lib/jenkins/.aws/credentials'}
|
|
|
|
: ${AWS_SSH_KEY:='/var/lib/jenkins/.ssh/kube_aws_rsa'}
|
|
|
|
: ${KUBE_SSH_USER:='ubuntu'}
|
|
|
|
# This is needed to be able to create PD from the e2e test
|
|
|
|
: ${AWS_SHARED_CREDENTIALS_FILE:='/var/lib/jenkins/.aws/credentials'}
|
2015-10-06 18:52:37 +00:00
|
|
|
;;
|
|
|
|
|
2015-07-20 20:33:35 +00:00
|
|
|
# Runs only the examples tests on GCE.
|
|
|
|
kubernetes-e2e-gce-examples)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e-examples"}
|
|
|
|
: ${E2E_NETWORK:="e2e-examples"}
|
2015-11-12 22:30:06 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=\[Example\]"}
|
2015-07-20 20:33:35 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-examples"}
|
|
|
|
: ${PROJECT:="kubernetes-jenkins"}
|
|
|
|
;;
|
|
|
|
|
2015-08-26 09:57:16 +00:00
|
|
|
# Runs only the autoscaling tests on GCE.
|
|
|
|
kubernetes-e2e-gce-autoscaling)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e-autoscaling"}
|
|
|
|
: ${E2E_NETWORK:="e2e-autoscaling"}
|
2016-01-12 18:11:56 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=\[Feature:Autoscaling\]"}
|
2015-08-26 09:57:16 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-autoscaling"}
|
|
|
|
: ${PROJECT:="k8s-jnks-e2e-gce-autoscaling"}
|
2015-10-21 01:47:38 +00:00
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2015-11-17 10:10:43 +00:00
|
|
|
: ${ENABLE_DEPLOYMENTS:=true}
|
2015-08-26 09:57:16 +00:00
|
|
|
# Override GCE default for cluster size autoscaling purposes.
|
|
|
|
ENABLE_CLUSTER_MONITORING="googleinfluxdb"
|
2015-10-12 09:30:47 +00:00
|
|
|
ADMISSION_CONTROL="NamespaceLifecycle,InitialResources,LimitRanger,SecurityContextDeny,ServiceAccount,ResourceQuota"
|
2015-08-26 09:57:16 +00:00
|
|
|
;;
|
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# Runs the flaky tests on GCE, sequentially.
|
|
|
|
kubernetes-e2e-gce-flaky)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e-flaky"}
|
|
|
|
: ${E2E_NETWORK:="e2e-flaky"}
|
2015-07-23 11:30:01 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
2015-07-15 06:50:09 +00:00
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
2015-07-23 11:30:01 +00:00
|
|
|
) --ginkgo.focus=$(join_regex_no_empty \
|
2015-07-15 06:50:09 +00:00
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2015-11-25 13:02:49 +00:00
|
|
|
)"}
|
2015-06-09 22:45:15 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-flaky"}
|
|
|
|
: ${PROJECT:="k8s-jkns-e2e-gce-flaky"}
|
2015-10-21 01:47:38 +00:00
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2015-12-14 18:15:48 +00:00
|
|
|
: ${E2E_DOWN:="true"}
|
2015-06-09 22:45:15 +00:00
|
|
|
;;
|
|
|
|
|
2015-08-28 20:24:55 +00:00
|
|
|
# Runs slow tests on GCE, sequentially.
|
|
|
|
kubernetes-e2e-gce-slow)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e-slow"}
|
|
|
|
: ${E2E_NETWORK:="e2e-slow"}
|
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=$(join_regex_no_empty \
|
|
|
|
${GCE_SLOW_TESTS[@]:+${GCE_SLOW_TESTS[@]}} \
|
|
|
|
)"}
|
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-slow"}
|
|
|
|
: ${PROJECT:="k8s-jkns-e2e-gce-slow"}
|
2015-10-21 01:47:38 +00:00
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2015-08-28 20:24:55 +00:00
|
|
|
;;
|
|
|
|
|
2015-09-02 22:46:49 +00:00
|
|
|
# Runs a subset of tests on GCE in parallel. Run against all pending PRs.
|
|
|
|
kubernetes-pull-build-test-e2e-gce)
|
2015-11-18 03:17:18 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="jnks-e2e-gce-${NODE_NAME}-${EXECUTOR_NUMBER}"}
|
|
|
|
: ${E2E_NETWORK:="e2e-gce-${NODE_NAME}-${EXECUTOR_NUMBER}"}
|
2015-09-02 22:46:49 +00:00
|
|
|
: ${GINKGO_PARALLEL:="y"}
|
|
|
|
# This list should match the list in kubernetes-e2e-gce-parallel.
|
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
2015-09-02 22:01:04 +00:00
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
2015-09-02 22:46:49 +00:00
|
|
|
${GCE_PARALLEL_SKIP_TESTS[@]:+${GCE_PARALLEL_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2015-09-19 07:49:01 +00:00
|
|
|
${GCE_SLOW_TESTS[@]:+${GCE_SLOW_TESTS[@]}} \
|
2015-09-02 22:46:49 +00:00
|
|
|
)"}
|
2015-11-18 03:17:18 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-gce-${NODE_NAME}-${EXECUTOR_NUMBER}"}
|
2015-09-02 22:46:49 +00:00
|
|
|
: ${PROJECT:="kubernetes-jenkins-pull"}
|
2015-09-24 18:16:17 +00:00
|
|
|
: ${ENABLE_DEPLOYMENTS:=true}
|
2015-09-02 22:46:49 +00:00
|
|
|
# Override GCE defaults
|
2015-11-24 03:06:36 +00:00
|
|
|
NUM_NODES=${NUM_NODES_PARALLEL}
|
2015-09-02 22:46:49 +00:00
|
|
|
;;
|
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# Runs all non-flaky tests on GCE in parallel.
|
|
|
|
kubernetes-e2e-gce-parallel)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e-parallel"}
|
|
|
|
: ${E2E_NETWORK:="e2e-parallel"}
|
|
|
|
: ${GINKGO_PARALLEL:="y"}
|
2015-07-23 11:30:01 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
2015-07-15 06:50:09 +00:00
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_PARALLEL_SKIP_TESTS[@]:+${GCE_PARALLEL_SKIP_TESTS[@]}} \
|
2015-08-27 17:26:06 +00:00
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2015-09-19 07:49:01 +00:00
|
|
|
${GCE_SLOW_TESTS[@]:+${GCE_SLOW_TESTS[@]}} \
|
2015-07-15 06:50:09 +00:00
|
|
|
)"}
|
2015-06-09 22:45:15 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-test-parallel"}
|
|
|
|
: ${PROJECT:="kubernetes-jenkins"}
|
2015-09-24 18:16:17 +00:00
|
|
|
: ${ENABLE_DEPLOYMENTS:=true}
|
2015-09-02 22:46:49 +00:00
|
|
|
# Override GCE defaults
|
2015-11-24 03:06:36 +00:00
|
|
|
NUM_NODES=${NUM_NODES_PARALLEL}
|
2015-06-09 22:45:15 +00:00
|
|
|
;;
|
|
|
|
|
2015-08-21 11:53:32 +00:00
|
|
|
# Runs all non-flaky tests on AWS in parallel.
|
|
|
|
kubernetes-e2e-aws-parallel)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-aws-e2e-parallel"}
|
|
|
|
: ${E2E_NETWORK:="e2e-parallel"}
|
|
|
|
: ${GINKGO_PARALLEL:="y"}
|
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_PARALLEL_SKIP_TESTS[@]:+${GCE_PARALLEL_SKIP_TESTS[@]}} \
|
2015-09-02 22:01:04 +00:00
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2015-10-01 17:46:46 +00:00
|
|
|
${AWS_REQUIRED_SKIP_TESTS[@]:+${AWS_REQUIRED_SKIP_TESTS[@]}} \
|
2015-08-21 11:53:32 +00:00
|
|
|
)"}
|
2015-09-24 18:16:17 +00:00
|
|
|
: ${ENABLE_DEPLOYMENTS:=true}
|
2015-08-21 11:53:32 +00:00
|
|
|
# Override AWS defaults.
|
2015-11-24 03:06:36 +00:00
|
|
|
NUM_NODES=${NUM_NODES_PARALLEL}
|
2015-08-21 11:53:32 +00:00
|
|
|
;;
|
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# Runs the flaky tests on GCE in parallel.
|
|
|
|
kubernetes-e2e-gce-parallel-flaky)
|
|
|
|
: ${E2E_CLUSTER_NAME:="parallel-flaky"}
|
|
|
|
: ${E2E_NETWORK:="e2e-parallel-flaky"}
|
|
|
|
: ${GINKGO_PARALLEL:="y"}
|
2015-07-23 11:30:01 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
2015-07-15 06:50:09 +00:00
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_PARALLEL_SKIP_TESTS[@]:+${GCE_PARALLEL_SKIP_TESTS[@]}} \
|
2015-07-23 11:30:01 +00:00
|
|
|
) --ginkgo.focus=$(join_regex_no_empty \
|
2015-09-02 22:01:04 +00:00
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2015-07-15 06:50:09 +00:00
|
|
|
)"}
|
2015-06-09 22:45:15 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="parallel-flaky"}
|
|
|
|
: ${PROJECT:="k8s-jkns-e2e-gce-prl-flaky"}
|
2015-10-21 01:47:38 +00:00
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2015-06-09 22:45:15 +00:00
|
|
|
# Override GCE defaults.
|
2015-11-24 03:06:36 +00:00
|
|
|
NUM_NODES=${NUM_NODES_PARALLEL}
|
2015-06-09 22:45:15 +00:00
|
|
|
;;
|
|
|
|
|
2016-01-15 19:07:36 +00:00
|
|
|
# Run the Reboot tests on GCE. (#19681)
|
2015-06-09 22:45:15 +00:00
|
|
|
kubernetes-e2e-gce-reboot)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e-reboot"}
|
|
|
|
: ${E2E_NETWORK:="e2e-reboot"}
|
2016-01-15 13:36:42 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=Reboot"}
|
2015-06-09 22:45:15 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-reboot"}
|
|
|
|
: ${PROJECT:="kubernetes-jenkins"}
|
|
|
|
;;
|
|
|
|
|
2016-01-15 19:07:36 +00:00
|
|
|
# Run the [Serial], [Disruptive], and [Feature:Restart] tests on GCE.
|
|
|
|
kubernetes-e2e-gce-serial)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e-serial"}
|
|
|
|
: ${E2E_NETWORK:="jenkins-gce-e2e-serial"}
|
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2016-01-19 19:08:03 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=\[Serial\]|\[Disruptive\]|\[Feature:Restart\] \
|
|
|
|
--ginkgo.skip=\[Flaky\]"}
|
2016-01-15 19:07:36 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-serial"}
|
|
|
|
: ${PROJECT:="kubernetes-jkns-e2e-gce-serial"}
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Run the [Serial], [Disruptive], and [Feature:Restart] tests on GKE.
|
|
|
|
kubernetes-e2e-gke-serial)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gke-e2e-serial"}
|
|
|
|
: ${E2E_NETWORK:="jenkins-gke-e2e-serial"}
|
|
|
|
: ${E2E_SET_CLUSTER_API_VERSION:=y}
|
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2016-01-19 19:08:03 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=\[Serial\]|\[Disruptive\]|\[Feature:Restart\] \
|
|
|
|
--ginkgo.skip=\[Flaky\]"}
|
|
|
|
: ${PROJECT:="jenkins-gke-e2e-serial"}
|
2016-01-15 19:07:36 +00:00
|
|
|
;;
|
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# Runs the performance/scalability tests on GCE. A larger cluster is used.
|
|
|
|
kubernetes-e2e-gce-scalability)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e-scalability"}
|
|
|
|
: ${E2E_NETWORK:="e2e-scalability"}
|
2015-11-25 12:24:40 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=\[Performance\] \
|
2015-12-23 10:15:27 +00:00
|
|
|
--gather-resource-usage=true \
|
2015-12-29 08:30:17 +00:00
|
|
|
--gather-metrics-at-teardown=true \
|
2016-01-14 13:12:38 +00:00
|
|
|
--gather-logs-sizes=true \
|
2016-01-15 10:53:38 +00:00
|
|
|
--output-print-type=json"}
|
2015-06-09 22:45:15 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-scalability"}
|
|
|
|
: ${PROJECT:="kubernetes-jenkins"}
|
|
|
|
# Override GCE defaults.
|
|
|
|
MASTER_SIZE="n1-standard-4"
|
2015-11-24 03:05:51 +00:00
|
|
|
NODE_SIZE="n1-standard-2"
|
2015-11-24 03:02:38 +00:00
|
|
|
NODE_DISK_SIZE="50GB"
|
2015-11-24 03:06:36 +00:00
|
|
|
NUM_NODES="100"
|
2015-08-18 09:13:45 +00:00
|
|
|
# Reduce logs verbosity
|
2015-10-29 09:12:39 +00:00
|
|
|
TEST_CLUSTER_LOG_LEVEL="--v=2"
|
2015-12-29 09:31:03 +00:00
|
|
|
# TODO: Remove when we figure out the reason for ocassional failures #19048
|
|
|
|
KUBELET_TEST_LOG_LEVEL="--v=4"
|
2015-10-06 09:12:00 +00:00
|
|
|
# Increase resync period to simulate production
|
|
|
|
TEST_CLUSTER_RESYNC_PERIOD="--min-resync-period=12h"
|
2015-06-09 22:45:15 +00:00
|
|
|
;;
|
|
|
|
|
2015-12-15 18:18:16 +00:00
|
|
|
# Runs e2e on GCE with flannel and VXLAN.
|
|
|
|
kubernetes-e2e-gce-flannel)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-e2e-flannel"}
|
|
|
|
: ${E2E_PUBLISH_GREEN_VERSION:="true"}
|
|
|
|
: ${E2E_NETWORK:="e2e-gce-flannel"}
|
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_PARALLEL_SKIP_TESTS[@]:+${GCE_PARALLEL_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
|
|
|
${GCE_SLOW_TESTS[@]:+${GCE_SLOW_TESTS[@]}} \
|
|
|
|
)"}
|
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-flannel"}
|
|
|
|
: ${PROJECT:="kubernetes-flannel"}
|
|
|
|
# Override GCE defaults.
|
|
|
|
NETWORK_PROVIDER="flannel"
|
|
|
|
;;
|
|
|
|
|
2015-12-11 08:22:21 +00:00
|
|
|
# Runs the performance/scalability test on huge 1000-node cluster on GCE.
|
|
|
|
# Flannel is used as network provider.
|
|
|
|
kubernetes-e2e-gce-enormous-cluster)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gce-enormous-cluster"}
|
|
|
|
: ${E2E_NETWORK:="e2e-enormous-cluster"}
|
2015-12-15 14:12:19 +00:00
|
|
|
# TODO: Currently run only density test.
|
|
|
|
# Once this is stable, run the whole [Performance] suite.
|
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=starting\s30\spods\sper\snode"}
|
2015-12-11 08:22:21 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-enormous-cluster"}
|
|
|
|
: ${PROJECT:="kubernetes-scale"}
|
|
|
|
# Override GCE defaults.
|
|
|
|
NETWORK_PROVIDER="flannel"
|
|
|
|
# Temporarily switch of Heapster, as this will not schedule anywhere.
|
|
|
|
# TODO: Think of a solution to enable it.
|
|
|
|
ENABLE_CLUSTER_MONITORING="none"
|
|
|
|
E2E_ZONE="asia-east1-a"
|
|
|
|
MASTER_SIZE="n1-standard-32"
|
|
|
|
NODE_SIZE="n1-standard-1"
|
|
|
|
NODE_DISK_SIZE="50GB"
|
|
|
|
NUM_NODES="1000"
|
|
|
|
# Reduce logs verbosity
|
2015-12-15 14:12:19 +00:00
|
|
|
TEST_CLUSTER_LOG_LEVEL="--v=1"
|
2015-12-11 08:22:21 +00:00
|
|
|
# Increase resync period to simulate production
|
|
|
|
TEST_CLUSTER_RESYNC_PERIOD="--min-resync-period=12h"
|
|
|
|
;;
|
|
|
|
|
2015-10-19 21:31:39 +00:00
|
|
|
# Sets up the GCE soak cluster weekly using the latest CI release.
|
|
|
|
kubernetes-soak-weekly-deploy-gce)
|
|
|
|
: ${E2E_CLUSTER_NAME:="gce-soak-weekly"}
|
|
|
|
: ${E2E_DOWN:="false"}
|
|
|
|
: ${E2E_NETWORK:="gce-soak-weekly"}
|
|
|
|
: ${E2E_TEST:="false"}
|
|
|
|
: ${E2E_UP:="true"}
|
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="gce-soak-weekly"}
|
|
|
|
: ${PROJECT:="kubernetes-jenkins"}
|
|
|
|
;;
|
|
|
|
|
2015-07-30 10:29:06 +00:00
|
|
|
# Runs tests on GCE soak cluster.
|
|
|
|
kubernetes-soak-continuous-e2e-gce)
|
|
|
|
: ${E2E_CLUSTER_NAME:="gce-soak-weekly"}
|
|
|
|
: ${E2E_DOWN:="false"}
|
|
|
|
: ${E2E_NETWORK:="gce-soak-weekly"}
|
|
|
|
: ${E2E_UP:="false"}
|
2015-11-17 18:44:15 +00:00
|
|
|
# Clear out any orphaned namespaces in case previous run was interrupted.
|
|
|
|
: ${E2E_CLEAN_START:="true"}
|
2016-01-05 20:29:14 +00:00
|
|
|
# We should be testing the reliability of a long-running cluster. The
|
|
|
|
# DISRUPTIVE_TESTS kill/restart components or nodes in the cluster,
|
|
|
|
# defeating the purpose of a soak cluster. (#15722)
|
2015-07-30 10:29:06 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
2015-08-31 21:58:50 +00:00
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2016-01-05 20:29:14 +00:00
|
|
|
${DISRUPTIVE_TESTS[@]:+${DISRUPTIVE_TESTS[@]}} \
|
2015-07-30 10:29:06 +00:00
|
|
|
)"}
|
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="gce-soak-weekly"}
|
|
|
|
: ${PROJECT:="kubernetes-jenkins"}
|
|
|
|
;;
|
|
|
|
|
2015-09-03 17:02:47 +00:00
|
|
|
kubernetes-e2e-gke-ci)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jkns-gke-e2e-ci"}
|
|
|
|
: ${E2E_NETWORK:="e2e-gke-ci"}
|
|
|
|
: ${E2E_SET_CLUSTER_API_VERSION:=y}
|
|
|
|
: ${PROJECT:="k8s-jkns-e2e-gke-ci"}
|
2015-10-21 01:47:38 +00:00
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2015-09-03 17:02:47 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
2015-11-03 19:21:00 +00:00
|
|
|
${GKE_DEFAULT_SKIP_TESTS[@]:+${GKE_DEFAULT_SKIP_TESTS[@]}} \
|
2015-09-03 17:02:47 +00:00
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
|
|
|
)"}
|
|
|
|
;;
|
|
|
|
|
2016-01-07 23:14:50 +00:00
|
|
|
# Run the GCE_PARALLEL_SKIP_TESTS on GKE.
|
2015-09-03 17:02:47 +00:00
|
|
|
kubernetes-e2e-gke-ci-reboot)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jkns-gke-e2e-ci-reboot"}
|
2015-10-26 23:21:04 +00:00
|
|
|
: ${E2E_NETWORK:="e2e-gke-ci-reboot"}
|
2015-09-03 17:02:47 +00:00
|
|
|
: ${E2E_SET_CLUSTER_API_VERSION:=y}
|
2015-10-26 23:21:04 +00:00
|
|
|
: ${PROJECT:="k8s-jkns-e2e-gke-ci-reboot"}
|
2015-10-21 01:47:38 +00:00
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2016-01-07 23:14:50 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=$(join_regex_allow_empty \
|
|
|
|
${GCE_PARALLEL_SKIP_TESTS[@]:+${GCE_PARALLEL_SKIP_TESTS[@]}} \
|
|
|
|
) --ginkgo.skip=$(join_regex_no_empty \
|
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
2015-09-03 17:02:47 +00:00
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2016-01-07 23:14:50 +00:00
|
|
|
${GKE_DEFAULT_SKIP_TESTS[@]:+${GKE_DEFAULT_SKIP_TESTS[@]}} \
|
2015-11-13 19:18:05 +00:00
|
|
|
)"}
|
2015-09-03 17:02:47 +00:00
|
|
|
;;
|
2015-09-11 22:50:44 +00:00
|
|
|
|
2015-11-30 09:46:54 +00:00
|
|
|
kubernetes-e2e-gke-flaky)
|
2015-11-26 08:34:24 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="kubernetes-gke-e2e-flaky"}
|
|
|
|
: ${E2E_NETWORK:="gke-e2e-flaky"}
|
|
|
|
: ${E2E_SET_CLUSTER_API_VERSION:=y}
|
2015-11-30 22:37:47 +00:00
|
|
|
: ${PROJECT:="k8s-jkns-e2e-gke-ci-flaky"}
|
2015-11-26 08:34:24 +00:00
|
|
|
: ${FAIL_ON_GCP_RESOURCE_LEAK:="true"}
|
2015-12-16 19:59:31 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
|
|
|
${GKE_REQUIRED_SKIP_TESTS[@]:+${GKE_REQUIRED_SKIP_TESTS[@]}}) \
|
|
|
|
--ginkgo.focus=$(join_regex_no_empty \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2015-11-26 08:34:24 +00:00
|
|
|
)"}
|
|
|
|
;;
|
|
|
|
|
2015-10-08 19:17:12 +00:00
|
|
|
# Sets up the GKE soak cluster weekly using the latest CI release.
|
|
|
|
kubernetes-soak-weekly-deploy-gke)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gke-soak-weekly"}
|
|
|
|
: ${E2E_DOWN:="false"}
|
|
|
|
: ${E2E_NETWORK:="gke-soak-weekly"}
|
|
|
|
: ${E2E_SET_CLUSTER_API_VERSION:=y}
|
|
|
|
: ${JENKINS_PUBLISHED_VERSION:="ci/latest"}
|
|
|
|
: ${E2E_TEST:="false"}
|
|
|
|
: ${E2E_UP:="true"}
|
|
|
|
: ${PROJECT:="kubernetes-jenkins"}
|
|
|
|
# Need at least n1-standard-2 nodes to run kubelet_perf tests
|
2015-11-24 03:05:51 +00:00
|
|
|
NODE_SIZE="n1-standard-2"
|
2015-10-08 19:17:12 +00:00
|
|
|
;;
|
|
|
|
|
|
|
|
# Runs tests on GKE soak cluster.
|
|
|
|
kubernetes-soak-continuous-e2e-gke)
|
|
|
|
: ${E2E_CLUSTER_NAME:="jenkins-gke-soak-weekly"}
|
|
|
|
: ${E2E_NETWORK:="gke-soak-weekly"}
|
|
|
|
: ${E2E_DOWN:="false"}
|
|
|
|
: ${E2E_UP:="false"}
|
2015-11-17 18:44:15 +00:00
|
|
|
# Clear out any orphaned namespaces in case previous run was interrupted.
|
|
|
|
: ${E2E_CLEAN_START:="true"}
|
2015-10-08 19:17:12 +00:00
|
|
|
: ${PROJECT:="kubernetes-jenkins"}
|
|
|
|
: ${E2E_OPT:="--check_version_skew=false"}
|
2016-01-05 20:29:14 +00:00
|
|
|
# We should be testing the reliability of a long-running cluster. The
|
|
|
|
# DISRUPTIVE_TESTS kill/restart components or nodes in the cluster,
|
|
|
|
# defeating the purpose of a soak cluster. (#15722)
|
2015-10-08 19:17:12 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
2015-11-19 18:48:48 +00:00
|
|
|
${GKE_REQUIRED_SKIP_TESTS[@]:+${GKE_REQUIRED_SKIP_TESTS[@]}} \
|
2015-10-08 19:17:12 +00:00
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
2016-01-05 20:29:14 +00:00
|
|
|
${DISRUPTIVE_TESTS[@]:+${DISRUPTIVE_TESTS[@]}} \
|
2015-10-08 19:17:12 +00:00
|
|
|
)"}
|
|
|
|
;;
|
|
|
|
|
2015-12-01 19:33:59 +00:00
|
|
|
# kubernetes-upgrade-gke-1.0-master
|
2015-10-07 21:01:24 +00:00
|
|
|
#
|
2015-12-02 23:54:31 +00:00
|
|
|
# Test upgrades from the latest release-1.0 build to the latest master build.
|
2015-10-07 21:01:24 +00:00
|
|
|
#
|
2015-12-08 23:32:32 +00:00
|
|
|
# Configurations for step1, step4, and step6 live in the release-1.0 branch.
|
2015-10-07 21:01:24 +00:00
|
|
|
|
2015-12-08 23:32:32 +00:00
|
|
|
kubernetes-upgrade-gke-1.0-master-step2-kubectl-e2e-new)
|
2015-12-01 22:59:08 +00:00
|
|
|
configure_upgrade_step 'configured-in-release-1.0' 'ci/latest' 'upgrade-gke-1-0-master' 'kubernetes-jenkins-gke-upgrade'
|
2015-10-07 21:01:24 +00:00
|
|
|
;;
|
|
|
|
|
2015-12-08 23:32:32 +00:00
|
|
|
kubernetes-upgrade-gke-1.0-master-step3-upgrade-master)
|
2015-12-01 22:59:08 +00:00
|
|
|
configure_upgrade_step 'configured-in-release-1.0' 'ci/latest' 'upgrade-gke-1-0-master' 'kubernetes-jenkins-gke-upgrade'
|
2015-10-07 21:01:24 +00:00
|
|
|
;;
|
|
|
|
|
2015-12-08 23:32:32 +00:00
|
|
|
kubernetes-upgrade-gke-1.0-master-step5-upgrade-cluster)
|
2015-12-01 22:59:08 +00:00
|
|
|
configure_upgrade_step 'configured-in-release-1.0' 'ci/latest' 'upgrade-gke-1-0-master' 'kubernetes-jenkins-gke-upgrade'
|
2015-10-07 21:01:24 +00:00
|
|
|
;;
|
|
|
|
|
2015-12-08 23:32:32 +00:00
|
|
|
kubernetes-upgrade-gke-1.0-master-step7-e2e-new)
|
2015-12-01 22:59:08 +00:00
|
|
|
configure_upgrade_step 'configured-in-release-1.0' 'ci/latest' 'upgrade-gke-1-0-master' 'kubernetes-jenkins-gke-upgrade'
|
2015-10-07 21:01:24 +00:00
|
|
|
;;
|
|
|
|
|
2015-12-01 23:08:42 +00:00
|
|
|
# kubernetes-upgrade-gke-1.1-master
|
|
|
|
#
|
2015-12-02 23:54:31 +00:00
|
|
|
# Test upgrades from the latest release-1.1 build to the latest master build.
|
|
|
|
#
|
2015-12-08 23:32:32 +00:00
|
|
|
# Configurations for step1, step4, and step6 live in the release-1.1 branch.
|
|
|
|
|
|
|
|
kubernetes-upgrade-gke-1.1-master-step2-kubectl-e2e-new)
|
|
|
|
configure_upgrade_step 'configured-in-release-1.1' 'ci/latest' 'upgrade-gke-1-1-master' 'kubernetes-jenkins-gke-upgrade'
|
|
|
|
;;
|
2015-12-01 23:08:42 +00:00
|
|
|
|
2015-12-08 23:32:32 +00:00
|
|
|
kubernetes-upgrade-gke-1.1-master-step3-upgrade-master)
|
2015-12-01 23:08:42 +00:00
|
|
|
configure_upgrade_step 'configured-in-release-1.1' 'ci/latest' 'upgrade-gke-1-1-master' 'kubernetes-jenkins-gke-upgrade'
|
2015-10-07 21:01:24 +00:00
|
|
|
;;
|
|
|
|
|
2015-12-08 23:32:32 +00:00
|
|
|
kubernetes-upgrade-gke-1.1-master-step5-upgrade-cluster)
|
2015-12-01 23:08:42 +00:00
|
|
|
configure_upgrade_step 'configured-in-release-1.1' 'ci/latest' 'upgrade-gke-1-1-master' 'kubernetes-jenkins-gke-upgrade'
|
2015-10-07 21:01:24 +00:00
|
|
|
;;
|
|
|
|
|
2015-12-08 23:32:32 +00:00
|
|
|
kubernetes-upgrade-gke-1.1-master-step7-e2e-new)
|
2015-12-01 23:08:42 +00:00
|
|
|
configure_upgrade_step 'configured-in-release-1.1' 'ci/latest' 'upgrade-gke-1-1-master' 'kubernetes-jenkins-gke-upgrade'
|
2015-09-28 19:00:46 +00:00
|
|
|
;;
|
|
|
|
|
2015-12-16 22:52:47 +00:00
|
|
|
# kubernetes-upgrade-gce-1.1-master
|
|
|
|
#
|
|
|
|
# Test upgrades from the latest release-1.1 build to the latest master build.
|
|
|
|
#
|
|
|
|
# Configurations for step1, step4, and step6 live in the release-1.1 branch.
|
|
|
|
|
|
|
|
kubernetes-upgrade-gce-1.1-master-step2-kubectl-e2e-new)
|
|
|
|
configure_upgrade_step 'configured-in-release-1.1' 'ci/latest' 'upgrade-gce-1-1-master' 'k8s-jkns-gce-upgrade'
|
|
|
|
;;
|
|
|
|
|
|
|
|
kubernetes-upgrade-gce-1.1-master-step3-upgrade-master)
|
|
|
|
configure_upgrade_step 'configured-in-release-1.1' 'ci/latest' 'upgrade-gce-1-1-master' 'k8s-jkns-gce-upgrade'
|
|
|
|
;;
|
|
|
|
|
|
|
|
kubernetes-upgrade-gce-1.1-master-step5-upgrade-cluster)
|
|
|
|
configure_upgrade_step 'configured-in-release-1.1' 'ci/latest' 'upgrade-gce-1-1-master' 'k8s-jkns-gce-upgrade'
|
|
|
|
;;
|
|
|
|
|
|
|
|
kubernetes-upgrade-gce-1.1-master-step7-e2e-new)
|
|
|
|
configure_upgrade_step 'configured-in-release-1.1' 'ci/latest' 'upgrade-gce-1-1-master' 'k8s-jkns-gce-upgrade'
|
|
|
|
;;
|
|
|
|
|
2015-11-23 19:14:00 +00:00
|
|
|
# kubernetes-upgrade-gce-1.0-current-release
|
2015-10-19 18:30:31 +00:00
|
|
|
#
|
|
|
|
# This suite:
|
|
|
|
#
|
2015-10-29 20:22:25 +00:00
|
|
|
# 1. launches a cluster at ci/latest-1.0,
|
2015-11-23 19:14:00 +00:00
|
|
|
# 2. upgrades the master to CURRENT_RELEASE_PUBLISHED_VERSION
|
2015-10-29 20:22:25 +00:00
|
|
|
# 3. runs ci/latest-1.0 e2es,
|
2015-10-19 18:30:31 +00:00
|
|
|
# 4. upgrades the rest of the cluster,
|
2015-10-29 20:22:25 +00:00
|
|
|
# 5. runs ci/latest-1.0 e2es again, then
|
2015-11-23 19:14:00 +00:00
|
|
|
# 6. runs CURRENT_RELEASE_PUBLISHED_VERSION e2es and tears down the cluster.
|
2015-10-19 18:30:31 +00:00
|
|
|
|
2015-12-01 19:33:59 +00:00
|
|
|
kubernetes-upgrade-1.0-current-release-gce-step1-deploy)
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_NETWORK:="gce-upgrade-1-0"}
|
2015-10-29 20:22:25 +00:00
|
|
|
: ${JENKINS_PUBLISHED_VERSION:="ci/latest-1.0"}
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${PROJECT:="k8s-jkns-gce-upgrade"}
|
|
|
|
: ${E2E_UP:="true"}
|
|
|
|
: ${E2E_TEST:="false"}
|
|
|
|
: ${E2E_DOWN:="false"}
|
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-upgrade-1-0"}
|
2015-11-24 03:06:36 +00:00
|
|
|
: ${NUM_NODES:=5}
|
2015-10-19 18:30:31 +00:00
|
|
|
;;
|
|
|
|
|
2015-11-23 19:14:00 +00:00
|
|
|
kubernetes-upgrade-1.0-current-release-gce-step2-upgrade-master)
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_NETWORK:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_OPT:="--check_version_skew=false"}
|
2015-11-04 20:54:36 +00:00
|
|
|
# Use upgrade logic of version we're upgrading to.
|
2015-11-23 19:14:00 +00:00
|
|
|
: ${JENKINS_PUBLISHED_VERSION:="${CURRENT_RELEASE_PUBLISHED_VERSION}"}
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${JENKINS_FORCE_GET_TARS:=y}
|
|
|
|
: ${PROJECT:="k8s-jkns-gce-upgrade"}
|
|
|
|
: ${E2E_UP:="false"}
|
|
|
|
: ${E2E_TEST:="true"}
|
|
|
|
: ${E2E_DOWN:="false"}
|
2015-11-12 22:30:06 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=Cluster\sUpgrade.*upgrade-master --upgrade-target=${CURRENT_RELEASE_PUBLISHED_VERSION}"}
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-upgrade-1-0"}
|
2015-11-24 03:06:36 +00:00
|
|
|
: ${NUM_NODES:=5}
|
2015-11-02 22:29:02 +00:00
|
|
|
: ${KUBE_ENABLE_DEPLOYMENTS:=true}
|
|
|
|
: ${KUBE_ENABLE_DAEMONSETS:=true}
|
2015-10-19 18:30:31 +00:00
|
|
|
;;
|
|
|
|
|
2015-11-23 19:14:00 +00:00
|
|
|
kubernetes-upgrade-1.0-current-release-gce-step3-e2e-old)
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_NETWORK:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_OPT:="--check_version_skew=false"}
|
|
|
|
: ${JENKINS_FORCE_GET_TARS:=y}
|
|
|
|
# Run old e2es
|
2015-10-29 20:22:25 +00:00
|
|
|
: ${JENKINS_PUBLISHED_VERSION:="ci/latest-1.0"}
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${PROJECT:="k8s-jkns-gce-upgrade"}
|
|
|
|
: ${E2E_UP:="false"}
|
|
|
|
: ${E2E_TEST:="true"}
|
|
|
|
: ${E2E_DOWN:="false"}
|
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
|
|
|
)"}
|
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-upgrade-1-0"}
|
2015-11-24 03:06:36 +00:00
|
|
|
: ${NUM_NODES:=5}
|
2015-10-19 18:30:31 +00:00
|
|
|
;;
|
|
|
|
|
2015-11-23 19:14:00 +00:00
|
|
|
kubernetes-upgrade-1.0-current-release-gce-step4-upgrade-cluster)
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_NETWORK:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_OPT:="--check_version_skew=false"}
|
2015-11-04 20:54:36 +00:00
|
|
|
# Use upgrade logic of version we're upgrading to.
|
2015-11-23 19:14:00 +00:00
|
|
|
: ${JENKINS_PUBLISHED_VERSION:="${CURRENT_RELEASE_PUBLISHED_VERSION}"}
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${JENKINS_FORCE_GET_TARS:=y}
|
|
|
|
: ${PROJECT:="k8s-jkns-gce-upgrade"}
|
|
|
|
: ${E2E_UP:="false"}
|
|
|
|
: ${E2E_TEST:="true"}
|
|
|
|
: ${E2E_DOWN:="false"}
|
2015-11-12 22:30:06 +00:00
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.focus=Cluster\sUpgrade.*upgrade-cluster --upgrade-target=${CURRENT_RELEASE_PUBLISHED_VERSION}"}
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-upgrade-1-0"}
|
2015-11-24 03:06:36 +00:00
|
|
|
: ${NUM_NODES:=5}
|
2015-11-02 22:29:02 +00:00
|
|
|
: ${KUBE_ENABLE_DEPLOYMENTS:=true}
|
|
|
|
: ${KUBE_ENABLE_DAEMONSETS:=true}
|
2015-10-19 18:30:31 +00:00
|
|
|
;;
|
|
|
|
|
2015-11-23 19:14:00 +00:00
|
|
|
kubernetes-upgrade-1.0-current-release-gce-step5-e2e-old)
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_NETWORK:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_OPT:="--check_version_skew=false"}
|
|
|
|
: ${JENKINS_FORCE_GET_TARS:=y}
|
|
|
|
# Run old e2es
|
2015-10-29 20:22:25 +00:00
|
|
|
: ${JENKINS_PUBLISHED_VERSION:="ci/latest-1.0"}
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${PROJECT:="k8s-jkns-gce-upgrade"}
|
|
|
|
: ${E2E_UP:="false"}
|
|
|
|
: ${E2E_TEST:="true"}
|
|
|
|
: ${E2E_DOWN:="false"}
|
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
|
|
|
)"}
|
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-upgrade-1-0"}
|
2015-11-24 03:06:36 +00:00
|
|
|
: ${NUM_NODES:=5}
|
2015-10-19 18:30:31 +00:00
|
|
|
;;
|
|
|
|
|
2015-11-23 19:14:00 +00:00
|
|
|
kubernetes-upgrade-1.0-current-release-gce-step6-e2e-new)
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="gce-upgrade-1-0"}
|
|
|
|
: ${E2E_NETWORK:="gce-upgrade-1-0"}
|
2015-10-27 21:01:47 +00:00
|
|
|
# TODO(15011): these really shouldn't be (very) version skewed, but because
|
2015-11-23 19:14:00 +00:00
|
|
|
# we have to get CURRENT_RELEASE_PUBLISHED_VERSION again, it could get slightly out of whack.
|
2015-10-27 21:01:47 +00:00
|
|
|
: ${E2E_OPT:="--check_version_skew=false"}
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${JENKINS_FORCE_GET_TARS:=y}
|
2015-11-23 19:14:00 +00:00
|
|
|
: ${JENKINS_PUBLISHED_VERSION:="${CURRENT_RELEASE_PUBLISHED_VERSION}"}
|
2015-10-19 18:30:31 +00:00
|
|
|
: ${PROJECT:="k8s-jkns-gce-upgrade"}
|
|
|
|
: ${E2E_UP:="false"}
|
|
|
|
: ${E2E_TEST:="true"}
|
|
|
|
: ${E2E_DOWN:="true"}
|
|
|
|
: ${GINKGO_TEST_ARGS:="--ginkgo.skip=$(join_regex_allow_empty \
|
|
|
|
${GCE_DEFAULT_SKIP_TESTS[@]:+${GCE_DEFAULT_SKIP_TESTS[@]}} \
|
|
|
|
${GCE_FLAKY_TESTS[@]:+${GCE_FLAKY_TESTS[@]}} \
|
|
|
|
${GCE_SLOW_TESTS[@]:+${GCE_SLOW_TESTS[@]}} \
|
|
|
|
)"}
|
|
|
|
: ${KUBE_GCE_INSTANCE_PREFIX:="e2e-upgrade-1-0"}
|
2015-11-24 03:06:36 +00:00
|
|
|
: ${NUM_NODES:=5}
|
2015-10-19 18:30:31 +00:00
|
|
|
;;
|
|
|
|
|
2015-10-08 08:04:12 +00:00
|
|
|
# Run Kubemark test on a fake 100 node cluster to have a comparison
|
|
|
|
# to the real results from scalability suite
|
2015-09-30 14:16:16 +00:00
|
|
|
kubernetes-kubemark-gce)
|
2015-09-30 14:03:06 +00:00
|
|
|
: ${E2E_CLUSTER_NAME:="kubernetes-kubemark"}
|
|
|
|
: ${E2E_NETWORK:="kubernetes-kubemark"}
|
|
|
|
: ${PROJECT:="k8s-jenkins-kubemark"}
|
|
|
|
: ${E2E_UP:="true"}
|
|
|
|
: ${E2E_DOWN:="true"}
|
|
|
|
: ${E2E_TEST:="false"}
|
|
|
|
: ${USE_KUBEMARK:="true"}
|
2015-10-08 08:04:12 +00:00
|
|
|
# Override defaults to be indpendent from GCE defaults and set kubemark parameters
|
2015-10-13 14:01:25 +00:00
|
|
|
KUBE_GCE_INSTANCE_PREFIX="kubemark100"
|
2015-11-24 03:06:36 +00:00
|
|
|
NUM_NODES="10"
|
2015-10-08 08:04:12 +00:00
|
|
|
MASTER_SIZE="n1-standard-2"
|
2015-11-24 03:05:51 +00:00
|
|
|
NODE_SIZE="n1-standard-1"
|
2016-01-19 19:20:59 +00:00
|
|
|
E2E_ZONE="asia-east1-a"
|
2015-10-08 08:04:12 +00:00
|
|
|
KUBEMARK_MASTER_SIZE="n1-standard-4"
|
2015-11-24 02:59:56 +00:00
|
|
|
KUBEMARK_NUM_NODES="100"
|
2015-09-30 14:03:06 +00:00
|
|
|
;;
|
2015-10-07 23:09:12 +00:00
|
|
|
|
2015-10-26 10:57:55 +00:00
|
|
|
# Run Kubemark test on a fake 500 node cluster to test for regressions on
|
|
|
|
# bigger clusters
|
|
|
|
kubernetes-kubemark-500-gce)
|
|
|
|
: ${E2E_CLUSTER_NAME:="kubernetes-kubemark-500"}
|
|
|
|
: ${E2E_NETWORK:="kubernetes-kubemark-500"}
|
2015-12-18 07:14:16 +00:00
|
|
|
: ${PROJECT:="kubernetes-scale"}
|
2015-10-26 10:57:55 +00:00
|
|
|
: ${E2E_UP:="true"}
|
|
|
|
: ${E2E_DOWN:="true"}
|
|
|
|
: ${E2E_TEST:="false"}
|
|
|
|
: ${USE_KUBEMARK:="true"}
|
|
|
|
# Override defaults to be indpendent from GCE defaults and set kubemark parameters
|
2015-11-24 03:06:36 +00:00
|
|
|
NUM_NODES="6"
|
2015-10-26 10:57:55 +00:00
|
|
|
MASTER_SIZE="n1-standard-4"
|
2015-11-24 03:05:51 +00:00
|
|
|
NODE_SIZE="n1-standard-8"
|
2015-10-26 10:57:55 +00:00
|
|
|
KUBE_GCE_INSTANCE_PREFIX="kubemark500"
|
2015-12-18 07:14:16 +00:00
|
|
|
E2E_ZONE="us-east1-b"
|
2015-10-26 10:57:55 +00:00
|
|
|
KUBEMARK_MASTER_SIZE="n1-standard-16"
|
2015-11-24 02:59:56 +00:00
|
|
|
KUBEMARK_NUM_NODES="500"
|
2015-10-26 10:57:55 +00:00
|
|
|
;;
|
|
|
|
|
2015-10-08 08:04:12 +00:00
|
|
|
# Run big Kubemark test, this currently means a 1000 node cluster and 16 core master
|
2015-10-07 23:09:12 +00:00
|
|
|
kubernetes-kubemark-gce-scale)
|
|
|
|
: ${E2E_CLUSTER_NAME:="kubernetes-kubemark-scale"}
|
|
|
|
: ${E2E_NETWORK:="kubernetes-kubemark-scale"}
|
|
|
|
: ${PROJECT:="kubernetes-scale"}
|
|
|
|
: ${E2E_UP:="true"}
|
|
|
|
: ${E2E_DOWN:="true"}
|
|
|
|
: ${E2E_TEST:="false"}
|
|
|
|
: ${USE_KUBEMARK:="true"}
|
2015-10-08 08:04:12 +00:00
|
|
|
# Override defaults to be indpendent from GCE defaults and set kubemark parameters
|
2015-10-09 09:44:40 +00:00
|
|
|
# We need 11 so that we won't hit max-pods limit (set to 100). TODO: do it in a nicer way.
|
2015-11-24 03:06:36 +00:00
|
|
|
NUM_NODES="11"
|
2015-10-08 08:04:12 +00:00
|
|
|
MASTER_SIZE="n1-standard-4"
|
2015-11-24 03:05:51 +00:00
|
|
|
NODE_SIZE="n1-standard-8" # Note: can fit about 17 hollow nodes per core
|
2015-11-30 22:31:32 +00:00
|
|
|
# so NUM_NODES x cores_per_node should
|
2015-10-08 08:04:12 +00:00
|
|
|
# be set accordingly.
|
2015-10-13 14:01:25 +00:00
|
|
|
KUBE_GCE_INSTANCE_PREFIX="kubemark1000"
|
2015-12-14 13:22:13 +00:00
|
|
|
E2E_ZONE="us-east1-b"
|
2015-10-08 08:04:12 +00:00
|
|
|
KUBEMARK_MASTER_SIZE="n1-standard-16"
|
2015-11-24 02:59:56 +00:00
|
|
|
KUBEMARK_NUM_NODES="1000"
|
2015-10-07 23:09:12 +00:00
|
|
|
;;
|
2015-06-09 22:45:15 +00:00
|
|
|
esac
|
2015-05-08 22:46:42 +00:00
|
|
|
|
2016-01-07 18:48:59 +00:00
|
|
|
# Skip gcloud update checking
|
|
|
|
export CLOUDSDK_COMPONENT_MANAGER_DISABLE_UPDATE_CHECK=true
|
|
|
|
|
2015-02-11 17:45:27 +00:00
|
|
|
# AWS variables
|
|
|
|
export KUBE_AWS_INSTANCE_PREFIX=${E2E_CLUSTER_NAME}
|
|
|
|
export KUBE_AWS_ZONE=${E2E_ZONE}
|
2015-12-10 07:22:47 +00:00
|
|
|
export AWS_CONFIG_FILE=${AWS_CONFIG_FILE:-}
|
|
|
|
export AWS_SSH_KEY=${AWS_SSH_KEY:-}
|
|
|
|
export KUBE_SSH_USER=${KUBE_SSH_USER:-}
|
|
|
|
export AWS_SHARED_CREDENTIALS_FILE=${AWS_SHARED_CREDENTIALS_FILE:-}
|
2015-02-11 17:45:27 +00:00
|
|
|
|
2015-01-12 21:46:10 +00:00
|
|
|
# GCE variables
|
|
|
|
export INSTANCE_PREFIX=${E2E_CLUSTER_NAME}
|
|
|
|
export KUBE_GCE_ZONE=${E2E_ZONE}
|
|
|
|
export KUBE_GCE_NETWORK=${E2E_NETWORK}
|
2015-06-09 22:45:15 +00:00
|
|
|
export KUBE_GCE_INSTANCE_PREFIX=${KUBE_GCE_INSTANCE_PREFIX:-}
|
2015-11-24 02:59:56 +00:00
|
|
|
export KUBE_GCE_NODE_PROJECT=${KUBE_GCE_NODE_PROJECT:-}
|
|
|
|
export KUBE_GCE_NODE_IMAGE=${KUBE_GCE_NODE_IMAGE:-}
|
2015-11-05 19:58:31 +00:00
|
|
|
export KUBE_OS_DISTRIBUTION=${KUBE_OS_DISTRIBUTION:-}
|
2015-12-18 21:59:14 +00:00
|
|
|
export GCE_SERVICE_ACCOUNT=$(gcloud auth list 2> /dev/null | grep active | cut -f3 -d' ')
|
2016-01-08 18:26:13 +00:00
|
|
|
export FAIL_ON_GCP_RESOURCE_LEAK="${FAIL_ON_GCP_RESOURCE_LEAK:-false}"
|
2015-01-12 21:46:10 +00:00
|
|
|
|
|
|
|
# GKE variables
|
|
|
|
export CLUSTER_NAME=${E2E_CLUSTER_NAME}
|
|
|
|
export ZONE=${E2E_ZONE}
|
|
|
|
export KUBE_GKE_NETWORK=${E2E_NETWORK}
|
2015-09-03 17:02:47 +00:00
|
|
|
export E2E_SET_CLUSTER_API_VERSION=${E2E_SET_CLUSTER_API_VERSION:-}
|
|
|
|
export CMD_GROUP=${CMD_GROUP:-}
|
2015-11-24 03:05:51 +00:00
|
|
|
export MACHINE_TYPE=${NODE_SIZE:-} # GKE scripts use MACHINE_TYPE for the node vm size
|
2016-01-08 18:26:13 +00:00
|
|
|
export CLOUDSDK_BUCKET="${CLOUDSDK_BUCKET:-}"
|
2015-09-03 17:02:47 +00:00
|
|
|
|
|
|
|
if [[ ! -z "${GKE_API_ENDPOINT:-}" ]]; then
|
|
|
|
export CLOUDSDK_API_ENDPOINT_OVERRIDES_CONTAINER=${GKE_API_ENDPOINT}
|
|
|
|
fi
|
2015-01-12 21:46:10 +00:00
|
|
|
|
2015-06-09 22:45:15 +00:00
|
|
|
# Shared cluster variables
|
2015-07-23 22:22:02 +00:00
|
|
|
export E2E_MIN_STARTUP_PODS=${E2E_MIN_STARTUP_PODS:-}
|
2015-08-11 13:25:36 +00:00
|
|
|
export KUBE_ENABLE_CLUSTER_MONITORING=${ENABLE_CLUSTER_MONITORING:-}
|
2015-11-05 19:58:31 +00:00
|
|
|
export KUBE_ENABLE_CLUSTER_REGISTRY=${ENABLE_CLUSTER_REGISTRY:-}
|
|
|
|
export KUBE_ENABLE_HORIZONTAL_POD_AUTOSCALER=${ENABLE_HORIZONTAL_POD_AUTOSCALER:-}
|
2015-09-24 18:16:17 +00:00
|
|
|
export KUBE_ENABLE_DEPLOYMENTS=${ENABLE_DEPLOYMENTS:-}
|
2015-10-06 00:41:40 +00:00
|
|
|
export KUBE_ENABLE_EXPERIMENTAL_API=${ENABLE_EXPERIMENTAL_API:-}
|
2015-06-09 22:45:15 +00:00
|
|
|
export MASTER_SIZE=${MASTER_SIZE:-}
|
2015-11-24 03:05:51 +00:00
|
|
|
export NODE_SIZE=${NODE_SIZE:-}
|
2015-11-24 03:02:38 +00:00
|
|
|
export NODE_DISK_SIZE=${NODE_DISK_SIZE:-}
|
2015-11-24 03:06:36 +00:00
|
|
|
export NUM_NODES=${NUM_NODES:-}
|
2015-10-14 12:13:14 +00:00
|
|
|
export TEST_CLUSTER_LOG_LEVEL=${TEST_CLUSTER_LOG_LEVEL:-}
|
2015-12-29 09:31:03 +00:00
|
|
|
export KUBELET_TEST_LOG_LEVEL=${KUBELET_TEST_LOG_LEVEL:-}
|
2015-10-14 12:13:14 +00:00
|
|
|
export TEST_CLUSTER_RESYNC_PERIOD=${TEST_CLUSTER_RESYNC_PERIOD:-}
|
2015-06-09 22:45:15 +00:00
|
|
|
export PROJECT=${PROJECT:-}
|
2015-12-16 08:53:02 +00:00
|
|
|
export NETWORK_PROVIDER=${NETWORK_PROVIDER:-}
|
2015-10-06 17:23:04 +00:00
|
|
|
export JENKINS_PUBLISHED_VERSION=${JENKINS_PUBLISHED_VERSION:-'ci/latest'}
|
2015-06-09 22:45:15 +00:00
|
|
|
|
2015-10-12 09:30:47 +00:00
|
|
|
export KUBE_ADMISSION_CONTROL=${ADMISSION_CONTROL:-}
|
|
|
|
|
2015-09-03 17:02:47 +00:00
|
|
|
export KUBERNETES_PROVIDER=${KUBERNETES_PROVIDER}
|
2015-01-12 21:46:10 +00:00
|
|
|
export PATH=${PATH}:/usr/local/go/bin
|
2015-12-18 21:43:26 +00:00
|
|
|
export KUBE_SKIP_UPDATE=y
|
2015-01-12 21:46:10 +00:00
|
|
|
export KUBE_SKIP_CONFIRMATIONS=y
|
|
|
|
|
2016-01-08 18:26:13 +00:00
|
|
|
# Kubemark
|
|
|
|
export USE_KUBEMARK="${USE_KUBEMARK:-false}"
|
|
|
|
export KUBEMARK_MASTER_SIZE="${KUBEMARK_MASTER_SIZE:-$MASTER_SIZE}"
|
|
|
|
export KUBEMARK_NUM_NODES="${KUBEMARK_NUM_NODES:-$NUM_NODES}"
|
|
|
|
|
2015-05-07 23:48:54 +00:00
|
|
|
# E2E Control Variables
|
2015-12-30 22:39:31 +00:00
|
|
|
export E2E_OPT="${E2E_OPT:-}"
|
2015-05-07 23:48:54 +00:00
|
|
|
export E2E_UP="${E2E_UP:-true}"
|
|
|
|
export E2E_TEST="${E2E_TEST:-true}"
|
|
|
|
export E2E_DOWN="${E2E_DOWN:-true}"
|
2015-11-17 18:44:15 +00:00
|
|
|
export E2E_CLEAN_START="${E2E_CLEAN_START:-}"
|
2016-01-08 18:26:13 +00:00
|
|
|
export E2E_PUBLISH_GREEN_VERSION="${E2E_PUBLISH_GREEN_VERSION:-false}"
|
2015-06-09 22:45:15 +00:00
|
|
|
# Used by hack/ginkgo-e2e.sh to enable ginkgo's parallel test runner.
|
|
|
|
export GINKGO_PARALLEL=${GINKGO_PARALLEL:-}
|
2016-01-13 01:45:23 +00:00
|
|
|
export GINKGO_PARALLEL_NODES=${GINKGO_PARALLEL_NODES:-}
|
2015-12-30 22:39:31 +00:00
|
|
|
export GINKGO_TEST_ARGS="${GINKGO_TEST_ARGS:-}"
|
2015-06-09 22:45:15 +00:00
|
|
|
|
2015-12-30 22:39:31 +00:00
|
|
|
# If we are on PR Jenkins merging into master, use the local e2e.sh. Otherwise, use the latest on github.
|
|
|
|
if [[ "${ghprbTargetBranch:-}" == "master" ]]; then
|
|
|
|
source "hack/jenkins/e2e-runner.sh"
|
2015-10-12 18:19:57 +00:00
|
|
|
else
|
2015-12-30 22:39:31 +00:00
|
|
|
source <(curl -fsS --retry 3 "https://raw.githubusercontent.com/kubernetes/kubernetes/master/hack/jenkins/e2e-runner.sh")
|
2015-05-07 23:48:54 +00:00
|
|
|
fi
|