mirror of
https://github.com/k3s-io/k3s.git
synced 2024-06-07 19:41:36 +00:00
tests/vagrant: refactor vagrant smoke tests (#4484)
- updated `tests/TESTING.md` - cgroup, snapshotter, and install tests all under tests/vagrant - cgroup and snapshotter workflows trigger for all code changes on all branches (excluding markdown docs, install script, and other vagrant tests) - install workflow triggers for relevant script and fixture changes, only on master or pull-requests that target it - integration and unit test workflows should not trigger for install script changes nor anything under tests/vagrant Signed-off-by: Jacob Blain Christen <jacob@rancher.com>
This commit is contained in:
parent
f18b3252c0
commit
c77efe64e1
91
.github/workflows/cgroup.yaml
vendored
Normal file
91
.github/workflows/cgroup.yaml
vendored
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
name: Control Group
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
paths-ignore:
|
||||||
|
- "**.md"
|
||||||
|
- "channel.yaml"
|
||||||
|
- "install.sh"
|
||||||
|
- "tests/**"
|
||||||
|
- "!tests/vagrant/cgroup/**"
|
||||||
|
- ".github/**"
|
||||||
|
- "!.github/workflows/cgroup.yaml"
|
||||||
|
pull_request:
|
||||||
|
paths-ignore:
|
||||||
|
- "**.md"
|
||||||
|
- "channel.yaml"
|
||||||
|
- "install.sh"
|
||||||
|
- "tests/**"
|
||||||
|
- "!tests/vagrant/cgroup/**"
|
||||||
|
- ".github/**"
|
||||||
|
- "!.github/workflows/cgroup.yaml"
|
||||||
|
workflow_dispatch: {}
|
||||||
|
jobs:
|
||||||
|
prep:
|
||||||
|
name: "Prepare"
|
||||||
|
runs-on: ubuntu-20.04
|
||||||
|
timeout-minutes: 40
|
||||||
|
steps:
|
||||||
|
- name: "Checkout"
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
with: { fetch-depth: 1 }
|
||||||
|
- name: "Build"
|
||||||
|
run: DOCKER_BUILDKIT=1 SKIP_VALIDATE=1 make
|
||||||
|
- name: "Upload"
|
||||||
|
uses: actions/upload-artifact@v2
|
||||||
|
with: { name: k3s, path: dist/artifacts/k3s }
|
||||||
|
test:
|
||||||
|
name: "Smoke Test"
|
||||||
|
needs: prep
|
||||||
|
# nested virtualization is only available on macOS hosts
|
||||||
|
runs-on: macos-10.15
|
||||||
|
timeout-minutes: 40
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
vm: [fedora-34]
|
||||||
|
mode: [unified]
|
||||||
|
max-parallel: 1
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
working-directory: tests/vagrant/cgroup/${{ matrix.mode }}/${{ matrix.vm }}
|
||||||
|
steps:
|
||||||
|
- name: "Checkout"
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
with: { fetch-depth: 1 }
|
||||||
|
- name: "Download Binary"
|
||||||
|
uses: actions/download-artifact@v2
|
||||||
|
with: { name: k3s, path: dist/artifacts/ }
|
||||||
|
- name: "Vagrant Cache"
|
||||||
|
uses: actions/cache@v2
|
||||||
|
with:
|
||||||
|
path: |
|
||||||
|
~/.vagrant.d/boxes
|
||||||
|
~/.vagrant.d/gems
|
||||||
|
key: cgroup-${{ hashFiles(format('tests/vagrant/cgroup/{0}/{1}/Vagrantfile', matrix.mode, matrix.vm)) }}
|
||||||
|
id: vagrant-cache
|
||||||
|
continue-on-error: true
|
||||||
|
- name: "Vagrant Plugin(s)"
|
||||||
|
run: vagrant plugin install vagrant-k3s
|
||||||
|
- name: "Vagrant Up ⏩ Install K3s"
|
||||||
|
run: vagrant up
|
||||||
|
- name: "K3s Start" # start k3s rootfull
|
||||||
|
run: vagrant ssh -- sudo systemctl start k3s-server
|
||||||
|
- name: "K3s Ready" # wait for k3s to be ready
|
||||||
|
run: vagrant provision --provision-with=k3s-ready
|
||||||
|
- name: "K3s Status" # kubectl get node,all -A -o wide
|
||||||
|
run: vagrant provision --provision-with=k3s-status
|
||||||
|
- name: "Sonobuoy (--mode=quick)"
|
||||||
|
env: {TEST_RESULTS_PATH: rootfull}
|
||||||
|
run: vagrant provision --provision-with=k3s-sonobuoy
|
||||||
|
- name: "K3s Stop" # stop k3s rootfull
|
||||||
|
run: vagrant ssh -- sudo systemctl stop k3s-server
|
||||||
|
- name: "Vagrant Reload"
|
||||||
|
run: vagrant reload
|
||||||
|
- name: "[Rootless] Starting K3s"
|
||||||
|
run: vagrant ssh -- systemctl --user start k3s-rootless
|
||||||
|
- name: "[Rootless] K3s Ready"
|
||||||
|
env: {TEST_KUBECONFIG: /home/vagrant/.kube/k3s.yaml}
|
||||||
|
run: vagrant provision --provision-with=k3s-ready
|
||||||
|
- name: "[Rootless] Sonobuoy (--mode=quick)"
|
||||||
|
env: {TEST_KUBECONFIG: /home/vagrant/.kube/k3s.yaml, TEST_RESULTS_PATH: rootless}
|
||||||
|
run: vagrant provision --provision-with=k3s-sonobuoy
|
80
.github/workflows/cgroup2.yaml
vendored
80
.github/workflows/cgroup2.yaml
vendored
@ -1,80 +0,0 @@
|
|||||||
name: cgroup2
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
paths-ignore:
|
|
||||||
- "**.md"
|
|
||||||
- "install.sh"
|
|
||||||
- "tests/install"
|
|
||||||
pull_request:
|
|
||||||
paths-ignore:
|
|
||||||
- "**.md"
|
|
||||||
- "install.sh"
|
|
||||||
- "tests/install"
|
|
||||||
workflow_dispatch: {}
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: "Build"
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
timeout-minutes: 40
|
|
||||||
steps:
|
|
||||||
- name: "Checkout"
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 1
|
|
||||||
- name: "Make"
|
|
||||||
run: DOCKER_BUILDKIT=1 SKIP_VALIDATE=1 make
|
|
||||||
- name: "Upload k3s binary"
|
|
||||||
uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: k3s
|
|
||||||
path: dist/artifacts/k3s
|
|
||||||
test:
|
|
||||||
name: "Test"
|
|
||||||
needs: build
|
|
||||||
# nested virtualization is only available on macOS hosts
|
|
||||||
runs-on: macos-10.15
|
|
||||||
timeout-minutes: 40
|
|
||||||
steps:
|
|
||||||
- name: "Checkout"
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 1
|
|
||||||
- name: "Download k3s binary"
|
|
||||||
uses: actions/download-artifact@v2
|
|
||||||
with:
|
|
||||||
name: k3s
|
|
||||||
path: ./tests/cgroup2
|
|
||||||
- name: "Boot Fedora VM"
|
|
||||||
run: |
|
|
||||||
cp -r k3s.service k3s-rootless.service ./tests/util ./tests/cgroup2
|
|
||||||
cd ./tests/cgroup2
|
|
||||||
vagrant up
|
|
||||||
vagrant ssh-config >> ~/.ssh/config
|
|
||||||
- name: "Starting k3s"
|
|
||||||
run: |
|
|
||||||
ssh default -- sudo systemctl start k3s
|
|
||||||
# Sonobuoy requires CoreDNS to be ready
|
|
||||||
- name: "Waiting for CoreDNS to be ready"
|
|
||||||
run: |
|
|
||||||
ssh default -- sudo KUBECONFIG=/etc/rancher/k3s/k3s.yaml /vagrant/util/wait-for-coredns.sh
|
|
||||||
# Vagrant is slow, so we set --mode=quick here
|
|
||||||
- name: "Run Sonobuoy (--mode=quick)"
|
|
||||||
run: |
|
|
||||||
ssh default -- sudo KUBECONFIG=/etc/rancher/k3s/k3s.yaml sonobuoy run --mode=quick --wait
|
|
||||||
- name: "Stopping k3s"
|
|
||||||
run: |
|
|
||||||
ssh default -- sudo systemctl stop k3s
|
|
||||||
# FIXME: rootful k3s processes are still running even after `systemctl stop k3s`, so we reboot the VM here.
|
|
||||||
# This reboot is also useful for ensuring `systemctl daemon-reload`: https://github.com/rootless-containers/rootlesscontaine.rs/issues/32
|
|
||||||
cd ./tests/cgroup2
|
|
||||||
vagrant halt
|
|
||||||
vagrant up
|
|
||||||
- name: "[Rootless] Starting k3s-rootless"
|
|
||||||
run: |
|
|
||||||
ssh default -- systemctl --user start k3s-rootless
|
|
||||||
- name: "[Rootless] Waiting for CoreDNS to be ready"
|
|
||||||
run: |
|
|
||||||
ssh default -- KUBECONFIG=/home/vagrant/.kube/k3s.yaml /vagrant/util/wait-for-coredns.sh
|
|
||||||
- name: "[Rootless] Run Sonobuoy (--mode=quick)"
|
|
||||||
run: |
|
|
||||||
ssh default -- KUBECONFIG=/home/vagrant/.kube/k3s.yaml sonobuoy run --mode=quick --wait
|
|
150
.github/workflows/install.yaml
vendored
150
.github/workflows/install.yaml
vendored
@ -1,111 +1,71 @@
|
|||||||
name: Installer
|
name: Install Script
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
|
branches: [main, master]
|
||||||
paths:
|
paths:
|
||||||
|
- "channel.yaml"
|
||||||
- "install.sh"
|
- "install.sh"
|
||||||
- "tests/install/**"
|
- "tests/vagrant/install/**"
|
||||||
pull_request:
|
pull_request:
|
||||||
|
branches: [main, master]
|
||||||
paths:
|
paths:
|
||||||
- "install.sh"
|
- "install.sh"
|
||||||
- "tests/install/**"
|
- "tests/vagrant/install/**"
|
||||||
workflow_dispatch: {}
|
workflow_dispatch: {}
|
||||||
jobs:
|
jobs:
|
||||||
install-centos-7:
|
test:
|
||||||
name: "CentOS 7"
|
name: "Smoke Test"
|
||||||
# nested virtualization is only available on macOS hosts
|
|
||||||
runs-on: macos-10.15
|
runs-on: macos-10.15
|
||||||
timeout-minutes: 40
|
timeout-minutes: 40
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
channel: [stable]
|
||||||
|
vm: [centos-7, centos-8, fedora-coreos, opensuse-leap, opensuse-microos, ubuntu-focal]
|
||||||
|
include:
|
||||||
|
- {channel: latest, vm: centos-8}
|
||||||
|
- {channel: latest, vm: ubuntu-focal}
|
||||||
|
- {channel: latest, vm: opensuse-leap}
|
||||||
|
- {channel: testing, vm: centos-8}
|
||||||
|
- {channel: testing, vm: opensuse-leap}
|
||||||
|
- {channel: testing, vm: ubuntu-focal}
|
||||||
|
max-parallel: 2
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
working-directory: tests/vagrant/install/${{ matrix.vm }}
|
||||||
|
env:
|
||||||
|
INSTALL_K3S_CHANNEL: ${{ matrix.channel }}
|
||||||
steps:
|
steps:
|
||||||
- name: "Checkout"
|
- name: "Checkout"
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
|
with: {fetch-depth: 1}
|
||||||
|
- name: "Vagrant Cache"
|
||||||
|
uses: actions/cache@v2
|
||||||
with:
|
with:
|
||||||
fetch-depth: 1
|
path: |
|
||||||
- name: "VagrantPlugin::K3S"
|
~/.vagrant.d/boxes
|
||||||
working-directory: tests/install/centos-7
|
~/.vagrant.d/gems
|
||||||
run: vagrant plugin install vagrant-k3s
|
key: install-${{ hashFiles(format('tests/vagrant/install/{0}/Vagrantfile', matrix.vm)) }}
|
||||||
- name: "Vagrant::⬆"
|
id: vagrant-cache
|
||||||
working-directory: tests/install/centos-7
|
continue-on-error: true
|
||||||
run: vagrant up
|
- name: "Vagrant Plugin(s)"
|
||||||
install-centos-8:
|
run: vagrant plugin install vagrant-k3s vagrant-reload
|
||||||
name: "CentOS 8"
|
- name: "Vagrant Up ⏩ Install K3s"
|
||||||
# nested virtualization is only available on macOS hosts
|
|
||||||
runs-on: macos-10.15
|
|
||||||
timeout-minutes: 40
|
|
||||||
steps:
|
|
||||||
- name: "Checkout"
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 1
|
|
||||||
- name: "VagrantPlugin::K3S"
|
|
||||||
working-directory: tests/install/centos-8
|
|
||||||
run: vagrant plugin install vagrant-k3s
|
|
||||||
- name: "Vagrant::⬆"
|
|
||||||
working-directory: tests/install/centos-8
|
|
||||||
run: vagrant up
|
|
||||||
install-fedora-coreos:
|
|
||||||
name: "Fedora CoreOS"
|
|
||||||
# nested virtualization is only available on macOS hosts
|
|
||||||
runs-on: macos-10.15
|
|
||||||
timeout-minutes: 40
|
|
||||||
steps:
|
|
||||||
- name: "Checkout"
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 1
|
|
||||||
- name: "VagrantPlugin::K3S"
|
|
||||||
working-directory: tests/install/fedora-coreos
|
|
||||||
run: vagrant plugin install vagrant-k3s
|
|
||||||
- name: "Vagrant::⬆"
|
|
||||||
working-directory: tests/install/fedora-coreos
|
|
||||||
run: vagrant up
|
|
||||||
install-opensuse-leap:
|
|
||||||
name: "openSUSE Leap"
|
|
||||||
# nested virtualization is only available on macOS hosts
|
|
||||||
runs-on: macos-10.15
|
|
||||||
timeout-minutes: 40
|
|
||||||
steps:
|
|
||||||
- name: "Checkout"
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 1
|
|
||||||
- name: "VagrantPlugin::K3S"
|
|
||||||
working-directory: tests/install/opensuse-leap
|
|
||||||
run: vagrant plugin install vagrant-k3s
|
|
||||||
- name: "Vagrant::⬆"
|
|
||||||
working-directory: tests/install/opensuse-leap
|
|
||||||
run: vagrant up
|
|
||||||
install-opensuse-microos:
|
|
||||||
name: "openSUSE MicroOS"
|
|
||||||
# nested virtualization is only available on macOS hosts
|
|
||||||
runs-on: macos-10.15
|
|
||||||
timeout-minutes: 40
|
|
||||||
steps:
|
|
||||||
- name: "Checkout"
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 1
|
|
||||||
- name: "VagrantPlugin::Reload"
|
|
||||||
working-directory: tests/install/opensuse-microos
|
|
||||||
run: vagrant plugin install vagrant-reload
|
|
||||||
- name: "VagrantPlugin::K3S"
|
|
||||||
working-directory: tests/install/opensuse-microos
|
|
||||||
run: vagrant plugin install vagrant-k3s
|
|
||||||
- name: "Vagrant::⬆"
|
|
||||||
working-directory: tests/install/opensuse-microos
|
|
||||||
run: vagrant up
|
|
||||||
install-ubuntu-focal:
|
|
||||||
name: "Ubuntu Focal"
|
|
||||||
# nested virtualization is only available on macOS hosts
|
|
||||||
runs-on: macos-10.15
|
|
||||||
timeout-minutes: 40
|
|
||||||
steps:
|
|
||||||
- name: "Checkout"
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
fetch-depth: 1
|
|
||||||
- name: "VagrantPlugin::K3S"
|
|
||||||
working-directory: tests/install/ubuntu-focal
|
|
||||||
run: vagrant plugin install vagrant-k3s
|
|
||||||
- name: "Vagrant::⬆"
|
|
||||||
working-directory: tests/install/ubuntu-focal
|
|
||||||
run: vagrant up
|
run: vagrant up
|
||||||
|
- name: "⏳ Node"
|
||||||
|
run: vagrant provision --provision-with=k3s-wait-for-node
|
||||||
|
- name: "⏳ CoreDNS"
|
||||||
|
run: vagrant provision --provision-with=k3s-wait-for-coredns
|
||||||
|
- name: "⏳ Local Storage"
|
||||||
|
run: vagrant provision --provision-with=k3s-wait-for-local-storage
|
||||||
|
continue-on-error: true
|
||||||
|
- name: "⏳ Metrics Server"
|
||||||
|
run: vagrant provision --provision-with=k3s-wait-for-metrics-server
|
||||||
|
continue-on-error: true
|
||||||
|
- name: "⏳ Traefik"
|
||||||
|
run: vagrant provision --provision-with=k3s-wait-for-traefik
|
||||||
|
continue-on-error: true
|
||||||
|
- name: "k3s-status"
|
||||||
|
run: vagrant provision --provision-with=k3s-status
|
||||||
|
- name: "k3s-procps"
|
||||||
|
run: vagrant provision --provision-with=k3s-procps
|
||||||
|
10
.github/workflows/integration.yaml
vendored
10
.github/workflows/integration.yaml
vendored
@ -3,13 +3,19 @@ on:
|
|||||||
push:
|
push:
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- "**.md"
|
- "**.md"
|
||||||
|
- "channel.yaml"
|
||||||
- "install.sh"
|
- "install.sh"
|
||||||
- "tests/install"
|
- "tests/vagrant/**"
|
||||||
|
- ".github/**"
|
||||||
|
- "!.github/workflows/integration.yaml"
|
||||||
pull_request:
|
pull_request:
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- "**.md"
|
- "**.md"
|
||||||
|
- "channel.yaml"
|
||||||
- "install.sh"
|
- "install.sh"
|
||||||
- "tests/install"
|
- "tests/vagrant/**"
|
||||||
|
- ".github/**"
|
||||||
|
- "!.github/workflows/integration.yaml"
|
||||||
workflow_dispatch: {}
|
workflow_dispatch: {}
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
|
83
.github/workflows/snapshotter.yaml
vendored
83
.github/workflows/snapshotter.yaml
vendored
@ -1,71 +1,80 @@
|
|||||||
name: Snapshotter Testing
|
name: Snapshotter
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
|
- "**.md"
|
||||||
|
- "channel.yaml"
|
||||||
- "install.sh"
|
- "install.sh"
|
||||||
- "tests/cgroup2/**"
|
- "tests/**"
|
||||||
- "tests/install/**"
|
- "!tests/vagrant/snapshotter/**"
|
||||||
- "tests/integration/**"
|
- ".github/**"
|
||||||
- "tests/unitcoverage/**"
|
- "!.github/workflows/snapshotter.yaml"
|
||||||
pull_request:
|
pull_request:
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
|
- "**.md"
|
||||||
|
- "channel.yaml"
|
||||||
- "install.sh"
|
- "install.sh"
|
||||||
- "tests/cgroup2/**"
|
- "tests/**"
|
||||||
- "tests/install/**"
|
- "!tests/vagrant/snapshotter/**"
|
||||||
- "tests/integration/**"
|
- ".github/**"
|
||||||
- "tests/unitcoverage/**"
|
- "!.github/workflows/snapshotter.yaml"
|
||||||
workflow_dispatch: {}
|
workflow_dispatch: {}
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
prep:
|
||||||
name: "Build"
|
name: "Prepare"
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
timeout-minutes: 40
|
timeout-minutes: 40
|
||||||
steps:
|
steps:
|
||||||
- name: "Checkout"
|
- name: "Checkout"
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
with:
|
with: { fetch-depth: 1 }
|
||||||
fetch-depth: 1
|
|
||||||
- name: "Build"
|
- name: "Build"
|
||||||
run: DOCKER_BUILDKIT=1 SKIP_VALIDATE=1 make
|
run: DOCKER_BUILDKIT=1 SKIP_VALIDATE=1 make
|
||||||
- name: "Upload Binary"
|
- name: "Upload Binary"
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with: { name: k3s, path: dist/artifacts/k3s }
|
||||||
name: k3s
|
|
||||||
path: dist/artifacts/k3s
|
|
||||||
- name: "Upload Images"
|
|
||||||
uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: k3s-airgap-images-amd64.tar
|
|
||||||
path: dist/artifacts/k3s-airgap-images-amd64.tar
|
|
||||||
test:
|
test:
|
||||||
name: "Test"
|
name: "Smoke Test"
|
||||||
|
needs: prep
|
||||||
# nested virtualization is only available on macOS hosts
|
# nested virtualization is only available on macOS hosts
|
||||||
runs-on: macos-10.15
|
runs-on: macos-10.15
|
||||||
needs: build
|
|
||||||
timeout-minutes: 40
|
timeout-minutes: 40
|
||||||
strategy:
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
vm: [opensuse-leap]
|
vm: [opensuse-leap]
|
||||||
|
snapshotter: [btrfs]
|
||||||
|
max-parallel: 1
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
working-directory: tests/vagrant/snapshotter/${{ matrix.snapshotter }}/${{ matrix.vm }}
|
||||||
|
env:
|
||||||
|
VAGRANT_EXPERIMENTAL: disks
|
||||||
steps:
|
steps:
|
||||||
- name: "Checkout"
|
- name: "Checkout"
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
with:
|
with: { fetch-depth: 1 }
|
||||||
fetch-depth: 1
|
|
||||||
- name: "Download Binary"
|
- name: "Download Binary"
|
||||||
uses: actions/download-artifact@v2
|
uses: actions/download-artifact@v2
|
||||||
|
with: { name: k3s, path: dist/artifacts/ }
|
||||||
|
- name: "Vagrant Cache"
|
||||||
|
uses: actions/cache@v2
|
||||||
with:
|
with:
|
||||||
name: k3s
|
path: |
|
||||||
path: dist/artifacts/
|
~/.vagrant.d/boxes
|
||||||
- name: "Download Images"
|
~/.vagrant.d/gems
|
||||||
uses: actions/download-artifact@v2
|
key: snapshotter-${{ hashFiles(format('tests/vagrant/snapshotter/{0}/{1}/Vagrantfile', matrix.snapshotter, matrix.vm)) }}
|
||||||
with:
|
id: vagrant-cache
|
||||||
name: k3s-airgap-images-amd64.tar
|
continue-on-error: true
|
||||||
path: dist/artifacts/
|
|
||||||
- name: "Vagrant Plugin(s)"
|
- name: "Vagrant Plugin(s)"
|
||||||
working-directory: tests/snapshotter/btrfs/${{ matrix.vm }}
|
|
||||||
run: vagrant plugin install vagrant-k3s
|
run: vagrant plugin install vagrant-k3s
|
||||||
- name: "Vagrant VM"
|
- name: "Vagrant Up ⏩ Install K3s"
|
||||||
working-directory: tests/snapshotter/btrfs/${{ matrix.vm }}
|
|
||||||
env:
|
|
||||||
VAGRANT_EXPERIMENTAL: disks
|
|
||||||
run: vagrant up
|
run: vagrant up
|
||||||
|
- name: "⏳ Node"
|
||||||
|
run: vagrant provision --provision-with=k3s-wait-for-node
|
||||||
|
- name: "⏳ CoreDNS"
|
||||||
|
run: vagrant provision --provision-with=k3s-wait-for-coredns
|
||||||
|
- name: "k3s-status" # kubectl get node,all -A -o wide
|
||||||
|
run: vagrant provision --provision-with=k3s-status
|
||||||
|
- name: "k3s-snapshots" # if no snapshots then we fail
|
||||||
|
run: vagrant provision --provision-with=k3s-snapshots
|
||||||
|
10
.github/workflows/unitcoverage.yaml
vendored
10
.github/workflows/unitcoverage.yaml
vendored
@ -3,13 +3,19 @@ on:
|
|||||||
push:
|
push:
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- "**.md"
|
- "**.md"
|
||||||
|
- "channel.yaml"
|
||||||
- "install.sh"
|
- "install.sh"
|
||||||
- "tests/install"
|
- "tests/vagrant/**"
|
||||||
|
- ".github/**"
|
||||||
|
- "!.github/workflows/unitcoverage.yaml"
|
||||||
pull_request:
|
pull_request:
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- "**.md"
|
- "**.md"
|
||||||
|
- "channel.yaml"
|
||||||
- "install.sh"
|
- "install.sh"
|
||||||
- "tests/install"
|
- "tests/vagrant/**"
|
||||||
|
- ".github/**"
|
||||||
|
- "!.github/workflows/unitcoverage.yaml"
|
||||||
workflow_dispatch: {}
|
workflow_dispatch: {}
|
||||||
jobs:
|
jobs:
|
||||||
test:
|
test:
|
||||||
|
@ -4,7 +4,7 @@ Go testing in K3s comes in 3 forms: Unit, Integration, and End-to-End (E2E). Thi
|
|||||||
document will explain *when* each test should be written and *how* each test should be
|
document will explain *when* each test should be written and *how* each test should be
|
||||||
generated, formatted, and run.
|
generated, formatted, and run.
|
||||||
|
|
||||||
Note: all shell commands given are relateive to the root k3s repo directory.
|
Note: all shell commands given are relative to the root k3s repo directory.
|
||||||
___
|
___
|
||||||
|
|
||||||
## Unit Tests
|
## Unit Tests
|
||||||
@ -95,6 +95,80 @@ sudo KUBECONFIG=/etc/rancher/k3s/k3s.yaml sonobuoy results <TAR_FILE_FROM_RETRIE
|
|||||||
|
|
||||||
___
|
___
|
||||||
|
|
||||||
|
## Smoke Tests
|
||||||
|
|
||||||
|
Smoke tests are defined under the [tests/vagrant](../tests/vagrant) path at the root of this repository.
|
||||||
|
The sub-directories therein contain fixtures for running simple clusters to assert correct behavior for "happy path"
|
||||||
|
scenarios. These fixtures are mostly self-contained Vagrantfiles describing single-node installations that are
|
||||||
|
easily spun up with Vagrant for the `libvirt` and `virtualbox` providers:
|
||||||
|
|
||||||
|
- [Install Script](../tests/vagrant/install) :arrow_right: on proposed changes to [install.sh](../install.sh)
|
||||||
|
- [CentOS 7](../tests/vagrant/install/centos-7) (stand-in for RHEL 7)
|
||||||
|
- [CentOS 8](../tests/vagrant/install/centos-8) (stand-in for RHEL 8)
|
||||||
|
- [Leap 15.3](../tests/vagrant/install/opensuse-microos) (stand-in for SLES)
|
||||||
|
- [MicroOS](../tests/vagrant/install/opensuse-microos) (stand-in for SLE-Micro)
|
||||||
|
- [Ubuntu 20.04](../tests/vagrant/install/ubuntu-focal) (Focal Fossa)
|
||||||
|
- [Control Groups](../tests/vagrant/cgroup) :arrow_right: on any code change
|
||||||
|
- [mode=unified](../tests/vagrant/cgroup/unified) (cgroups v2)
|
||||||
|
- [Fedora 34](../tests/vagrant/cgroup/unified/fedora-34) (rootfull + rootless)
|
||||||
|
- [Snapshotter](../tests/vagrant/snapshotter/btrfs/opensuse-leap) :arrow_right: on any code change
|
||||||
|
- [BTRFS](../tests/vagrant/snapshotter/btrfs) ([containerd built-in](https://github.com/containerd/containerd/tree/main/snapshots/btrfs))
|
||||||
|
- [Leap 15.3](../tests/vagrant/snapshotter/btrfs/opensuse-leap)
|
||||||
|
|
||||||
|
When adding new installer test(s) please copy the prevalent style for the `Vagrantfile`.
|
||||||
|
Ideally, the boxes used for additional assertions will support the default `virtualbox` provider which
|
||||||
|
enables them to be used by our Github Actions Workflow(s). See:
|
||||||
|
- [cgroup.yaml](../.github/workflows/cgroup.yaml).
|
||||||
|
- [install.yaml](../.github/workflows/install.yaml).
|
||||||
|
|
||||||
|
### Framework
|
||||||
|
|
||||||
|
If you are new to Vagrant, Hashicorp has written some pretty decent introductory tutorials and docs, see:
|
||||||
|
- https://learn.hashicorp.com/collections/vagrant/getting-started
|
||||||
|
- https://www.vagrantup.com/docs/installation
|
||||||
|
|
||||||
|
#### Plugins and Providers
|
||||||
|
|
||||||
|
The `libvirt` and `vmware_desktop` providers cannot be used without first [installing the relevant plugins](https://www.vagrantup.com/docs/cli/plugin#plugin-install)
|
||||||
|
which are [`vagrant-libvirt`](https://github.com/vagrant-libvirt/vagrant-libvirt) and
|
||||||
|
[`vagrant-vmware-desktop`](https://www.vagrantup.com/docs/providers/vmware/installation), respectively.
|
||||||
|
Much like the default [`virtualbox` provider](https://www.vagrantup.com/docs/providers/virtualbox) these will do
|
||||||
|
nothing useful without also installing the relevant server runtimes and/or client programs.
|
||||||
|
|
||||||
|
#### Environment Variables
|
||||||
|
|
||||||
|
These can be set on the CLI or exported before invoking Vagrant:
|
||||||
|
- `TEST_VM_CPUS` (default :arrow_right: 2)<br/>
|
||||||
|
The number of vCPU for the guest to use.
|
||||||
|
- `TEST_VM_MEMORY` (default :arrow_right: 2048)<br/>
|
||||||
|
The number of megabytes of memory for the guest to use.
|
||||||
|
- `TEST_VM_BOOT_TIMEOUT` (default :arrow_right: 600)<br/>
|
||||||
|
The time in seconds that Vagrant will wait for the machine to boot and be accessible.
|
||||||
|
|
||||||
|
### Running
|
||||||
|
|
||||||
|
The **Install Script** tests can be run by changing to the fixture directory and invoking `vagrant up`, e.g.:
|
||||||
|
```shell
|
||||||
|
cd tests/vagrant/install/centos-8
|
||||||
|
vagrant up
|
||||||
|
# the following provisioners are optional. the do not run by default but are invoked
|
||||||
|
# explicitly by github actions workflow to avoid certain timeout issues on slow runners
|
||||||
|
vagrant provision --provision-with=k3s-wait-for-node
|
||||||
|
vagrant provision --provision-with=k3s-wait-for-coredns
|
||||||
|
vagrant provision --provision-with=k3s-wait-for-local-storage
|
||||||
|
vagrant provision --provision-with=k3s-wait-for-metrics-server
|
||||||
|
vagrant provision --provision-with=k3s-wait-for-traefik
|
||||||
|
vagrant provision --provision-with=k3s-status
|
||||||
|
vagrant provision --provision-with=k3s-procps
|
||||||
|
```
|
||||||
|
|
||||||
|
The **Control Groups** and **Snapshotter** tests require that k3s binary is built at `dist/artifacts/k3s`.
|
||||||
|
They are invoked similarly, i.e. `vagrant up`, but with different sets of named shell provisioners.
|
||||||
|
Take a look at the individual Vagrantfiles and/or the Github Actions workflows that harness them to get
|
||||||
|
an idea of how they can be invoked.
|
||||||
|
|
||||||
|
___
|
||||||
|
|
||||||
## End-to-End (E2E) Tests
|
## End-to-End (E2E) Tests
|
||||||
|
|
||||||
End-to-end tests utilize [Ginkgo](https://onsi.github.io/ginkgo/) and [Gomega](https://onsi.github.io/gomega/) like the integration tests, but rely on separate testing utilities and are self-contained within the `test/e2e` directory. E2E tests cover complete K3s single and multi-cluster configuration and administration: bringup, update, teardown etc.
|
End-to-end tests utilize [Ginkgo](https://onsi.github.io/ginkgo/) and [Gomega](https://onsi.github.io/gomega/) like the integration tests, but rely on separate testing utilities and are self-contained within the `test/e2e` directory. E2E tests cover complete K3s single and multi-cluster configuration and administration: bringup, update, teardown etc.
|
||||||
|
5
tests/cgroup2/.gitignore
vendored
5
tests/cgroup2/.gitignore
vendored
@ -1,5 +0,0 @@
|
|||||||
k3s
|
|
||||||
k3s.service
|
|
||||||
k3s-rootless.service
|
|
||||||
util/
|
|
||||||
.vagrant/
|
|
61
tests/cgroup2/Vagrantfile
vendored
61
tests/cgroup2/Vagrantfile
vendored
@ -1,61 +0,0 @@
|
|||||||
# -*- mode: ruby -*-
|
|
||||||
# vi: set ft=ruby :
|
|
||||||
|
|
||||||
# Vagrant box for testing k3s with cgroup v2.
|
|
||||||
# Invoked via k3s/.github/workflows/cgroup2.yaml .
|
|
||||||
#
|
|
||||||
# The following files need to be present in this directory:
|
|
||||||
# - k3s
|
|
||||||
# - k3s.service
|
|
||||||
# - k3s-rootless.service
|
|
||||||
# - util/
|
|
||||||
Vagrant.configure("2") do |config|
|
|
||||||
config.vm.box = "fedora/34-cloud-base"
|
|
||||||
memory = 2048
|
|
||||||
cpus = 2
|
|
||||||
config.vm.provider :virtualbox do |v|
|
|
||||||
v.memory = memory
|
|
||||||
v.cpus = cpus
|
|
||||||
end
|
|
||||||
config.vm.provider :libvirt do |v|
|
|
||||||
v.memory = memory
|
|
||||||
v.cpus = cpus
|
|
||||||
end
|
|
||||||
config.vm.provision "install-k3s", type: "shell", run: "once" do |sh|
|
|
||||||
sh.inline = <<~SHELL
|
|
||||||
set -eux -o pipefail
|
|
||||||
|
|
||||||
# Install k3s binary
|
|
||||||
install -m 755 /vagrant/k3s /usr/local/bin
|
|
||||||
ln -sf /usr/local/bin/k3s /usr/local/bin/kubectl
|
|
||||||
|
|
||||||
# Install k3s systemd service (not launched here)
|
|
||||||
cp -f /vagrant/k3s.service /etc/systemd/system/k3s.service
|
|
||||||
touch /etc/systemd/system/k3s.service.env
|
|
||||||
systemctl daemon-reload
|
|
||||||
|
|
||||||
# Install sonobuoy binary
|
|
||||||
curl -fsSL https://github.com/vmware-tanzu/sonobuoy/releases/download/v0.20.0/sonobuoy_0.20.0_linux_amd64.tar.gz | tar xzvC /usr/local/bin sonobuoy
|
|
||||||
|
|
||||||
# [Rootless] Configure sysctl
|
|
||||||
echo "net.ipv4.ip_forward=1" > /etc/sysctl.d/rootless.conf
|
|
||||||
sysctl --system
|
|
||||||
|
|
||||||
# [Rootless] Enable cgroup v2 delegation
|
|
||||||
mkdir -p /etc/systemd/system/user@.service.d
|
|
||||||
cat <<-EOF > /etc/systemd/system/user@.service.d/delegate.conf
|
|
||||||
[Service]
|
|
||||||
Delegate=yes
|
|
||||||
EOF
|
|
||||||
systemctl daemon-reload
|
|
||||||
|
|
||||||
# [Rootless] Enable systemd lingering
|
|
||||||
loginctl enable-linger vagrant
|
|
||||||
|
|
||||||
# [Rootless] Install k3s-rootless systemd service (not launched here)
|
|
||||||
mkdir -p /home/vagrant/.config/systemd/user
|
|
||||||
cp -f /vagrant/k3s-rootless.service /home/vagrant/.config/systemd/user/k3s-rootless.service
|
|
||||||
chown -R vagrant:vagrant /home/vagrant/.config
|
|
||||||
SHELL
|
|
||||||
end
|
|
||||||
end
|
|
1
tests/vagrant/.gitignore
vendored
Normal file
1
tests/vagrant/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
.vagrant/
|
120
tests/vagrant/cgroup/unified/fedora-34/Vagrantfile
vendored
Normal file
120
tests/vagrant/cgroup/unified/fedora-34/Vagrantfile
vendored
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
# -*- mode: ruby -*-
|
||||||
|
# vi: set ft=ruby :
|
||||||
|
#
|
||||||
|
# Vagrant box for testing k3s with cgroup v2.
|
||||||
|
|
||||||
|
ENV['TEST_UNITFILE_ROOTFULL'] ||= '../../../../../k3s.service'
|
||||||
|
ENV['TEST_UNITFILE_ROOTLESS'] ||= '../../../../../k3s-rootless.service'
|
||||||
|
|
||||||
|
Vagrant.configure("2") do |config|
|
||||||
|
config.vagrant.plugins = {
|
||||||
|
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
||||||
|
}
|
||||||
|
config.vm.box = "fedora/34-cloud-base"
|
||||||
|
config.vm.boot_timeout = ENV['TEST_VM_BOOT_TIMEOUT'] || 600 # seconds
|
||||||
|
config.vm.synced_folder '../../../../../dist/artifacts', '/vagrant', type: 'rsync', disabled: false,
|
||||||
|
rsync__exclude: ENV['RSYNC_EXCLUDE'] || '*.tar.*'
|
||||||
|
|
||||||
|
config.vm.define 'cgroup-unified', primary: true do |test|
|
||||||
|
test.vm.hostname = 'smoke'
|
||||||
|
test.vm.provision :file, run: 'always', source: ENV['TEST_UNITFILE_ROOTFULL'], destination: 'k3s-rootfull.service'
|
||||||
|
test.vm.provision :file, run: 'always', source: ENV['TEST_UNITFILE_ROOTLESS'], destination: 'k3s-rootless.service'
|
||||||
|
test.vm.provision 'k3s-prepare', type: "shell", run: "once", privileged: true do |sh|
|
||||||
|
sh.inline = <<~SHELL
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eux -o pipefail
|
||||||
|
|
||||||
|
# Install k3s binary
|
||||||
|
install -vm 755 /vagrant/k3s /usr/local/bin
|
||||||
|
|
||||||
|
# Install k3s SELinux policy
|
||||||
|
dnf install -y https://github.com/k3s-io/k3s-selinux/releases/download/v0.5.testing.2/k3s-selinux-0.5-2.el8.noarch.rpm
|
||||||
|
|
||||||
|
# Install k3s systemd service (not launched here)
|
||||||
|
install -vm 644 -T /home/vagrant/k3s-rootfull.service /etc/systemd/system/k3s-server.service
|
||||||
|
touch /etc/systemd/system/k3s-server.service.env
|
||||||
|
systemctl daemon-reload
|
||||||
|
|
||||||
|
# Install sonobuoy binary
|
||||||
|
curl -fsSL https://github.com/vmware-tanzu/sonobuoy/releases/download/v0.20.0/sonobuoy_0.20.0_linux_amd64.tar.gz | tar xzvC /usr/local/bin sonobuoy
|
||||||
|
|
||||||
|
# [Rootless] Configure sysctl
|
||||||
|
echo "net.ipv4.ip_forward=1" > /etc/sysctl.d/rootless.conf
|
||||||
|
sysctl --system
|
||||||
|
# [Rootless] Enable cgroup v2 delegation
|
||||||
|
mkdir -p /etc/systemd/system/user@.service.d
|
||||||
|
cat <<-EOF > /etc/systemd/system/user@.service.d/delegate.conf
|
||||||
|
[Service]
|
||||||
|
Delegate=yes
|
||||||
|
EOF
|
||||||
|
systemctl daemon-reload
|
||||||
|
|
||||||
|
# [Rootless] Enable systemd lingering
|
||||||
|
loginctl enable-linger vagrant
|
||||||
|
|
||||||
|
# [Rootless] Install k3s-rootless systemd service (not launched here)
|
||||||
|
mkdir -p /home/vagrant/.config/systemd/user
|
||||||
|
cp -f /home/vagrant/k3s-rootless.service /home/vagrant/.config/systemd/user/k3s-rootless.service
|
||||||
|
chown -R vagrant:vagrant /home/vagrant/.config
|
||||||
|
SHELL
|
||||||
|
end
|
||||||
|
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
||||||
|
k3s.args = %w[server]
|
||||||
|
k3s.env = %w[INSTALL_K3S_NAME=server INSTALL_K3S_SKIP_DOWNLOAD=true K3S_TOKEN=vagrant INSTALL_K3S_SKIP_ENABLE=true]
|
||||||
|
k3s.config = {
|
||||||
|
'disable' => %w[local-storage metrics-server servicelb traefik],
|
||||||
|
'disable-helm-controller' => true,
|
||||||
|
'disable-network-policy' => true,
|
||||||
|
'write-kubeconfig-mode' => '0644',
|
||||||
|
}
|
||||||
|
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
||||||
|
end
|
||||||
|
test.vm.provision "k3s-ready", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
|
sh.env = {
|
||||||
|
:PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin",
|
||||||
|
:KUBECONFIG => ENV['TEST_KUBECONFIG'] || '/etc/rancher/k3s/k3s.yaml',
|
||||||
|
}
|
||||||
|
sh.inline = <<~SHELL
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eu -o pipefail
|
||||||
|
echo 'Waiting for node to be ready ...'
|
||||||
|
time timeout 500 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
||||||
|
time timeout 500 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
||||||
|
SHELL
|
||||||
|
end
|
||||||
|
test.vm.provision "k3s-status", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
|
sh.env = {
|
||||||
|
:PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin",
|
||||||
|
:KUBECONFIG => ENV['TEST_KUBECONFIG'] || '/etc/rancher/k3s/k3s.yaml',
|
||||||
|
}
|
||||||
|
sh.inline = <<~SHELL
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eux -o pipefail
|
||||||
|
kubectl get node,all -A -o wide
|
||||||
|
SHELL
|
||||||
|
end
|
||||||
|
test.vm.provision "k3s-sonobuoy", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
|
sh.env = {
|
||||||
|
:PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin",
|
||||||
|
:KUBECONFIG => ENV['TEST_KUBECONFIG'] || '/etc/rancher/k3s/k3s.yaml',
|
||||||
|
:RESULTS_PATH => ENV['TEST_RESULTS_PATH'] || '.',
|
||||||
|
}
|
||||||
|
sh.inline = <<~SHELL
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eux -o pipefail
|
||||||
|
sonobuoy run --mode=quick --wait
|
||||||
|
sonobuoy retrieve ${RESULTS_PATH}
|
||||||
|
sonobuoy results $(ls -rt ${RESULTS_PATH}/*.tar.gz | tail -1) | grep Status | grep passed
|
||||||
|
SHELL
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
config.vm.provision 'selinux-status', type: 'shell', run: 'once', inline: 'sestatus'
|
||||||
|
|
||||||
|
%w[libvirt virtualbox].each do |p|
|
||||||
|
config.vm.provider p do |v|
|
||||||
|
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
||||||
|
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
@ -2,71 +2,74 @@
|
|||||||
# vi: set ft=ruby :
|
# vi: set ft=ruby :
|
||||||
#
|
#
|
||||||
|
|
||||||
ENV['TEST_INSTALL_SH'] ||= '../../../install.sh'
|
ENV['TEST_INSTALL_SH'] ||= '../../../../install.sh'
|
||||||
|
|
||||||
Vagrant.configure("2") do |config|
|
Vagrant.configure("2") do |config|
|
||||||
config.vagrant.plugins = {
|
config.vagrant.plugins = {
|
||||||
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
||||||
}
|
}
|
||||||
|
config.vm.box = "dweomer/centos-7.9-amd64"
|
||||||
|
config.vm.boot_timeout = ENV['TEST_VM_BOOT_TIMEOUT'] || 600 # seconds
|
||||||
|
config.vm.synced_folder '.', '/vagrant', disabled: true
|
||||||
|
|
||||||
config.vm.define 'install-centos-7', primary: true do |test|
|
config.vm.define 'install-centos-7', primary: true do |test|
|
||||||
test.vm.box = 'centos/7'
|
test.vm.hostname = 'smoke'
|
||||||
test.vm.hostname = 'install'
|
|
||||||
test.vm.provision 'selinux-status', type: 'shell', run: 'once', inline: 'sestatus'
|
|
||||||
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
||||||
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
||||||
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
||||||
k3s.args = %w[server]
|
k3s.args = %w[server]
|
||||||
k3s.env = %w[INSTALL_K3S_NAME=server]
|
k3s.env = ENV.select{|k,v| k.start_with?('K3S_') || k.start_with?('INSTALL_K3S_')}.merge({
|
||||||
|
:INSTALL_K3S_NAME => 'server',
|
||||||
|
})
|
||||||
k3s.config = {
|
k3s.config = {
|
||||||
:selinux => true,
|
:selinux => true,
|
||||||
:token => 'vagrant',
|
:token => 'vagrant',
|
||||||
}
|
}
|
||||||
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-node", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-node", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
echo 'Waiting for node to be ready ...'
|
echo 'Waiting for node to be ready ...'
|
||||||
time timeout 120 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-status", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
@ -74,17 +77,19 @@ Vagrant.configure("2") do |config|
|
|||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status-selinux", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-procps", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eux -o pipefail
|
set -eux -o pipefail
|
||||||
ps auxZ | grep container_ | grep -v grep
|
ps auxZ | grep -E 'k3s|kube|container' | grep -v grep
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
%w[hyperv libvirt virtualbox vmware_desktop].each do |p|
|
config.vm.provision 'selinux-status', type: 'shell', run: 'once', inline: 'sestatus'
|
||||||
|
|
||||||
|
%w[libvirt virtualbox vmware_desktop].each do |p|
|
||||||
config.vm.provider p do |v|
|
config.vm.provider p do |v|
|
||||||
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
||||||
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
||||||
@ -94,6 +99,4 @@ Vagrant.configure("2") do |config|
|
|||||||
v.gui = false
|
v.gui = false
|
||||||
v.check_guest_additions = false
|
v.check_guest_additions = false
|
||||||
end
|
end
|
||||||
|
end
|
||||||
config.vm.synced_folder '.', '/vagrant', disabled: true
|
|
||||||
end
|
|
@ -2,71 +2,74 @@
|
|||||||
# vi: set ft=ruby :
|
# vi: set ft=ruby :
|
||||||
#
|
#
|
||||||
|
|
||||||
ENV['TEST_INSTALL_SH'] ||= '../../../install.sh'
|
ENV['TEST_INSTALL_SH'] ||= '../../../../install.sh'
|
||||||
|
|
||||||
Vagrant.configure("2") do |config|
|
Vagrant.configure("2") do |config|
|
||||||
config.vagrant.plugins = {
|
config.vagrant.plugins = {
|
||||||
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
||||||
}
|
}
|
||||||
|
config.vm.box = "dweomer/centos-8.4-amd64"
|
||||||
|
config.vm.boot_timeout = ENV['TEST_VM_BOOT_TIMEOUT'] || 600 # seconds
|
||||||
|
config.vm.synced_folder '.', '/vagrant', disabled: true
|
||||||
|
|
||||||
config.vm.define 'install-centos-8', primary: true do |test|
|
config.vm.define 'install-centos-8', primary: true do |test|
|
||||||
test.vm.box = 'centos/stream8'
|
test.vm.hostname = 'smoke'
|
||||||
test.vm.hostname = 'install'
|
|
||||||
test.vm.provision 'selinux-status', type: 'shell', run: 'once', inline: 'sestatus'
|
|
||||||
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
||||||
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
||||||
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
||||||
k3s.args = %w[server]
|
k3s.args = %w[server]
|
||||||
k3s.env = %w[INSTALL_K3S_NAME=server]
|
k3s.env = ENV.select{|k,v| k.start_with?('K3S_') || k.start_with?('INSTALL_K3S_')}.merge({
|
||||||
|
:INSTALL_K3S_NAME => 'server',
|
||||||
|
})
|
||||||
k3s.config = {
|
k3s.config = {
|
||||||
:selinux => true,
|
:selinux => true,
|
||||||
:token => 'vagrant',
|
:token => 'vagrant',
|
||||||
}
|
}
|
||||||
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-node", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-node", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
echo 'Waiting for node to be ready ...'
|
echo 'Waiting for node to be ready ...'
|
||||||
time timeout 120 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-status", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
@ -74,17 +77,19 @@ Vagrant.configure("2") do |config|
|
|||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status-selinux", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-procps", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eux -o pipefail
|
set -eux -o pipefail
|
||||||
ps auxZ | grep container_ | grep -v grep
|
ps auxZ | grep -E 'k3s|kube|container' | grep -v grep
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
%w[hyperv libvirt virtualbox vmware_desktop].each do |p|
|
config.vm.provision 'selinux-status', type: 'shell', run: 'once', inline: 'sestatus'
|
||||||
|
|
||||||
|
%w[libvirt virtualbox vmware_desktop].each do |p|
|
||||||
config.vm.provider p do |v|
|
config.vm.provider p do |v|
|
||||||
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
||||||
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
||||||
@ -94,6 +99,4 @@ Vagrant.configure("2") do |config|
|
|||||||
v.gui = false
|
v.gui = false
|
||||||
v.check_guest_additions = false
|
v.check_guest_additions = false
|
||||||
end
|
end
|
||||||
|
end
|
||||||
config.vm.synced_folder '.', '/vagrant', disabled: true
|
|
||||||
end
|
|
@ -2,71 +2,74 @@
|
|||||||
# vi: set ft=ruby :
|
# vi: set ft=ruby :
|
||||||
#
|
#
|
||||||
|
|
||||||
ENV['TEST_INSTALL_SH'] ||= '../../../install.sh'
|
ENV['TEST_INSTALL_SH'] ||= '../../../../install.sh'
|
||||||
|
|
||||||
Vagrant.configure("2") do |config|
|
Vagrant.configure("2") do |config|
|
||||||
config.vagrant.plugins = {
|
config.vagrant.plugins = {
|
||||||
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
||||||
}
|
}
|
||||||
|
config.vm.box = 'dhml/fedora-coreos-34.20210725.3.0-20210813'
|
||||||
|
config.vm.boot_timeout = ENV['TEST_VM_BOOT_TIMEOUT'] || 600 # seconds
|
||||||
|
config.vm.synced_folder '.', '/vagrant', disabled: true
|
||||||
|
|
||||||
config.vm.define 'install-fedora-coreos', primary: true do |test|
|
config.vm.define 'install-fedora-coreos', primary: true do |test|
|
||||||
test.vm.box = 'dhml/fedora-coreos-34.20210725.3.0-20210813'
|
test.vm.hostname = 'smoke'
|
||||||
test.vm.hostname = 'install'
|
|
||||||
test.vm.provision 'selinux-status', type: 'shell', run: 'once', inline: 'sestatus'
|
|
||||||
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
||||||
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
||||||
k3s.installer_url = 'file:///var/home/core/install.sh'
|
k3s.installer_url = 'file:///var/home/core/install.sh'
|
||||||
k3s.args = %w[server]
|
k3s.args = %w[server]
|
||||||
k3s.env = %w[INSTALL_K3S_NAME=server]
|
k3s.env = ENV.select{|k,v| k.start_with?('K3S_') || k.start_with?('INSTALL_K3S_')}.merge({
|
||||||
|
:INSTALL_K3S_NAME => 'server',
|
||||||
|
})
|
||||||
k3s.config = {
|
k3s.config = {
|
||||||
:selinux => true,
|
:selinux => true,
|
||||||
:token => 'vagrant',
|
:token => 'vagrant',
|
||||||
}
|
}
|
||||||
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-node", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-node", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
echo 'Waiting for node to be ready ...'
|
echo 'Waiting for node to be ready ...'
|
||||||
time timeout 120 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-status", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
@ -74,9 +77,19 @@ Vagrant.configure("2") do |config|
|
|||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
|
test.vm.provision "k3s-procps", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
|
sh.inline = <<~SHELL
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eux -o pipefail
|
||||||
|
ps auxZ | grep -E 'k3s|kube|container' | grep -v grep
|
||||||
|
SHELL
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
%w[hyperv libvirt virtualbox vmware_desktop].each do |p|
|
config.vm.provision 'selinux-status', type: 'shell', run: 'once', inline: 'sestatus'
|
||||||
|
|
||||||
|
%w[libvirt virtualbox vmware_desktop].each do |p|
|
||||||
config.vm.provider p do |v|
|
config.vm.provider p do |v|
|
||||||
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
||||||
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
||||||
@ -86,6 +99,4 @@ Vagrant.configure("2") do |config|
|
|||||||
v.gui = false
|
v.gui = false
|
||||||
v.check_guest_additions = false
|
v.check_guest_additions = false
|
||||||
end
|
end
|
||||||
|
|
||||||
config.vm.synced_folder '.', '/vagrant', disabled: true
|
|
||||||
end
|
end
|
@ -2,71 +2,76 @@
|
|||||||
# vi: set ft=ruby :
|
# vi: set ft=ruby :
|
||||||
#
|
#
|
||||||
|
|
||||||
ENV['TEST_INSTALL_SH'] ||= '../../../install.sh'
|
ENV['TEST_INSTALL_SH'] ||= '../../../../install.sh'
|
||||||
|
|
||||||
Vagrant.configure("2") do |config|
|
Vagrant.configure("2") do |config|
|
||||||
config.vagrant.plugins = {
|
config.vagrant.plugins = {
|
||||||
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
||||||
}
|
}
|
||||||
|
config.vm.box = 'opensuse/Leap-15.3.x86_64'
|
||||||
|
config.vm.boot_timeout = ENV['TEST_VM_BOOT_TIMEOUT'] || 600 # seconds
|
||||||
|
config.vm.synced_folder '.', '/vagrant', disabled: true
|
||||||
|
|
||||||
config.vm.define 'install-opensuse-leap', primary: true do |test|
|
config.vm.define 'install-opensuse-leap', primary: true do |test|
|
||||||
test.vm.box = 'opensuse/Leap-15.3.x86_64'
|
test.vm.hostname = 'smoke'
|
||||||
test.vm.hostname = 'install'
|
|
||||||
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
||||||
# /sbin/apparmor_parser is needed by the 1.21 kubelet if the value of /sys/module/apparmor/parameters/enabled is Y
|
# /sbin/apparmor_parser is needed by the 1.21 kubelet if the value of /sys/module/apparmor/parameters/enabled is Y
|
||||||
test.vm.provision 'k3s-prepare', type: 'shell', run: 'once', inline: 'zypper install -y apparmor-parser'
|
test.vm.provision 'k3s-prepare', type: 'shell', run: 'once', inline: 'zypper install -y apparmor-parser'
|
||||||
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
||||||
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
||||||
k3s.args = %w[server]
|
k3s.args = %w[server]
|
||||||
k3s.env = %w[INSTALL_K3S_NAME=server INSTALL_K3S_SKIP_SELINUX_RPM=true]
|
k3s.env = ENV.select{|k,v| k.start_with?('K3S_') || k.start_with?('INSTALL_K3S_')}.merge({
|
||||||
|
:INSTALL_K3S_NAME => 'server',
|
||||||
|
:INSTALL_K3S_SKIP_SELINUX_RPM => 'true',
|
||||||
|
})
|
||||||
k3s.config = {
|
k3s.config = {
|
||||||
:token => 'vagrant',
|
:token => 'vagrant',
|
||||||
}
|
}
|
||||||
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-node", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-node", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
echo 'Waiting for node to be ready ...'
|
echo 'Waiting for node to be ready ...'
|
||||||
time timeout 120 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostnamectl --static) 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostnamectl --static) 2>/dev/null); do sleep 5; done'
|
||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-status", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
@ -74,9 +79,17 @@ Vagrant.configure("2") do |config|
|
|||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
|
test.vm.provision "k3s-procps", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
|
sh.inline = <<~SHELL
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eux -o pipefail
|
||||||
|
ps auxZ | grep -E 'k3s|kube|container' | grep -v grep
|
||||||
|
SHELL
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
%w[hyperv libvirt virtualbox vmware_desktop].each do |p|
|
%w[libvirt virtualbox vmware_desktop].each do |p|
|
||||||
config.vm.provider p do |v|
|
config.vm.provider p do |v|
|
||||||
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
||||||
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
||||||
@ -86,6 +99,4 @@ Vagrant.configure("2") do |config|
|
|||||||
v.gui = false
|
v.gui = false
|
||||||
v.check_guest_additions = false
|
v.check_guest_additions = false
|
||||||
end
|
end
|
||||||
|
|
||||||
config.vm.synced_folder '.', '/vagrant', disabled: true
|
|
||||||
end
|
end
|
@ -2,23 +2,26 @@
|
|||||||
# vi: set ft=ruby :
|
# vi: set ft=ruby :
|
||||||
#
|
#
|
||||||
|
|
||||||
ENV['TEST_INSTALL_SH'] ||= '../../../install.sh'
|
ENV['TEST_INSTALL_SH'] ||= '../../../../install.sh'
|
||||||
|
|
||||||
Vagrant.configure("2") do |config|
|
Vagrant.configure("2") do |config|
|
||||||
config.vagrant.plugins = {
|
config.vagrant.plugins = {
|
||||||
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
||||||
'vagrant-reload' => {},
|
'vagrant-reload' => {},
|
||||||
}
|
}
|
||||||
|
config.vm.box = 'dweomer/microos.amd64'
|
||||||
|
config.vm.boot_timeout = ENV['TEST_VM_BOOT_TIMEOUT'] || 600 # seconds
|
||||||
|
config.vm.synced_folder '.', '/vagrant', disabled: true
|
||||||
|
|
||||||
config.vm.define 'install-microos', primary: true do |test|
|
config.vm.define 'install-microos', primary: true do |test|
|
||||||
test.vm.box = 'dweomer/microos.amd64'
|
test.vm.hostname = 'smoke'
|
||||||
test.vm.hostname = 'install'
|
|
||||||
test.vm.provision 'selinux-status', type: 'shell', run: 'once', inline: 'sestatus'
|
|
||||||
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
||||||
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
||||||
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
||||||
k3s.args = %w[server]
|
k3s.args = %w[server]
|
||||||
k3s.env = %w[INSTALL_K3S_NAME=server]
|
k3s.env = ENV.select{|k,v| k.start_with?('K3S_') || k.start_with?('INSTALL_K3S_')}.merge({
|
||||||
|
:INSTALL_K3S_NAME => 'server',
|
||||||
|
})
|
||||||
k3s.config = {
|
k3s.config = {
|
||||||
:selinux => true,
|
:selinux => true,
|
||||||
:token => 'vagrant',
|
:token => 'vagrant',
|
||||||
@ -27,49 +30,49 @@ Vagrant.configure("2") do |config|
|
|||||||
end
|
end
|
||||||
# install.sh will move the snapshot forward when installing k3s-selinux policy, so, we reboot to pick that up
|
# install.sh will move the snapshot forward when installing k3s-selinux policy, so, we reboot to pick that up
|
||||||
test.vm.provision 'k3s-reload', type: 'reload', run: 'once'
|
test.vm.provision 'k3s-reload', type: 'reload', run: 'once'
|
||||||
test.vm.provision "k3s-wait-for-node", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-node", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
echo 'Waiting for node to be ready ...'
|
echo 'Waiting for node to be ready ...'
|
||||||
time timeout 120 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostnamectl --static) 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostnamectl --static) 2>/dev/null); do sleep 5; done'
|
||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-status", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
@ -77,17 +80,17 @@ Vagrant.configure("2") do |config|
|
|||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status-selinux", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-procps", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eux -o pipefail
|
set -eux -o pipefail
|
||||||
ps auxZ | grep container_ | grep -v grep
|
ps auxZ | grep -E 'k3s|kube|container' | grep -v grep
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
%w[hyperv libvirt virtualbox vmware_desktop].each do |p|
|
%w[libvirt virtualbox vmware_desktop].each do |p|
|
||||||
config.vm.provider p do |v|
|
config.vm.provider p do |v|
|
||||||
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
||||||
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
||||||
@ -97,6 +100,4 @@ Vagrant.configure("2") do |config|
|
|||||||
v.gui = false
|
v.gui = false
|
||||||
v.check_guest_additions = false
|
v.check_guest_additions = false
|
||||||
end
|
end
|
||||||
|
end
|
||||||
config.vm.synced_folder '.', '/vagrant', disabled: true
|
|
||||||
end
|
|
@ -2,71 +2,74 @@
|
|||||||
# vi: set ft=ruby :
|
# vi: set ft=ruby :
|
||||||
#
|
#
|
||||||
|
|
||||||
ENV['TEST_INSTALL_SH'] ||= '../../../install.sh'
|
ENV['TEST_INSTALL_SH'] ||= '../../../../install.sh'
|
||||||
|
|
||||||
Vagrant.configure("2") do |config|
|
Vagrant.configure("2") do |config|
|
||||||
config.vagrant.plugins = {
|
config.vagrant.plugins = {
|
||||||
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
||||||
}
|
}
|
||||||
|
config.vm.box = 'generic/ubuntu2004'
|
||||||
|
config.vm.boot_timeout = ENV['TEST_VM_BOOT_TIMEOUT'] || 600 # seconds
|
||||||
|
config.vm.synced_folder '.', '/vagrant', disabled: true
|
||||||
|
|
||||||
config.vm.define 'install-ubuntu-focal', primary: true do |test|
|
config.vm.define 'install-ubuntu-focal', primary: true do |test|
|
||||||
test.vm.box = 'generic/ubuntu2004'
|
test.vm.hostname = 'smoke'
|
||||||
test.vm.hostname = 'install'
|
|
||||||
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
test.vm.provision 'k3s-upload', type: 'file', run: 'always', source: ENV['TEST_INSTALL_SH'], destination: 'install.sh'
|
||||||
# sh is a symlink to dash, so, we need to sidestep this: https://github.com/dweomer/vagrant-k3s/blob/v0.1.2/lib/vagrant-k3s/provisioner.rb#L71
|
|
||||||
test.vm.provision 'k3s-prepare', type: 'shell', run: 'once', inline: 'ln -nsf bash /usr/bin/sh'
|
|
||||||
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
test.vm.provision 'k3s-install', type: 'k3s', run: 'once' do |k3s|
|
||||||
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
k3s.installer_url = 'file:///home/vagrant/install.sh'
|
||||||
k3s.args = %w[server]
|
k3s.args = %w[server]
|
||||||
k3s.env = %w[INSTALL_K3S_NAME=server INSTALL_K3S_SKIP_SELINUX_RPM=true]
|
k3s.env = ENV.select{|k,v| k.start_with?('K3S_') || k.start_with?('INSTALL_K3S_')}.merge({
|
||||||
|
:INSTALL_K3S_NAME => 'server',
|
||||||
|
:INSTALL_K3S_SKIP_SELINUX_RPM => 'true',
|
||||||
|
})
|
||||||
k3s.config = {
|
k3s.config = {
|
||||||
:token => 'vagrant',
|
:token => 'vagrant',
|
||||||
}
|
}
|
||||||
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-node", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-node", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
echo 'Waiting for node to be ready ...'
|
echo 'Waiting for node to be ready ...'
|
||||||
time timeout 120 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-local-storage", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/local-path-provisioner 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-metrics-server", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/metrics-server 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-traefik", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
time timeout 180 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/traefik 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-status", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
@ -74,9 +77,17 @@ Vagrant.configure("2") do |config|
|
|||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
|
test.vm.provision "k3s-procps", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
|
sh.inline = <<~SHELL
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eux -o pipefail
|
||||||
|
ps auxZ | grep -E 'k3s|kube|container' | grep -v grep
|
||||||
|
SHELL
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
%w[hyperv libvirt virtualbox vmware_desktop].each do |p|
|
%w[libvirt virtualbox vmware_desktop].each do |p|
|
||||||
config.vm.provider p do |v|
|
config.vm.provider p do |v|
|
||||||
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
||||||
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
||||||
@ -86,6 +97,4 @@ Vagrant.configure("2") do |config|
|
|||||||
v.gui = false
|
v.gui = false
|
||||||
v.check_guest_additions = false
|
v.check_guest_additions = false
|
||||||
end
|
end
|
||||||
|
|
||||||
config.vm.synced_folder '.', '/vagrant', disabled: true
|
|
||||||
end
|
end
|
@ -1,17 +1,20 @@
|
|||||||
# -*- mode: ruby -*-
|
# -*- mode: ruby -*-
|
||||||
# vi: set ft=ruby :
|
# vi: set ft=ruby :
|
||||||
#
|
#
|
||||||
|
# Vagrant box for testing k3s with the btrfs snapshotter. Usage:
|
||||||
ENV['TEST_VM_NAME'] ||= 'snapshotter-btrfs'
|
# VAGRANT_EXPERIMENTAL=disks vagrant up
|
||||||
ENV['TEST_VM_HOSTNAME'] ||= 'test'
|
|
||||||
|
|
||||||
Vagrant.configure("2") do |config|
|
Vagrant.configure("2") do |config|
|
||||||
config.vagrant.plugins = {
|
config.vagrant.plugins = {
|
||||||
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
'vagrant-k3s' => {:version => '~> 0.1.3'},
|
||||||
}
|
}
|
||||||
config.vm.define ENV['TEST_VM_NAME'], primary: true do |test|
|
config.vm.box = "opensuse/Leap-15.3.x86_64"
|
||||||
test.vm.box = "opensuse/Leap-15.3.x86_64"
|
config.vm.boot_timeout = ENV['TEST_VM_BOOT_TIMEOUT'] || 600 # seconds
|
||||||
test.vm.hostname = ENV['TEST_VM_HOSTNAME']
|
config.vm.synced_folder '../../../../../dist/artifacts', '/vagrant', type: 'rsync', disabled: false,
|
||||||
|
rsync__exclude: ENV['RSYNC_EXCLUDE'] || '*.tar.*'
|
||||||
|
|
||||||
|
config.vm.define 'snapshotter-btrfs', primary: true do |test|
|
||||||
|
test.vm.hostname = 'smoke'
|
||||||
test.vm.provision 'k3s-prepare', type: 'shell', run: 'once', privileged: true do |sh|
|
test.vm.provision 'k3s-prepare', type: 'shell', run: 'once', privileged: true do |sh|
|
||||||
sh.inline = <<~EOF
|
sh.inline = <<~EOF
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
@ -30,10 +33,8 @@ Vagrant.configure("2") do |config|
|
|||||||
umount /mnt
|
umount /mnt
|
||||||
mount -t btrfs -o subvol=@k3s /dev/${BTRFS_DEV} /var/lib/rancher/k3s
|
mount -t btrfs -o subvol=@k3s /dev/${BTRFS_DEV} /var/lib/rancher/k3s
|
||||||
fi
|
fi
|
||||||
if [ -e /vagrant/k3s ]; then
|
# Install k3s binary
|
||||||
cp -vf /vagrant/k3s /usr/local/bin/
|
install -m 755 /vagrant/k3s /usr/local/bin
|
||||||
chmod -v +x /usr/local/bin/k3s
|
|
||||||
fi
|
|
||||||
if [ -e /vagrant/*.tar ]; then
|
if [ -e /vagrant/*.tar ]; then
|
||||||
mkdir -vp /var/lib/rancher/k3s/agent/images
|
mkdir -vp /var/lib/rancher/k3s/agent/images
|
||||||
for tar in /vagrant/*.tar; do
|
for tar in /vagrant/*.tar; do
|
||||||
@ -53,38 +54,49 @@ Vagrant.configure("2") do |config|
|
|||||||
}
|
}
|
||||||
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
k3s.config_mode = '0644' # side-step https://github.com/k3s-io/k3s/issues/4321
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-ready", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-wait-for-node", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
echo 'Waiting for node to be ready ...'
|
echo 'Waiting for node to be ready ...'
|
||||||
time timeout 120 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostname) 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl wait --for condition=ready node/$(hostnamectl --static) 2>/dev/null); do sleep 5; done'
|
||||||
|
kubectl get node,all -A -o wide
|
||||||
|
SHELL
|
||||||
|
end
|
||||||
|
test.vm.provision "k3s-wait-for-coredns", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
|
sh.inline = <<~SHELL
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eu -o pipefail
|
||||||
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
time timeout 300 bash -c 'while ! (kubectl --namespace kube-system rollout status --timeout 10s deploy/coredns 2>/dev/null); do sleep 5; done'
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
test.vm.provision "k3s-status", type: "shell", run: "once" do |sh|
|
test.vm.provision "k3s-status", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
sh.inline = <<~SHELL
|
sh.inline = <<~SHELL
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eux -o pipefail
|
set -eux -o pipefail
|
||||||
kubectl get node,all -A -o wide
|
kubectl get node,all -A -o wide
|
||||||
|
SHELL
|
||||||
|
end
|
||||||
|
test.vm.provision "k3s-snapshots", type: "shell", run: ENV['CI'] == 'true' ? 'never' : 'once' do |sh|
|
||||||
|
sh.env = { :PATH => "/usr/local/bin:/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" }
|
||||||
|
sh.inline = <<~SHELL
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eux -o pipefail
|
||||||
btrfs subvolume list /var/lib/rancher/k3s/agent/containerd/io.containerd.snapshotter.v1.btrfs
|
btrfs subvolume list /var/lib/rancher/k3s/agent/containerd/io.containerd.snapshotter.v1.btrfs
|
||||||
SHELL
|
SHELL
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
%w[hyperv libvirt virtualbox vmware_desktop].each do |p|
|
%w[libvirt virtualbox].each do |p|
|
||||||
config.vm.provider p do |v|
|
config.vm.provider p do |v|
|
||||||
v.cpus = ENV['CPUS'] || 2
|
v.cpus = ENV['TEST_VM_CPUS'] || 2
|
||||||
v.memory = ENV['MEMORY'] || 2048
|
v.memory = ENV['TEST_VM_MEMORY'] || 2048
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
config.vm.provider :hyperv do |v,o|
|
|
||||||
o.vm.disk :disk, name: "btrfs", size: "8GB" # Requires VAGRANT_EXPERIMENTAL="disks"
|
|
||||||
end
|
|
||||||
|
|
||||||
config.vm.provider :libvirt do |v,o|
|
config.vm.provider :libvirt do |v,o|
|
||||||
v.storage :file, :size => '8G'
|
v.storage :file, :size => '8G'
|
||||||
end
|
end
|
||||||
@ -94,7 +106,4 @@ Vagrant.configure("2") do |config|
|
|||||||
v.check_guest_additions = false
|
v.check_guest_additions = false
|
||||||
o.vm.disk :disk, name: "btrfs", size: "8GB" # Requires VAGRANT_EXPERIMENTAL="disks"
|
o.vm.disk :disk, name: "btrfs", size: "8GB" # Requires VAGRANT_EXPERIMENTAL="disks"
|
||||||
end
|
end
|
||||||
|
|
||||||
config.vm.synced_folder '../../../../dist/artifacts', '/vagrant', type: 'rsync', disabled: ['1', 'true'].include?(ENV['RSYNC_DISABLE']),
|
|
||||||
rsync__exclude: ENV['RSYNC_EXCLUDE'] || '*.tar.*'
|
|
||||||
end
|
end
|
Loading…
Reference in New Issue
Block a user