-
Notifications
You must be signed in to change notification settings - Fork 6
62 lines (50 loc) · 2.8 KB
/
rust.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
name: Tests
on: [create, pull_request]
env:
CARGO_TERM_COLOR: always
jobs:
run-tests:
runs-on: ubuntu-latest
steps:
- name: Start K3S
uses: debianmaster/actions-k3s@v1.0.1
id: k3s
with:
version: 'latest'
- uses: actions/checkout@v2
- name: Run tests
run: |
# 🄿🅁🄴🄿🄰🅁🄰🅃🄸🄾🄽🅂
# debianmaster/actions-k3s sets owner of the Kubeconfig output to a different user.
# To generate kubeconfigs for specific service accounts, current user must have read rights to the cluster-admin kubeconfig folder
sudo chown $(id -u):$(id -g) /tmp/output/
export CLUSTER_ADMIN_KUBECONFIG=$KUBECONFIG
# Create cluster role and a service account with permissions and related kubeconfig for CLI module
kubectl apply -f cli/tests/permissions/cluster_role.yaml
bash tests_common/k8s_cluster_setup/kubeconfig.sh h2o-cli default
# Create cluster role and a service account with permissions and related kubeconfig for DEPLOYMENT MODULE
kubectl apply -f deployment/tests/permissions/cluster_role.yaml
bash tests_common/k8s_cluster_setup/kubeconfig.sh h2o-deployment default
# Create cluster role and a service account with permissions and related kubeconfig for OPERATOR
kubectl apply -f operator/tests/permissions/cluster_role.yaml
kubectl apply -f operator/crd/h2os.h2o.ai.crd.yaml
bash tests_common/k8s_cluster_setup/kubeconfig.sh h2o-operator default
# 🅃🄴🅂🅃🅂
# Each module is tested with kubeconfig reflecting service account with just enough permissions
# for the given module.
#Test CLI module
export KUBECONFIG=$(pwd)/kubeconfigs-generated/kubeconfig-h2o-cli-default.yaml
cargo test -p h2ok --verbose
# Test DEPLOYMENT module
export KUBECONFIG=$(pwd)/kubeconfigs-generated/kubeconfig-h2o-deployment-default.yaml
cargo test -p deployment --verbose
# Test OPERATOR module
export KUBECONFIG=$(pwd)/kubeconfigs-generated/kubeconfig-h2o-operator-default.yaml
cargo test -p h2o-operator --verbose
# Create new service account for OPERATOR with CRD v1beta1
# Permissions are on purpose expected to be the same for v1beta1 H2O CRD, therefore the same ClusterRole is used
export KUBECONFIG=$CLUSTER_ADMIN_KUBECONFIG
kubectl apply -f operator/bundle/manifests/h2os.h2o.ai.crd.yaml # Overrides previous H2O CRDs
# Test OPERATOR module with CRD v1beta1 to test out the Red Hat version of the H2O custom resource
export KUBECONFIG=$(pwd)/kubeconfigs-generated/kubeconfig-h2o-operator-default.yaml
cargo test -p h2o-operator --verbose