-
Notifications
You must be signed in to change notification settings - Fork 5.4k
/
run-operator-tests.sh
61 lines (48 loc) · 1.99 KB
/
run-operator-tests.sh
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
#!/bin/bash
set -euo pipefail
# TODO(aslonnie): refactor this test to be hermetic.
echo "--- Build image"
bazel run //ci/ray_ci:build_in_docker -- docker \
--platform cpu --canonical-tag kuberay-test
docker tag rayproject/ray:kuberay-test ray-ci:kuberay-test
echo "--- Setup k8s environment"
bash ci/k8s/prep-k8s-environment.sh
kind load docker-image ray-ci:kuberay-test
# The following is essentially running
# python python/ray/tests/kuberay/setup/setup_kuberay.py
bash python/ray/autoscaler/kuberay/init-config.sh
kubectl create -k python/ray/autoscaler/kuberay/config/default
echo "--- Test ray cluster creation"
kubectl apply -f python/ray/tests/kuberay/setup/raycluster_test.yaml
kubectl get rayclusters.ray.io
kubectl delete -f python/ray/tests/kuberay/setup/raycluster_test.yaml
echo "--- Wait until all pods of test cluster are deleted"
kubectl get pods -o custom-columns=POD:metadata.name --no-headers
for i in {1..120}; do
if [[ "$(kubectl get pods -o custom-columns=POD:metadata.name --no-headers | wc -l)" == "0" ]]; then
break
fi
if [[ $i == 120 ]]; then
echo "Timed out waiting for pods to be deleted"
exit 1
fi
sleep 1
done
echo "--- Run bazel tests"
# Needs to send in the kubeconfig file in base64 encoding.
bazel run //ci/ray_ci:test_in_docker -- //python/ray/tests/... kuberay \
--build-name k8sbuild \
--network host \
--test-env=RAY_IMAGE=docker.io/library/ray-ci:kuberay-test \
--test-env=PULL_POLICY=Never \
--test-env=KUBECONFIG=/tmp/rayci-kubeconfig \
"--test-env=KUBECONFIG_BASE64=$(base64 -w0 "$HOME/.kube/config")"
# Test for autoscaler v2.
bazel run //ci/ray_ci:test_in_docker -- //python/ray/tests/... kuberay \
--build-name k8sbuild \
--network host \
--test-env=RAY_IMAGE=docker.io/library/ray-ci:kuberay-test \
--test-env=PULL_POLICY=Never \
--test-env=AUTOSCALER_V2=True \
--test-env=KUBECONFIG=/tmp/rayci-kubeconfig \
"--test-env=KUBECONFIG_BASE64=$(base64 -w0 "$HOME/.kube/config")"