2016-10-05 19:37:32 +00:00
#!/bin/bash
# Copyright 2016 The Kubernetes 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.
# This script generates the Github Release page and uploads all the binaries/etc to that page
# This is intended to be run on a new release tag in order to generate the github release page for that release
2016-12-24 04:11:05 +00:00
# The script expects the following env variables:
2016-12-23 11:46:04 +00:00
# VERSION_MAJOR: The major version of the tag to be released.
# VERSION_MINOR: The minor version of the tag to be released.
# VERSION_BUILD: The build version of the tag to be released.
2017-06-20 15:45:30 +00:00
# ISO_SHA256: The sha 256 of the minikube-iso for the current release.
2016-12-23 11:46:04 +00:00
# GITHUB_TOKEN: The Github API access token. Injected by the Jenkins credential provider.
2016-10-05 19:37:32 +00:00
2016-12-23 11:46:04 +00:00
set -e
2016-10-05 19:37:32 +00:00
export TAGNAME = v${ VERSION_MAJOR } .${ VERSION_MINOR } .${ VERSION_BUILD }
export DEB_VERSION = ${ VERSION_MAJOR } .${ VERSION_MINOR } -${ VERSION_BUILD }
export GITHUB_ORGANIZATION = "kubernetes"
export GITHUB_REPO = "minikube"
export PROJECT_NAME = "minikube"
export DARWIN_SHA256 = $( cat out/minikube-darwin-amd64.sha256)
export LINUX_SHA256 = $( cat out/minikube-linux-amd64.sha256)
export WINDOWS_SHA256 = $( cat out/minikube-windows-amd64.exe.sha256)
# Description could be moved into file on machine or fetched via URL. Doing this for now as it is the simplest, portable solution.
# ================================================================================
export DESCRIPTION = " # Minikube ${ TAGNAME }
Minikube is still under active development, and features may change at any time. Release notes are available [ here] ( https://github.com/kubernetes/minikube/blob/${ TAGNAME } /CHANGELOG.md) .
## Distribution
2017-06-20 15:45:30 +00:00
Minikube is distributed in binary form for Linux, OSX, and Windows systems for the ${ TAGNAME } release. Please note that Windows support is currently experimental and may have issues. Binaries are available through GitHub or on Google Cloud Storage. The direct GCS links are:
2016-10-05 19:37:32 +00:00
[ Darwin/amd64] ( https://storage.googleapis.com/minikube/releases/${ TAGNAME } /minikube-darwin-amd64)
[ Linux/amd64] ( https://storage.googleapis.com/minikube/releases/${ TAGNAME } /minikube-linux-amd64)
[ Windows/amd64] ( https://storage.googleapis.com/minikube/releases/${ TAGNAME } /minikube-windows-amd64.exe)
## Installation
### OSX
\` \` \` shell
2018-07-27 06:41:04 +00:00
curl -Lo minikube https://storage.googleapis.com/minikube/releases/${ TAGNAME } /minikube-darwin-amd64 && chmod +x minikube && sudo cp minikube /usr/local/bin/ && rm minikube
2016-10-05 19:37:32 +00:00
\` \` \`
2018-07-27 06:41:04 +00:00
Feel free to leave off \` \` \` sudo cp minikube /usr/local/bin/ && rm minikube\` \` \` if you would like to add minikube to your path manually.
2016-10-05 19:37:32 +00:00
2018-06-24 23:29:51 +00:00
Or you can install via homebrew with \` brew cask install minikube\` .
2018-05-30 21:25:24 +00:00
2016-10-05 19:37:32 +00:00
### Linux
\` \` \` shell
2018-07-27 06:41:04 +00:00
curl -Lo minikube https://storage.googleapis.com/minikube/releases/${ TAGNAME } /minikube-linux-amd64 && chmod +x minikube && sudo cp minikube /usr/local/bin/ && rm minikube
2016-10-05 19:37:32 +00:00
\` \` \`
2018-07-27 06:41:04 +00:00
Feel free to leave off \` \` \` sudo cp minikube /usr/local/bin/ && rm minikube\` \` \` if you would like to add minikube to your path manually.
2016-10-05 19:37:32 +00:00
### Debian Package (.deb) [Experimental]
Download the \` minikube_${ DEB_VERSION } .deb\` file, and install it using \` sudo dpkg -i minikube_$( DEB_VERSION) .deb\`
### Windows [Experimental]
2017-06-20 15:45:30 +00:00
Download the \` minikube-windows-amd64.exe\` file, rename it to \` minikube.exe\` and add it to your path.
2016-10-05 19:37:32 +00:00
### Windows Installer [Experimental]
Download the \` minikube-installer.exe\` file, and execute the installer. This will automatically add minikube.exe to your path with an uninstaller available as well.
## Usage
Documentation is available [ here] ( https://github.com/kubernetes/minikube/blob/${ TAGNAME } /README.md) .
## Checksums
Minikube consists of a binary executable and a VM image in ISO format. To verify the contents of your distribution, you can compare sha256 hashes with these values:
\` \` \`
$ tail -n +1 -- out/*.sha256
= = > out/minikube-darwin-amd64.sha256 <= =
${ DARWIN_SHA256 }
= = > out/minikube-linux-amd64.sha256 <= =
${ LINUX_SHA256 }
= = > out/minikube-windows-amd64.exe.sha256 <= =
${ WINDOWS_SHA256 }
\` \` \`
### ISO
\` \` \` shell
$ openssl sha256 minikube.iso
2016-12-23 11:46:04 +00:00
SHA256( minikube.iso) =
2016-10-05 19:37:32 +00:00
${ ISO_SHA256 }
\` \` \`
"
# ================================================================================
# Deleting release from github before creating new one
github-release delete --user ${ GITHUB_ORGANIZATION } --repo ${ GITHUB_REPO } --tag ${ TAGNAME } || true
# Creating a new release in github
github-release release \
--user ${ GITHUB_ORGANIZATION } \
--repo ${ GITHUB_REPO } \
--tag ${ TAGNAME } \
--name " ${ TAGNAME } " \
--description " ${ DESCRIPTION } "
# Uploading the files into github
2017-10-27 00:01:57 +00:00
FILES_TO_UPLOAD = (
'minikube-linux-amd64'
'minikube-linux-amd64.sha256'
'minikube-darwin-amd64'
'minikube-darwin-amd64.sha256'
'minikube-windows-amd64'
2018-07-17 15:18:16 +00:00
'minikube-windows-amd64.sha256'
2017-10-27 00:01:57 +00:00
'minikube-installer.exe'
" minikube_ ${ DEB_VERSION } .deb "
'docker-machine-driver-kvm2'
'docker-machine-driver-hyperkit'
)
for UPLOAD in " ${ FILES_TO_UPLOAD [@] } "
do
2018-06-27 21:59:15 +00:00
n = 0
until [ $n -ge 5 ]
do
github-release upload --user ${ GITHUB_ORGANIZATION } --repo ${ GITHUB_REPO } --tag ${ TAGNAME } --name $UPLOAD --file out/$UPLOAD && break
n = $[ $n +1]
sleep 15
done
2017-10-27 00:01:57 +00:00
done