Compare commits
2 Commits
118ff5319e
...
5005800844
| Author | SHA1 | Date |
|---|---|---|
|
|
5005800844 | |
|
|
081d3f0758 |
|
|
@ -1,11 +1,11 @@
|
|||
---
|
||||
spec_version: '1.0'
|
||||
indicators:
|
||||
throughput: "metricSelector=builtin:service.requestCount.total:merge(\"dt.entity.service\"):sum&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
error_rate: "metricSelector=builtin:service.errors.total.count:merge(\"dt.entity.service\"):avg&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p50: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(50)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p90: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(90)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p95: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(95)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
#rt_addToCart: "metricSelector=calc:service.itemscontroller.qg:filter(eq(url,addToCart)):merge(0):percentile(95)&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(SERVICE)"
|
||||
pg_heap_suspension: "metricSelector=builtin:tech.jvm.memory.gc.suspensionTime:merge(\"dt.entity.process_group_instance\"):max&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(PROCESS_GROUP_INSTANCE)"
|
||||
---
|
||||
spec_version: '1.0'
|
||||
indicators:
|
||||
throughput: "metricSelector=builtin:service.requestCount.total:merge(\"dt.entity.service\"):sum&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
error_rate: "metricSelector=builtin:service.errors.total.count:merge(\"dt.entity.service\"):avg&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p50: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(50)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p90: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(90)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p95: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(95)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
#rt_addToCart: "metricSelector=calc:service.itemscontroller.qg:filter(eq(url,addToCart)):merge(0):percentile(95)&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(SERVICE)"
|
||||
pg_heap_suspension: "metricSelector=builtin:tech.jvm.memory.gc.suspensionTime:merge(\"dt.entity.process_group_instance\"):max&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(PROCESS_GROUP_INSTANCE)"
|
||||
pg_cpu_usage: "metricSelector=builtin:tech.generic.cpu.usage:merge(\"dt.entity.process_group_instance\"):max&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(PROCESS_GROUP_INSTANCE)"
|
||||
|
|
@ -1,5 +1,5 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<jmeterTestPlan version="1.2" properties="5.0" jmeter="5.1.1 r1855137">
|
||||
<jmeterTestPlan version="1.2" properties="5.0" jmeter="5.2.1">
|
||||
<hashTree>
|
||||
<TestPlan guiclass="TestPlanGui" testclass="TestPlan" testname="Test Plan" enabled="true">
|
||||
<stringProp name="TestPlan.comments"></stringProp>
|
||||
|
|
@ -39,7 +39,7 @@
|
|||
</elementProp>
|
||||
<elementProp name="LoopCount" elementType="Argument">
|
||||
<stringProp name="Argument.name">LoopCount</stringProp>
|
||||
<stringProp name="Argument.value">1</stringProp>
|
||||
<stringProp name="Argument.value">1000</stringProp>
|
||||
<stringProp name="Argument.metadata">=</stringProp>
|
||||
</elementProp>
|
||||
</collectionProp>
|
||||
|
|
@ -60,11 +60,13 @@
|
|||
<boolProp name="ThreadGroup.scheduler">false</boolProp>
|
||||
<stringProp name="ThreadGroup.duration"></stringProp>
|
||||
<stringProp name="ThreadGroup.delay"></stringProp>
|
||||
<boolProp name="ThreadGroup.same_user_on_next_iteration">true</boolProp>
|
||||
</ThreadGroup>
|
||||
<hashTree>
|
||||
<CookieManager guiclass="CookiePanel" testclass="CookieManager" testname="HTTP Cookie Manager" enabled="true">
|
||||
<collectionProp name="CookieManager.cookies"/>
|
||||
<boolProp name="CookieManager.clearEachIteration">false</boolProp>
|
||||
<boolProp name="CookieManager.controlledByThreadGroup">false</boolProp>
|
||||
</CookieManager>
|
||||
<hashTree/>
|
||||
<HeaderManager guiclass="HeaderPanel" testclass="HeaderManager" testname="HTTP Header Manager" enabled="true">
|
||||
|
|
|
|||
|
|
@ -14,7 +14,7 @@ actions:
|
|||
image: "alpine/helm:3.7.2"
|
||||
serviceAccount: "jes-deploy-using-helm"
|
||||
cmd: ["helm"]
|
||||
args: ["upgrade", "--force", "--create-namespace", "--install", "-n", "$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "$(KEPTN_SERVICE)", "/keptn/charts/$(KEPTN_SERVICE).tgz", "--set", "image=$(IMAGE)", "--set", "keptn.service=$(KEPTN_SERVICE)", "--set", "keptn.deployment=$(KEPTN_STAGE)", "--wait"]
|
||||
args: ["upgrade", "--force", "--create-namespace", "--install", "-n", "$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "$(KEPTN_SERVICE)", "/keptn/charts/$(KEPTN_SERVICE).tgz", "--set", "image=$(IMAGE)", "--set", "keptn.service=$(KEPTN_SERVICE)", "--set", "keptn.deployment=$(KEPTN_STAGE)", "--set", "keptn.project=$(KEPTN_PROJECT)","--set", "keptn.stage=$(KEPTN_STAGE)", "--wait"]
|
||||
|
||||
- name: "Rollback using helm"
|
||||
events:
|
||||
|
|
@ -44,15 +44,15 @@ actions:
|
|||
# Note: Hardcoded kubernetes namespace & KEPTN_SERVICE does most likely not match the deployment name
|
||||
args: ["-c", "REPLICAS=$(kubectl -n ${KEPTN_PROJECT}-${KEPTN_STAGE} get deployment/${KEPTN_SERVICE} -o go-template='{{.spec.replicas}}');DESIRED=$((${SCALING}+${REPLICAS}));echo Scaling deployment to ${DESIRED} && kubectl -n ${KEPTN_PROJECT}-${KEPTN_STAGE} scale --replicas=${DESIRED} deployment/${KEPTN_SERVICE}"]
|
||||
|
||||
# - name: "Run tests using locust"
|
||||
# events:
|
||||
# - name: "sh.keptn.event.test.triggered"
|
||||
# tasks:
|
||||
# - name: "Run locust"
|
||||
# files:
|
||||
# - locust/basic.py
|
||||
# - locust/locust.conf
|
||||
- name: "Run tests using locust"
|
||||
events:
|
||||
- name: "sh.keptn.event.test.triggered"
|
||||
tasks:
|
||||
- name: "Run locust"
|
||||
files:
|
||||
- locust/basic.py
|
||||
- locust/locust.conf
|
||||
|
||||
# image: "locustio/locust:2.8.6"
|
||||
# cmd: ["locust"]
|
||||
# args: ["--config", "/keptn/locust/locust.conf", "-f", "/keptn/locust/basic.py", "--host", "http://$(KEPTN_SERVICE).$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "--only-summary"]
|
||||
image: "locustio/locust:2.8.6"
|
||||
cmd: ["locust"]
|
||||
args: ["--config", "/keptn/locust/locust.conf", "-f", "/keptn/locust/basic.py", "--host", "http://$(KEPTN_SERVICE).$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "--only-summary"]
|
||||
|
|
@ -0,0 +1,8 @@
|
|||
from locust import HttpUser, between, task
|
||||
|
||||
class WebsiteUser(HttpUser):
|
||||
wait_time = between(5, 15)
|
||||
|
||||
@task
|
||||
def index(self):
|
||||
self.client.get("/")
|
||||
|
|
@ -0,0 +1,4 @@
|
|||
locustfile = /locust/locust.py
|
||||
headless = true
|
||||
users = 10
|
||||
run-time = 1m
|
||||
|
|
@ -15,21 +15,21 @@ spec:
|
|||
properties:
|
||||
teststrategy: "functional"
|
||||
- name: "evaluation"
|
||||
- name: "release"
|
||||
#- name: "release"
|
||||
- name: "delivery-direct"
|
||||
tasks:
|
||||
- name: "deployment"
|
||||
properties:
|
||||
deploymentstrategy: "direct"
|
||||
- name: "release"
|
||||
- name: "rollback"
|
||||
tasks:
|
||||
- name: "rollback"
|
||||
- name: "only-test"
|
||||
tasks:
|
||||
- name: "test"
|
||||
properties:
|
||||
teststrategy: "functional"
|
||||
# - name: "rollback"
|
||||
# tasks:
|
||||
# - name: "rollback"
|
||||
# - name: "only-test"
|
||||
# tasks:
|
||||
# - name: "test"
|
||||
# properties:
|
||||
# teststrategy: "functional"
|
||||
- name: "staging"
|
||||
sequences:
|
||||
- name: "delivery"
|
||||
|
|
|
|||
|
|
@ -0,0 +1,42 @@
|
|||
---
|
||||
spec_version: "0.1.1"
|
||||
comparison:
|
||||
aggregate_function: "avg"
|
||||
compare_with: "single_result"
|
||||
include_result_with_score: "pass"
|
||||
number_of_comparison_results: 1
|
||||
filter:
|
||||
objectives:
|
||||
- sli: "response_time_p95"
|
||||
key_sli: false
|
||||
pass: # pass if (relative change <= 10% AND absolute value is < 600ms)
|
||||
- criteria:
|
||||
- "<=+25%" # relative values require a prefixed sign (plus or minus)
|
||||
- "<60000" # absolute values only require a logical operator
|
||||
warning: # if the response time is below 800ms, the result should be a warning
|
||||
- criteria:
|
||||
- "<=80000"
|
||||
weight: 1
|
||||
# - sli: "rt_addToCart" # looking at a particular transaction
|
||||
# weight: 3 # business critical transaction
|
||||
# pass:
|
||||
# - criteria:
|
||||
# - "<=+20%" # Degradation-driven
|
||||
# - "<300000" # NFR-driven
|
||||
# warning:
|
||||
# - criteria:
|
||||
# - "<=+50%"
|
||||
# - "<=500000"
|
||||
- sli: "error_rate"
|
||||
pass:
|
||||
- criteria:
|
||||
- "<=+15%"
|
||||
- "<2"
|
||||
warning:
|
||||
- criteria:
|
||||
- "<10"
|
||||
- sli: "pg_heap_suspension"
|
||||
- sli: "pg_cpu_usage"
|
||||
total_score:
|
||||
pass: "90%"
|
||||
warning: "70%"
|
||||
Loading…
Reference in New Issue