Fix bugs #39
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: E2E Tests | |
on: | |
push: | |
pull_request: | |
jobs: | |
test-e2e: | |
name: Run on Ubuntu | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
packages: write | |
id-token: write | |
steps: | |
- name: Clone the code | |
uses: actions/checkout@v4 | |
- name: Tailscale | |
uses: tailscale/github-action@v2 | |
with: | |
oauth-client-id: ${{ secrets.TS_OAUTH_CLIENT_ID }} | |
oauth-secret: ${{ secrets.TS_OAUTH_SECRET }} | |
tags: tag:ci | |
- name: Install and Run SSH server | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y openssh-server | |
sudo systemctl start ssh | |
sudo systemctl status ssh | |
whoami | |
mkdir -p ~/.ssh | |
curl -L https://github.com/tsuzu.keys >> ~/.ssh/authorized_keys | |
- run: | | |
cd .github && docker compose up -d | |
docker ps -a | |
curl -LO https://github.com/lxc/incus/releases/latest/download/bin.linux.incus.x86_64 | |
sudo install *incus* /usr/local/bin/incus | |
- uses: nick-fields/retry@v3 | |
with: | |
timeout_seconds: 15 | |
max_attempts: 30 | |
continue_on_error: false | |
command: | | |
docker exec -i incus incus config show | |
- uses: actions/github-script@v7 | |
with: | |
script: | | |
const audience = 'incus'; | |
const homedir = require("os").homedir(); | |
const idToken = await core.getIDToken(audience); | |
await io.mkdirP(homedir + "/.config/incus/oidctokens") | |
await io.mkdirP("./shared") | |
await io.cp("./.github/config.yml", homedir + "/.config/incus/config.yml") | |
require("fs").writeFileSync(homedir + "/.config/incus/oidctokens/incus.json", JSON.stringify({ | |
"access_token": idToken, | |
"token": "bearer", | |
})) | |
require("fs").writeFileSync("./shared/incus.txt", idToken) | |
- run: | | |
mkdir -p ~/.config/incus/servercerts | |
docker cp incus:/var/lib/incus/server.crt ~/.config/incus/servercerts/incus.crt | |
docker exec -i incus incus config set core.https_address :8443 | |
docker exec -i incus incus config set oidc.audience incus | |
docker exec -i incus incus config set oidc.client.id incus | |
docker exec -i incus incus config set oidc.issuer https://token.actions.githubusercontent.com | |
incus profile list | |
incus profile show default | |
incus storage create default dir | |
incus profile device add default root disk pool=default path=/ | |
incus network create br0 --type=bridge | |
incus profile device add default eth0 nic name=eth0 nictype=bridged parent=br0 | |
sudo sysctl -w net.ipv4.ip_forward=1 | |
sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE | |
- name: Setup Go | |
uses: actions/setup-go@v5 | |
with: | |
go-version: '~1.22' | |
- name: Install the latest version of kind | |
run: | | |
curl -Lo ./kind https://kind.sigs.k8s.io/dl/latest/kind-linux-amd64 | |
chmod +x ./kind | |
sudo mv ./kind /usr/local/bin/kind | |
- name: Verify kind installation | |
run: kind version | |
- name: Create kind cluster | |
run: kind create cluster --config .github/kind.yaml | |
- name: Install cluster-api | |
run: | | |
curl -L https://github.com/kubernetes-sigs/cluster-api/releases/download/v1.9.1/clusterctl-linux-amd64 -o clusterctl | |
sudo install -o root -g root -m 0755 clusterctl /usr/local/bin/clusterctl | |
# Enable the experimental Cluster topology feature. | |
export CLUSTER_TOPOLOGY=true | |
# Initialize the management cluster | |
clusterctl init --infrastructure docker | |
- name: Running Test e2e | |
run: | | |
export INCUS_CERT=~/.config/incus/servercerts/incus.crt | |
export INCUS_TOKEN=~/.config/incus/oidctokens/incus.txt | |
go mod tidy | |
make test-e2e | |
exit 1 | |
- name: Wait | |
if: failure() | |
run: | | |
sleep 3600 | |
echo "Failed" |