Skip to content

Commit

Permalink
Merge pull request #11 from essobedo/upgrade-kind-and-kubectl
Browse files Browse the repository at this point in the history
Upgrade default version of kind and kubectl
  • Loading branch information
squakez authored Feb 9, 2023
2 parents 4fedef2 + d7ca1cf commit b53ad9c
Show file tree
Hide file tree
Showing 7 changed files with 46 additions and 25 deletions.
15 changes: 8 additions & 7 deletions .github/workflows/test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@ name: Test

on:
pull_request:
branches:
- main
push:
branches:
- main
Expand Down Expand Up @@ -31,8 +33,8 @@ jobs:
strategy:
matrix:
version:
- v0.11.1
- v0.10.0
- v0.17.0
- v0.16.0
os: [ubuntu-latest, macos-latest]
runs-on: ${{ matrix.os }}
steps:
Expand All @@ -54,8 +56,8 @@ jobs:
strategy:
matrix:
version:
- v0.11.1
- v0.10.0
- v0.17.0
- v0.16.0
os: [ubuntu-latest, macos-latest]
runs-on: ${{ matrix.os }}
steps:
Expand Down Expand Up @@ -86,7 +88,7 @@ jobs:
strategy:
matrix:
version:
- v0.11.1
- v0.17.0
os: [ubuntu-latest, macos-latest]
runs-on: ${{ matrix.os }}
steps:
Expand Down Expand Up @@ -132,8 +134,7 @@ jobs:
strategy:
matrix:
knative_version:
- v0.24.0
- v1.0.0
- v1.9.0
os: [ubuntu-latest, macos-latest]
runs-on: ${{ matrix.os }}
steps:
Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,14 +17,14 @@ For more information, reference the GitHub Help Documentation for [Creating a wo

For more information on inputs, see the [API Documentation](https://developer.github.com/v3/repos/releases/#input)

- `version`: The KinD version to use (default: `v0.11.1`)
- `version`: The KinD version to use (default: `v0.17.0`)
- `config`: The path to the KinD config file
- `node_image`: The Docker image for the cluster nodes
- `cluster_name`: The name of the cluster to create (default: `kind`)
- `wait`: The duration to wait for the control plane to become ready (default: `60s`)
- `log_level`: The log level for KinD
- `registry`: Configures an insecure registry on `kind-registry:5000` to be used with KinD (default: `true`)
- `kubectl_version`: The kubectl version to use (default: `v1.21.1`)
- `kubectl_version`: The kubectl version to use (default: `v1.26.1`)
- `knative_serving`: The version of Knative Serving to install on the Kind cluster (not installed by default - example: `v1.0.0`)
- `knative_kourier`: The version of Knative Net Kourier to install on the Kind cluster (not installed by default - example: `v1.0.0`)
- `knative_eventing`: The version of Knative Eventing to install on the Kind cluster (not installed by default - example: `v1.0.0`)
Expand Down
4 changes: 2 additions & 2 deletions action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ branding:
icon: cloud
inputs:
version:
description: "The KinD version to use (default: v0.11.1)"
description: "The KinD version to use (default: v0.17.0)"
config:
description: "The path to the KinD config file"
node_image:
Expand All @@ -20,7 +20,7 @@ inputs:
registry:
description: "Configures an insecure registry on kind-registry:5000 to be used with KinD (default: true)"
kubectl_version:
description: "The version of kubectl to use (default: v1.20.0)"
description: "The version of kubectl to use (default: v1.26.1)"
knative_serving:
description: "The version of Knative Serving to install on the Kind cluster (not installed by default - example: v1.0.0)"
knative_kourier:
Expand Down
13 changes: 11 additions & 2 deletions kind.sh
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,9 @@ set -o errexit
set -o nounset
set -o pipefail

DEFAULT_KIND_VERSION=v0.11.1
DEFAULT_KIND_VERSION=v0.17.0
DEFAULT_CLUSTER_NAME=kind
DEFAULT_KUBECTL_VERSION=v1.21.1
DEFAULT_KUBECTL_VERSION=v1.26.1

show_help() {
cat << EOF
Expand Down Expand Up @@ -49,6 +49,7 @@ main() {

install_kind
install_kubectl
install_docker
create_kind_cluster

}
Expand Down Expand Up @@ -169,6 +170,14 @@ install_kubectl() {
kubectl version --client --output=yaml
}

install_docker() {
if [ "$RUNNER_OS" == "macOS" ] && ! [ -x "$(command -v docker)" ]; then
echo 'Installing docker...'
brew install docker colima
colima start
fi
}

create_kind_cluster() {
echo 'Creating kind cluster...'
local args=(create cluster "--name=$cluster_name" "--wait=$wait")
Expand Down
16 changes: 11 additions & 5 deletions knative.sh
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,13 @@ parse_command_line() {

install_prerequisites() {
echo "Installing yq for patching Knative resources..."
sudo pip install yq
if [ "$RUNNER_OS" == "macOS" ]; then
brew install yq
else
wget https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 -O /usr/local/bin/yq
chmod +x /usr/local/bin/yq
fi
yq --version
}

install_serving() {
Expand All @@ -118,7 +124,7 @@ install_serving() {
kubectl apply --filename $base/serving-crds.yaml
echo "Waiting for resources to be initialized..."
sleep 5
curl -L -s $base/serving-core.yaml | yq 'del(.spec.template.spec.containers[]?.resources)' -y | yq 'del(.metadata.annotations."knative.dev/example-checksum")' -y | kubectl apply -f -
curl -L -s $base/serving-core.yaml | yq 'del(.spec.template.spec.containers[]?.resources)' | yq 'del(.metadata.annotations."knative.dev/example-checksum")' | kubectl apply -f -
echo "Waiting for resources to be initialized..."
sleep 60
kubectl get pod -n knative-serving
Expand Down Expand Up @@ -151,17 +157,17 @@ install_eventing() {
kubectl apply --filename $base/eventing-crds.yaml
echo "Waiting for resources to be initialized..."
sleep 5
curl -L -s $base/eventing-core.yaml | yq 'del(.spec.template.spec.containers[]?.resources)' -y | yq 'del(.metadata.annotations."knative.dev/example-checksum")' -y | kubectl apply -f -
curl -L -s $base/eventing-core.yaml | yq 'del(.spec.template.spec.containers[]?.resources)' | yq 'del(.metadata.annotations."knative.dev/example-checksum")' | kubectl apply -f -
# Eventing channels
set +e
curl -L -s $base/in-memory-channel.yaml | yq 'del(.spec.template.spec.containers[]?.resources)' -y | yq 'del(.metadata.annotations."knative.dev/example-checksum")' -y | kubectl apply -f -
curl -L -s $base/in-memory-channel.yaml | yq 'del(.spec.template.spec.containers[]?.resources)' | yq 'del(.metadata.annotations."knative.dev/example-checksum")' | kubectl apply -f -
if [ $? -ne 0 ]; then
set -e
curl -L -s $base/in-memory-channel.yaml | kubectl apply -f -
fi
set -e
# Eventing broker
curl -L -s $base/mt-channel-broker.yaml | yq 'del(.spec.template.spec.containers[]?.resources)' -y | yq 'del(.metadata.annotations."knative.dev/example-checksum")' -y | kubectl apply -f -
curl -L -s $base/mt-channel-broker.yaml | yq 'del(.spec.template.spec.containers[]?.resources)' | yq 'del(.metadata.annotations."knative.dev/example-checksum")' | kubectl apply -f -
echo "Waiting for resources to be initialized..."
sleep 30
kubectl get pod -n knative-eventing
Expand Down
4 changes: 2 additions & 2 deletions main.sh
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ main() {
args_knative+=(--knative-eventing "${INPUT_KNATIVE_EVENTING}")
fi

if [[ -z "${INPUT_REGISTRY:-}" ]] || [[ "${INPUT_REGISTRY,,}" = "true" ]]; then
if [[ -z "${INPUT_REGISTRY:-}" ]] || [[ "$(echo ${INPUT_REGISTRY} | tr '[:upper:]' '[:lower:]')" = "true" ]]; then
if [[ ${args:+exist} == "exist" ]] && [[ ${#args[@]} -gt 0 ]]; then
"$SCRIPT_DIR/registry.sh" "${args[@]}"
else
Expand All @@ -82,7 +82,7 @@ main() {
"$SCRIPT_DIR/kind.sh"
fi

if [[ -z "${INPUT_REGISTRY:-}" ]] || [[ "${INPUT_REGISTRY,,}" = "true" ]]; then
if [[ -z "${INPUT_REGISTRY:-}" ]] || [[ "$(echo ${INPUT_REGISTRY} | tr '[:upper:]' '[:lower:]')" = "true" ]]; then
if [[ ${args:+exist} == "exist" ]] && [[ ${#args[@]} -gt 0 ]]; then
"$SCRIPT_DIR/registry.sh" "--document" "true" "${args[@]}"
else
Expand Down
15 changes: 10 additions & 5 deletions registry.sh
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ main() {

if [[ "$document" = "false" ]]
then
install_docker
create_registry
connect_registry
create_kind_config
Expand Down Expand Up @@ -121,16 +122,20 @@ parse_command_line() {
done
}

create_registry() {
echo "Creating registry \"$registry_name\" on port $registry_port from image \"$registry_image\"..."
install_docker() {
if [ "$RUNNER_OS" == "macOS" ] && ! [ -x "$(command -v docker)" ]; then
brew install docker colima
colima start
echo 'Installing docker...'
brew install docker colima
colima start
fi
}

create_registry() {
echo "Creating registry \"$registry_name\" on port $registry_port from image \"$registry_image\"..."
docker run -d --restart=always -p "${registry_port}:5000" --name "${registry_name}" $registry_image > /dev/null

# Adding registry to /etc/hosts
sudo -- bash -c 'echo "127.0.0.1 $registry_name" >> /etc/hosts'
echo "127.0.0.1 $registry_name" | sudo tee -a /etc/hosts

# Exporting the registry location for subsequent jobs
echo "KIND_REGISTRY=${registry_name}:${registry_port}" >> $GITHUB_ENV
Expand Down

0 comments on commit b53ad9c

Please sign in to comment.