From 81fa7f65336c31d9852cb6ced386a1fdafcc32fb Mon Sep 17 00:00:00 2001 From: Tamal Saha Date: Sat, 18 Aug 2018 01:16:49 -0700 Subject: [PATCH] Squashed 'hack/libbuild/' changes from 5e13446a..70ef1128 70ef1128 fix branch naming issue (#23) da3abb93 Use TAG instead of CUSTOM_OPERATOR_TAG, so it'll be common accross all repo (#22) 581ca8c0 Rename cleanup to cleanup_test_stuff (#21) d5b1ae3f Add concourse scripts for creating cluster, installing dependencies (#20) 6274f165 fix TAG_STRATEGY: unbound variable (#19) 46c48326 Remove gopath static flags. 637d3545 Fix reproducible build and add tags for static. git-subtree-dir: hack/libbuild git-subtree-split: 70ef11282ee43c0ba11ee94e9e3d4d008b82498e --- common/lib.sh | 4 +- concourse/cluster.sh | 299 ++++++++++++++++++++++++++++++++++++++ concourse/dependencies.sh | 40 +++++ concourse/init.sh | 24 +++ libbuild.py | 8 +- 5 files changed, 371 insertions(+), 4 deletions(-) create mode 100755 concourse/cluster.sh create mode 100755 concourse/dependencies.sh create mode 100755 concourse/init.sh diff --git a/common/lib.sh b/common/lib.sh index ad44d6243..7c7410731 100755 --- a/common/lib.sh +++ b/common/lib.sh @@ -91,7 +91,7 @@ detect_tag() { echo "commit_timestamp = $commit_timestamp" # write TAG info to a file so that it can be loaded by a different command or script - if [ "$1" != '' ]; then + if [ $# -gt 0 ] && [ "$1" != '' ]; then cat >"$1" </dev/null + apt-get install -y awscli &>/dev/null + + ## create cluster using kops + # aws credentials for kops user + set +x + export AWS_ACCESS_KEY_ID=${KOPS_AWS_ACCESS_KEY_ID:-} + export AWS_SECRET_ACCESS_KEY=${KOPS_AWS_SECRET_ACCESS_KEY:-} + set -x + + # name of the cluster + NAME=$NAME.k8s.local + + # use s3 bucket for cluster state storage + export KOPS_STATE_STORE=s3://kubedbci + + # check avability + aws ec2 describe-availability-zones --region us-east-1 + + # generate ssh-keys without prompt + ssh-keygen -q -t rsa -N '' -f /root/.ssh/id_rsa + + # generate cluster configuration + kops create cluster --zones us-east-1a --node-count 1 "$NAME" + + # build cluster + kops update cluster "$NAME" --yes + + # wait for cluster to be ready + end=$((SECONDS + 900)) + while [ $SECONDS -lt $end ]; do + if (kops validate cluster); then + break + else + sleep 60 + fi + done + + StorageClass="gp2" +} + +function azure_common() { + StorageClass="default" + + # download azure cli + AZ_REPO=$(lsb_release -cs) + echo "deb [arch=amd64] https://packages.microsoft.com/repos/azure-cli/ $AZ_REPO main" | + tee /etc/apt/sources.list.d/azure-cli.list + curl -L https://packages.microsoft.com/keys/microsoft.asc | apt-key add - + apt-get install -y apt-transport-https &>/dev/null + apt-get update &>/dev/null + apt-get install -y azure-cli &>/dev/null + + # login with service principal + set +x + az login --service-principal --username "$APP_ID" --password "$PASSWORD" --tenant "$TENANT_ID" &>/dev/null + az group create --name "$NAME" --location "$ZONE" + set -x +} + +function prepare_aks() { + azure_common + set +x + az aks create --resource-group "$NAME" --name "$NAME" --service-principal "$APP_ID" --client-secret "$PASSWORD" --generate-ssh-keys --node-vm-size "$NODE" --node-count 1 --kubernetes-version "$K8S_VERSION" &>/dev/null + set -x + az aks get-credentials --resource-group "$NAME" --name "$NAME" + +} + +function prepare_acs() { + azure_common + set +x + az acs create --orchestrator-type kubernetes --orchestrator-version "$K8S_VERSION" --resource-group "$NAME" --name "$NAME" --master-vm-size "$NODE" --agent-vm-size "$NODE" --agent-count 1 --service-principal "$APP_ID" --client-secret "$PASSWORD" --generate-ssh-keys &>/dev/null + set -x + az acs kubernetes get-credentials --resource-group "$NAME" --name "$NAME" +} + +function prepare_kubespray() { + apt-get update + apt-get install -y jq + + ssh-keygen -q -t rsa -N '' -f /root/.ssh/id_rsa + go get -u github.com/ebsarr/packet + + export PACKET_API_TOKEN=${PACKET_API_TOKEN:-} + export PACKET_PROJECT_ID=${PACKET_PROJECT_ID:-} + + packet admin create-sshkey -f /root/.ssh/id_rsa.pub --label "$NAME" --key="$PACKET_API_TOKEN" >ssh_key.js + export SSH_KEY_ID + SSH_KEY_ID=$(jq -r .id ssh_key.js) + + packet baremetal create-device --facility ams1 --hostname "$NAME" --os-type ubuntu_16_04 --project-id "$PACKET_PROJECT_ID" --key="$PACKET_API_TOKEN" >js.json + + export DEVICE_ID + DEVICE_ID=$(jq -r .id js.json) + + export PUBLIC_IP + PUBLIC_IP=$(jq -r .ip_addresses[0].address js.json) + + ssh -o "StrictHostKeyChecking no" root@"$PUBLIC_IP" swapoff -a + + apt-get install -y ansible + + git clone https://github.com/kubernetes-incubator/kubespray.git + pushd kubespray + git checkout -b tags/v2.5.0 + + pip install -r requirements.txt + cp -rfp inventory/sample inventory/mycluster + + cat >inventory/mycluster/hosts.ini <sc.yaml </dev/null +apt-get install -y python-pip lsb-release &>/dev/null + +# install kubectl +curl -LO https://storage.googleapis.com/kubernetes-release/release/"$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)"/bin/linux/amd64/kubectl &>/dev/null +chmod +x ./kubectl +mv ./kubectl /bin/kubectl + +# install onessl +curl -fsSL -o onessl https://github.com/kubepack/onessl/releases/download/$ONESSL_VERSION/onessl-linux-amd64 +chmod +x onessl +mv onessl /usr/local/bin/ + +# install pharmer +if [[ "$ClusterProvider" != "cncf" && "$ClusterProvider" != "kubespray" && "$ClusterProvider" != "aws" ]]; then + pushd /tmp + curl -LO https://cdn.appscode.com/binaries/pharmer/$PHARMER_VERSION/pharmer-linux-amd64 + chmod +x pharmer-linux-amd64 + mv pharmer-linux-amd64 /bin/pharmer + popd + # mkdir -p "$GOPATH"/src/github.com/pharmer + # pushd "$GOPATH"/src/github.com/pharmer + # git clone https://github.com/pharmer/pharmer + # cd pharmer + # ./hack/builddeps.sh + # ./hack/make.py + # popd +fi diff --git a/concourse/init.sh b/concourse/init.sh new file mode 100755 index 000000000..39caa28b1 --- /dev/null +++ b/concourse/init.sh @@ -0,0 +1,24 @@ +#!/usr/bin/env bash + +GOPATH=$(go env GOPATH) +REPO_ROOT="$GOPATH/src/github.com/$ORG_NAME/$REPO_NAME" +PHARMER_VERSION="0.1.0-rc.5" +ONESSL_VERSION="0.7.0" +ClusterProvider=$ClusterProvider + +# copy $REPO_ROOT to $GOPATH +mkdir -p "$GOPATH"/src/github.com/$ORG_NAME +cp -r $REPO_NAME "$GOPATH"/src/github.com/$ORG_NAME + +# install all the dependencies and prepeare cluster +source "$REPO_ROOT/hack/libbuild/concourse/dependencies.sh" +source "$REPO_ROOT/hack/libbuild/concourse/cluster.sh" + +pushd "$GOPATH"/src/github.com/$ORG_NAME/$REPO_NAME + +# changed name of branch +# this is necessary because operator image tag is based on branch name +# for parallel tests, if two test build image of same tag, it'll create problem +# one test may finish early and delete image while other is using it +git checkout -b $(git rev-parse --short HEAD)-$ClusterProvider +popd diff --git a/libbuild.py b/libbuild.py index 493cc8688..79bba0e23 100644 --- a/libbuild.py +++ b/libbuild.py @@ -174,13 +174,15 @@ def go_build(name, goos, goarch, main, compress=False, upx=False): if linker_opts: ldflags = "-ldflags '{}'".format(' '.join(linker_opts)) + tags = "-tags 'osusergo netgo static_build'" + bindir = 'dist/{name}'.format(name=name) if not os.path.isdir(bindir): os.makedirs(bindir) if goos == 'alpine': repo_dir = REPO_ROOT[len(GOPATH):] uid = check_output('id -u').strip() - cmd = "docker run --rm -u {uid} -v /tmp:/.cache -v {repo_root}:/go{repo_dir} -w /go{repo_dir} -e {cgo_env} golang:1.9-alpine {goc} build -o {bindir}/{name}-{goos}-{goarch}{ext} {cgo} {ldflags} {main}".format( + cmd = "docker run --rm -u {uid} -v /tmp:/.cache -v {repo_root}:/go{repo_dir} -w /go{repo_dir} -e {cgo_env} golang:1.9-alpine {goc} build -o {bindir}/{name}-{goos}-{goarch}{ext} {cgo} {ldflags} {tags} {main}".format( repo_root=REPO_ROOT, repo_dir=repo_dir, uid=uid, @@ -192,11 +194,12 @@ def go_build(name, goos, goarch, main, compress=False, upx=False): cgo_env=cgo_env, cgo=cgo, ldflags=ldflags, + tags=tags, ext='.exe' if goos == 'windows' else '', main=main ) else: - cmd = "GOOS={goos} GOARCH={goarch} {cgo_env} {goc} build -o {bindir}/{name}-{goos}-{goarch}{ext} {cgo} {ldflags} {main}".format( + cmd = "GOOS={goos} GOARCH={goarch} {cgo_env} {goc} build -o {bindir}/{name}-{goos}-{goarch}{ext} {cgo} {ldflags} {tags} {main}".format( name=name, goc=GOC, goos=goos, @@ -205,6 +208,7 @@ def go_build(name, goos, goarch, main, compress=False, upx=False): cgo_env=cgo_env, cgo=cgo, ldflags=ldflags, + tags=tags, ext='.exe' if goos == 'windows' else '', main=main )