run_jmeter_tests.yaml 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312
  1. name: JMeter integration tests
  2. on:
  3. workflow_call:
  4. inputs:
  5. runner_labels:
  6. required: true
  7. type: string
  8. version-emqx:
  9. required: true
  10. type: string
  11. jobs:
  12. jmeter_artifact:
  13. runs-on: ${{ fromJSON(inputs.runner_labels) }}
  14. steps:
  15. - name: Cache Jmeter
  16. id: cache-jmeter
  17. uses: actions/cache@v3
  18. with:
  19. path: /tmp/apache-jmeter.tgz
  20. key: apache-jmeter-5.4.3.tgz
  21. - name: download jmeter
  22. if: steps.cache-jmeter.outputs.cache-hit != 'true'
  23. timeout-minutes: 15
  24. env:
  25. JMETER_VERSION: 5.4.3
  26. run: |
  27. # versions below 5.5 had been moved to the archive area
  28. # latest version is 5.6, the script below should handle both scenarios
  29. URL=https://downloads.apache.org/jmeter/binaries/apache-jmeter-$JMETER_VERSION.tgz
  30. ARCHIVE_URL=https://archive.apache.org/dist/jmeter/binaries/apache-jmeter-$JMETER_VERSION.tgz
  31. if wget -q --method HEAD $URL; then
  32. wget --no-verbose --no-check-certificate -O /tmp/apache-jmeter.tgz $URL
  33. else
  34. wget --no-verbose --no-check-certificate -O /tmp/apache-jmeter.tgz $ARCHIVE_URL
  35. fi
  36. - uses: actions/upload-artifact@v3
  37. with:
  38. name: apache-jmeter.tgz
  39. path: /tmp/apache-jmeter.tgz
  40. advanced_feat:
  41. runs-on: ${{ fromJSON(inputs.runner_labels) }}
  42. strategy:
  43. fail-fast: false
  44. matrix:
  45. scripts_type:
  46. - mqtt_subscription_topic_metrics
  47. - mqtt_delayed_publish
  48. - mqtt_topic_rewrite
  49. # - mqtt_retainer
  50. needs: jmeter_artifact
  51. steps:
  52. - uses: actions/checkout@v3
  53. - uses: ./.github/actions/prepare-jmeter
  54. with:
  55. version-emqx: ${{ inputs.version-emqx }}
  56. - name: docker compose up
  57. timeout-minutes: 5
  58. run: |
  59. docker compose \
  60. -f .ci/docker-compose-file/docker-compose-emqx-cluster.yaml \
  61. up --wait --build
  62. echo HAPROXY_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' haproxy) >> $GITHUB_ENV
  63. - name: show logs
  64. if: failure()
  65. run: |
  66. docker compose \
  67. -f .ci/docker-compose-file/docker-compose-emqx-cluster.yaml \
  68. logs
  69. - name: run jmeter
  70. run: |
  71. jmeter/bin/jmeter.sh \
  72. -Jjmeter.save.saveservice.output_format=xml -n \
  73. -t scripts/broker-autotest-suite/${{ matrix.scripts_type }}.jmx \
  74. -Demqx_ip=$HAPROXY_IP \
  75. -l jmeter_logs/${{ matrix.scripts_type }}.jtl \
  76. -j jmeter_logs/logs/${{ matrix.scripts_type }}.log
  77. - name: check logs
  78. run: |
  79. if cat jmeter_logs/${{ matrix.scripts_type }}.jtl | grep -e '<failure>true</failure>' > /dev/null 2>&1; then
  80. echo "check logs failed"
  81. exit 1
  82. fi
  83. - uses: actions/upload-artifact@v3
  84. if: always()
  85. with:
  86. name: jmeter_logs
  87. path: ./jmeter_logs
  88. pgsql_authn_authz:
  89. runs-on: ${{ fromJSON(inputs.runner_labels) }}
  90. strategy:
  91. fail-fast: false
  92. matrix:
  93. pgsql_tag:
  94. - 9
  95. - 10
  96. - 11
  97. - 12
  98. - 13
  99. scripts_type:
  100. - pgsql_authn
  101. - pgsql_authz
  102. needs: jmeter_artifact
  103. steps:
  104. - uses: actions/checkout@v3
  105. - uses: ./.github/actions/prepare-jmeter
  106. with:
  107. version-emqx: ${{ inputs.version-emqx }}
  108. - name: docker compose up
  109. timeout-minutes: 5
  110. env:
  111. PGSQL_TAG: ${{ matrix.pgsql_tag }}
  112. run: |
  113. docker pull postgres:${PGSQL_TAG}
  114. docker compose \
  115. -f .ci/docker-compose-file/docker-compose-emqx-cluster.yaml \
  116. -f .ci/docker-compose-file/docker-compose-pgsql-tls.yaml \
  117. up --wait --build
  118. echo HAPROXY_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' haproxy) >> $GITHUB_ENV
  119. echo PGSQL_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' pgsql-tls) >> $GITHUB_ENV
  120. - name: run jmeter
  121. run: |
  122. jmeter/bin/jmeter.sh \
  123. -Jjmeter.save.saveservice.output_format=xml -n \
  124. -t scripts/broker-autotest-suite/${{ matrix.scripts_type }}.jmx \
  125. -Demqx_ip=$HAPROXY_IP \
  126. -Ddb_ip=$PGSQL_IP \
  127. -Dport="5432" \
  128. -Dpgsql_user="root" \
  129. -Dpgsql_pwd="public" \
  130. -Ddbname="mqtt" \
  131. -Droute="apps/emqx_auth/test/data/certs" \
  132. -Dca_name="ca.crt" \
  133. -Dkey_name="client.key" \
  134. -Dcert_name="client.crt" \
  135. -l jmeter_logs/${{ matrix.scripts_type }}_${{ matrix.pgsql_tag }}.jtl \
  136. -j jmeter_logs/logs/${{ matrix.scripts_type }}_${{ matrix.pgsql_tag }}.log
  137. - name: check logs
  138. run: |
  139. if cat jmeter_logs/${{ matrix.scripts_type }}_${{ matrix.pgsql_tag }}.jtl | grep -e '<failure>true</failure>' > /dev/null 2>&1; then
  140. echo "check logs failed"
  141. exit 1
  142. fi
  143. - name: dump docker compose logs
  144. if: failure()
  145. run: |
  146. docker compose -f .ci/docker-compose-file/docker-compose-emqx-cluster.yaml logs --no-color > ./jmeter_logs/emqx.log
  147. - uses: actions/upload-artifact@v3
  148. if: always()
  149. with:
  150. name: jmeter_logs
  151. path: ./jmeter_logs
  152. mysql_authn_authz:
  153. runs-on: ${{ fromJSON(inputs.runner_labels) }}
  154. strategy:
  155. fail-fast: false
  156. matrix:
  157. mysql_tag:
  158. - 5.7
  159. - 8
  160. scripts_type:
  161. - mysql_authn
  162. - mysql_authz
  163. needs: jmeter_artifact
  164. steps:
  165. - uses: actions/checkout@v3
  166. - uses: ./.github/actions/prepare-jmeter
  167. with:
  168. version-emqx: ${{ inputs.version-emqx }}
  169. - name: docker compose up
  170. timeout-minutes: 5
  171. env:
  172. PGSQL_TAG: ${{ matrix.mysql_tag }}
  173. run: |
  174. docker compose \
  175. -f .ci/docker-compose-file/docker-compose-emqx-cluster.yaml \
  176. -f .ci/docker-compose-file/docker-compose-mysql-tls.yaml \
  177. up --wait --build
  178. echo HAPROXY_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' haproxy) >> $GITHUB_ENV
  179. echo MYSQL_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' mysql-tls) >> $GITHUB_ENV
  180. - name: run jmeter
  181. run: |
  182. jmeter/bin/jmeter.sh \
  183. -Jjmeter.save.saveservice.output_format=xml -n \
  184. -t scripts/broker-autotest-suite/${{ matrix.scripts_type }}.jmx \
  185. -Demqx_ip=$HAPROXY_IP \
  186. -Dmysql_ip=$MYSQL_IP \
  187. -Dport="3306" \
  188. -Dmysql_user="root" \
  189. -Dmysql_pwd="public" \
  190. -Ddbname="mqtt" \
  191. -Droute="apps/emqx_auth/test/data/certs" \
  192. -Dca_name="ca.crt" \
  193. -Dkey_name="client.key" \
  194. -Dcert_name="client.crt" \
  195. -l jmeter_logs/${{ matrix.scripts_type }}_${{ matrix.mysql_tag }}.jtl \
  196. -j jmeter_logs/logs/${{ matrix.scripts_type }}_${{ matrix.mysql_tag }}.log
  197. - name: check logs
  198. run: |
  199. if cat jmeter_logs/${{ matrix.scripts_type }}_${{ matrix.mysql_tag }}.jtl | grep -e '<failure>true</failure>' > /dev/null 2>&1; then
  200. echo "check logs failed"
  201. exit 1
  202. fi
  203. - uses: actions/upload-artifact@v3
  204. if: always()
  205. with:
  206. name: jmeter_logs
  207. path: ./jmeter_logs
  208. JWT_authn:
  209. runs-on: ${{ fromJSON(inputs.runner_labels) }}
  210. strategy:
  211. fail-fast: false
  212. matrix:
  213. scripts_type:
  214. - jwt_authn
  215. needs: jmeter_artifact
  216. steps:
  217. - uses: actions/checkout@v3
  218. - uses: ./.github/actions/prepare-jmeter
  219. with:
  220. version-emqx: ${{ inputs.version-emqx }}
  221. - name: docker compose up
  222. timeout-minutes: 5
  223. run: |
  224. docker compose \
  225. -f .ci/docker-compose-file/docker-compose-emqx-cluster.yaml \
  226. up --wait --build
  227. echo HAPROXY_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' haproxy) >> $GITHUB_ENV
  228. - name: run jwks_server
  229. timeout-minutes: 10
  230. run: |
  231. cd scripts/jwks-server
  232. mvn package
  233. cd target
  234. docker run --name jwks_server --network emqx_bridge --ip 172.100.239.88 -d -v $(pwd)/jwkserver-0.0.1.jar:/jwks_server/jwkserver-0.0.1.jar --workdir /jwks_server openjdk:8-jdk bash \
  235. -c "java -jar jwkserver-0.0.1.jar"
  236. - name: run jmeter
  237. run: |
  238. jmeter/bin/jmeter.sh \
  239. -Jjmeter.save.saveservice.output_format=xml -n \
  240. -t scripts/broker-autotest-suite/${{ matrix.scripts_type }}.jmx \
  241. -Demqx_ip=$HAPROXY_IP \
  242. -Djwks_ip="172.100.239.88" \
  243. -l jmeter_logs/${{ matrix.scripts_type }}.jtl \
  244. -j jmeter_logs/logs/${{ matrix.scripts_type }}.log
  245. - name: check logs
  246. run: |
  247. if cat jmeter_logs/${{ matrix.scripts_type }}.jtl | grep -e '<failure>true</failure>' > /dev/null 2>&1; then
  248. echo "check logs failed"
  249. exit 1
  250. fi
  251. - uses: actions/upload-artifact@v3
  252. if: always()
  253. with:
  254. name: jmeter_logs
  255. path: ./jmeter_logs
  256. built_in_database_authn_authz:
  257. runs-on: ${{ fromJSON(inputs.runner_labels) }}
  258. strategy:
  259. fail-fast: false
  260. matrix:
  261. scripts_type:
  262. - built_in_database_authn
  263. - built_in_database_authz
  264. needs: jmeter_artifact
  265. steps:
  266. - uses: actions/checkout@v3
  267. - uses: ./.github/actions/prepare-jmeter
  268. with:
  269. version-emqx: ${{ inputs.version-emqx }}
  270. - name: docker compose up
  271. timeout-minutes: 5
  272. run: |
  273. docker compose \
  274. -f .ci/docker-compose-file/docker-compose-emqx-cluster.yaml \
  275. up --wait --build
  276. echo HAPROXY_IP=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' haproxy) >> $GITHUB_ENV
  277. - name: run jmeter
  278. run: |
  279. jmeter/bin/jmeter.sh \
  280. -Jjmeter.save.saveservice.output_format=xml -n \
  281. -t scripts/broker-autotest-suite/${{ matrix.scripts_type }}.jmx \
  282. -Demqx_ip=$HAPROXY_IP \
  283. -l jmeter_logs/${{ matrix.scripts_type }}.jtl \
  284. -j jmeter_logs/logs/${{ matrix.scripts_type }}.log
  285. - name: check logs
  286. run: |
  287. if cat jmeter_logs/${{ matrix.scripts_type }}.jtl | grep -e '<failure>true</failure>' > /dev/null 2>&1; then
  288. echo "check logs failed"
  289. exit 1
  290. fi
  291. - uses: actions/upload-artifact@v3
  292. if: always()
  293. with:
  294. name: jmeter_logs
  295. path: ./jmeter_logs