forked from ExpediaGroup/styx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
134 lines (106 loc) · 4.34 KB
/
Makefile
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
SHELL := /bin/bash
.PHONY: all test clean
ALL_PROFILES = release,quality
STACK = development
CURRENT_DIR := $(shell pwd)
# VERSION UPDATE
VERSION=0.6-SNAPSHOT
set-version:
mvn versions:set -DnewVersion=${VERSION}
## Removes all files built by build process
clean:
mvn clean -P$(ALL_PROFILES)
## Run unit tests and checkstyle
unit-test:
mvn clean test -Pquality
PLATFORM=macosx
## Compile, run unit tests, checkstyle and integration tests
e2e:
mvn clean verify -Pquality,release,$(PLATFORM)
## Compile code and tests but do not run
# Note: Pre-integration test phase is necessary to produce styx.properties file
# needed by AdminSpec.scala tests.
e2e-compile:
mvn clean pre-integration-test -P$(PLATFORM)
## Run system tests
e2e-test:
mvn -f system-tests/pom.xml -P$(PLATFORM) scalatest:test
## Execute a single end-to-end (scala) test
# Alternatively, it should be possible to run an individual e2e test
# with following Maven command:
#
# mvn -f system-tests/pom.xml scalatest:test -Dsuites='*ProxyPropertySpec'
#
e2e-test-single:
mvn -f system-tests/pom.xml scalatest:test -Dsuites='${TEST}'
## Compile, test and create styx.zip
release: clean
mvn install -Prelease
## Compile and create styx.zip without running tests
release-no-tests: clean
mvn install -Prelease,$(PLATFORM) -Dmaven.test.skip=true
GIT_BRANCH=$(shell basename $(shell git symbolic-ref --short HEAD))
LOAD_TEST_DIR=$(CURRENT_DIR)/logs/load-test-$(GIT_BRANCH)-$(shell date "+%Y_%m_%d_%H:%M:%S")
RATE=3000
TIMES=3
DURATION=30
CONNECTIONS=200
ENDPOINT=http://localhost:8080/lp/demo
SSL_ENDPOINT=https://localhost:8443/lp/demo
LOAD_TEST_TOOL=scripts/load-test-tool/load_test.py
PERF_DIR=system-tests/performance
wrk2:
git clone https://github.com/giltene/wrk2.git
wrk2/wrk: wrk2
# Assumes openssl has been installed using homebrew, *AND* the homebrew
# installation directory is /usr/local
(cd wrk2/; LIBRARY_PATH=/usr/local/opt/openssl/lib C_INCLUDE_PATH=/usr/local/opt/openssl/include make)
## Run a load test against Styx - launch styx with: make start STACK=perf-local
load-test: wrk2/wrk
(cd $(PERF_DIR); python $(LOAD_TEST_TOOL) -o'$(LOAD_TEST_DIR)' -d $(DURATION) -c $(CONNECTIONS) --times $(TIMES) -R $(RATE) $(ENDPOINT))
## Run a load test against Styx's HTTPS endpoint - launch styx with: make start STACK=perf-local
load-test-https:
(cd $(PERF_DIR); python $(LOAD_TEST_TOOL) -o'$(LOAD_TEST_DIR)' -d $(DURATION) -c $(CONNECTIONS) --times $(TIMES) -R $(RATE) $(SSL_ENDPOINT))
## A more primitive load-test - do we need this?
load-simple:
(cd $(PERF_DIR)/tools/wrk; ./wrk -H 'Host: localhost' -H 'Connection: keep-alive' -t 2 -c 200 -d 30s -R3000 --latency $(ENDPOINT))
## Run a build with tests and checkstyle
quality: clean
mvn install -Pquality
## Run a build with checkstyle but no tests
quality-no-tests:
mvn -Dmaven.test.skip=true clean install -Pquality -Dmaven.test.skip=true
STYX_BUILD_ARTIFACT = $(shell find distribution/target -name "styx*.zip")
STYX_HOME = $(CURRENT_DIR)/distribution/target/styx/styx
CONFIG_ROOT := $(STYX_HOME)/conf/env-$(STACK)
## Compile and create styx.zip then unzip into a directory defined by STYX_HOME
release-styx: release-no-tests
unzip -oq ${STYX_BUILD_ARTIFACT} -d $(dir ${STYX_HOME})
mv `find $(CURRENT_DIR)/distribution/target/styx -type d -name "styx-*"` ${STYX_HOME}
## Stops running netty-based origins (i.e. the origins started by start-origins)
stop-origins:
(support/origins-starter-app/bin/styx-originsstopper.sh 2>&1)
## Starts netty-based origins (release-styx needs to have been run first)
start-origins: release-styx stop-origins
(support/origins-starter-app/bin/styx-originsstarter.sh $(STYX_HOME) $(CONFIG_ROOT)/styx-config.yml &)
## Start with netty-based origins running on the ports Styx expects to find them
start-with-origins: release-styx start-origins
$(STYX_HOME)/bin/startup \
-e $(CONFIG_ROOT)/styx-env.sh \
-l $(CONFIG_ROOT)/logback.xml \
$(CONFIG_ROOT)/styx-config.yml
## Start with no origins (they can be launched separately if desired)
start: release-styx
$(STYX_HOME)/bin/startup \
-e $(CONFIG_ROOT)/styx-env.sh \
-l $(CONFIG_ROOT)/logback.xml \
$(CONFIG_ROOT)/styx-config.yml
## Build site-docs
docs:
mvn clean site:site
## Run site-docs locally
docs-run:
mvn site:run
## Test Styx's resilence against denial-of-service attack
ddos:
slowhttptest -c 4000 -B -g -o my_body_stats -i 110 -r 200 -s 8192 -t POST -u http://localhost:8080/demo