forked from apache/skywalking-swck
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathe2e.yaml
101 lines (97 loc) · 3.8 KB
/
e2e.yaml
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
setup:
env: kind
file: ../kind.yaml
steps:
- name: prepare e2e.yaml
command: bash hack/prepare-e2e.sh
- name: install cert-manager
command: |
# kind k8s cluster is in $TMPDIR
export KUBECONFIG=$TMPDIR/e2e-k8s.config
kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/v1.8.0/cert-manager.yaml
wait:
- namespace: cert-manager
resource: pod
for: condition=Ready
- name: install operator
command: |
export OPERATOR_IMG=controller
make -C operator docker-build
kind load docker-image controller
make -C operator install
make -C operator deploy
wait:
- namespace: skywalking-swck-system
resource: pod
for: condition=Ready
- name: install metrics-adapter
command: |
export ADAPTER_IMG=metrics-adapter
make -C adapter docker-build
kind load docker-image metrics-adapter
make -C adapter deploy
kubectl wait pods -n skywalking-custom-metrics-system -l app=custom-metrics-apiserver --for condition=Ready --timeout=90s
- name: setup oapserver and ui
command: |
kubectl create namespace skywalking-system
grep -B20 "\-\-\-" test/e2e/skywalking-components.yaml | kubectl apply -f -
wait:
- namespace: skywalking-system
resource: OAPServer/skywalking-system
for: condition=Available
- name: setup java agent demo
command: |
kubectl label namespace skywalking-system swck-injection=enabled
sed 's/oap-service/skywalking-system-oap.skywalking-system/' test/e2e/demo.yaml | kubectl create -f -
wait:
- namespace: skywalking-system
resource: deployment/demo
for: condition=Available
- name: setup the hpa of java agent demo
command: |
kubectl apply -f test/e2e/hpa-demo.yaml
kind:
expose-ports:
- namespace: skywalking-system
resource: service/demo
port: 8085
- namespace: skywalking-system
resource: service/skywalking-system-oap
port: 12800
timeout: 20m
cleanup:
# always never success failure
on: always
trigger:
action: http
interval: 30s
times: 30
url: http://${service_demo_host}:${service_demo_8085}/hello
method: GET
verify:
# verify with retry strategy
retry:
# max retry count
count: 10
# the interval between two attempts, e.g. 10s, 1m.
interval: 10s
cases:
- query: swctl --display yaml --base-url=http://${service_skywalking_system_oap_host}:${service_skywalking_system_oap_12800}/graphql metrics linear --name service_cpm --service-name Your_ApplicationName | yq e 'to_entries' -
expected: ../verify/hpa-metrics.yaml
# the trigger will do 30 times, as the hpa's value is set as 5, so the deployment's replicas will be 3(maxReplicas).
- query: 'kubectl get deployment demo -n skywalking-system -o jsonpath=''{.status.replicas}'' | yq e ''{"replicas": .}'' - | yq e ''to_entries'' -'
expected: ../verify/replicas.yaml