run_test_cases.yaml 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. name: Run test case
  2. on:
  3. push:
  4. tags:
  5. - v*
  6. - e*
  7. pull_request:
  8. jobs:
  9. run_static_analysis:
  10. runs-on: ubuntu-20.04
  11. container: emqx/build-env:erl23.2.7.2-emqx-2-ubuntu20.04
  12. steps:
  13. - uses: actions/checkout@v2
  14. - name: set git credentials
  15. run: |
  16. if make emqx-ee --dry-run > /dev/null 2>&1; then
  17. echo "https://ci%40emqx.io:${{ secrets.CI_GIT_TOKEN }}@github.com" > $HOME/.git-credentials
  18. git config --global credential.helper store
  19. fi
  20. - name: xref
  21. run: make xref
  22. - name: dialyzer
  23. run: make dialyzer
  24. run_proper_test:
  25. runs-on: ubuntu-20.04
  26. container: emqx/build-env:erl23.2.7.2-emqx-2-ubuntu20.04
  27. steps:
  28. - uses: actions/checkout@v2
  29. - name: set git credentials
  30. run: |
  31. if make emqx-ee --dry-run > /dev/null 2>&1; then
  32. echo "https://ci%40emqx.io:${{ secrets.CI_GIT_TOKEN }}@github.com" > $HOME/.git-credentials
  33. git config --global credential.helper store
  34. fi
  35. - name: proper
  36. run: make proper
  37. run_common_test:
  38. runs-on: ubuntu-20.04
  39. steps:
  40. - uses: actions/checkout@v2
  41. - name: set edition
  42. id: set_edition
  43. run: |
  44. if make emqx-ee --dry-run > /dev/null 2>&1; then
  45. echo "EDITION=enterprise" >> $GITHUB_ENV
  46. else
  47. echo "EDITION=opensource" >> $GITHUB_ENV
  48. fi
  49. - name: docker compose up
  50. if: env.EDITION == 'opensource'
  51. env:
  52. MYSQL_TAG: 8
  53. REDIS_TAG: 6
  54. MONGO_TAG: 4
  55. PGSQL_TAG: 13
  56. LDAP_TAG: 2.4.50
  57. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  58. run: |
  59. docker-compose \
  60. -f .ci/docker-compose-file/docker-compose.yaml \
  61. -f .ci/docker-compose-file/docker-compose-ldap-tcp.yaml \
  62. -f .ci/docker-compose-file/docker-compose-mongo-tcp.yaml \
  63. -f .ci/docker-compose-file/docker-compose-mysql-tcp.yaml \
  64. -f .ci/docker-compose-file/docker-compose-pgsql-tcp.yaml \
  65. -f .ci/docker-compose-file/docker-compose-redis-single-tcp.yaml \
  66. up -d --build
  67. - name: docker compose up
  68. if: env.EDITION == 'enterprise'
  69. env:
  70. MYSQL_TAG: 8
  71. REDIS_TAG: 6
  72. MONGO_TAG: 4
  73. PGSQL_TAG: 13
  74. LDAP_TAG: 2.4.50
  75. OPENTSDB_TAG: latest
  76. INFLUXDB_TAG: 1.7.6
  77. DYNAMODB_TAG: 1.11.477
  78. TIMESCALE_TAG: latest-pg11
  79. CASSANDRA_TAG: 3.11.6
  80. RABBITMQ_TAG: 3.7
  81. KAFKA_TAG: 2.5.0
  82. PULSAR_TAG: 2.3.2
  83. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  84. timeout-minutes: 20
  85. run: |
  86. docker-compose \
  87. -f .ci/docker-compose-file/docker-compose.yaml \
  88. -f .ci/docker-compose-file/docker-compose-ldap-tcp.yaml \
  89. -f .ci/docker-compose-file/docker-compose-mongo-tcp.yaml \
  90. -f .ci/docker-compose-file/docker-compose-mysql-tcp.yaml \
  91. -f .ci/docker-compose-file/docker-compose-pgsql-tcp.yaml \
  92. -f .ci/docker-compose-file/docker-compose-redis-single-tcp.yaml \
  93. -f .ci/docker-compose-file/docker-compose-enterprise.yaml \
  94. -f .ci/docker-compose-file/docker-compose-enterprise-cassandra-tcp.yaml \
  95. -f .ci/docker-compose-file/docker-compose-enterprise-dynamodb-tcp.yaml \
  96. -f .ci/docker-compose-file/docker-compose-enterprise-influxdb-tcp.yaml \
  97. -f .ci/docker-compose-file/docker-compose-enterprise-kafka-tcp.yaml \
  98. -f .ci/docker-compose-file/docker-compose-enterprise-opentsdb-tcp.yaml \
  99. -f .ci/docker-compose-file/docker-compose-enterprise-pulsar-tcp.yaml \
  100. -f .ci/docker-compose-file/docker-compose-enterprise-rabbit-tcp.yaml \
  101. -f .ci/docker-compose-file/docker-compose-enterprise-timescale-tcp.yaml \
  102. -f .ci/docker-compose-file/docker-compose-enterprise-mysql-client.yaml \
  103. -f .ci/docker-compose-file/docker-compose-enterprise-pgsql-and-timescale-client.yaml \
  104. up -d --build
  105. docker exec -i erlang bash -c "echo \"https://ci%40emqx.io:${{ secrets.CI_GIT_TOKEN }}@github.com\" > /root/.git-credentials && git config --global credential.helper store"
  106. while [ $(docker ps -a --filter name=client --filter exited=0 | wc -l) \
  107. != $(docker ps -a --filter name=client | wc -l) ]; do
  108. sleep 5
  109. done
  110. - name: run eunit
  111. run: |
  112. docker exec -i erlang bash -c "make eunit"
  113. - name: run common test
  114. run: |
  115. docker exec -i erlang bash -c "make ct"
  116. - name: run cover
  117. run: |
  118. printenv > .env
  119. docker exec -i erlang bash -c "make cover"
  120. docker exec --env-file .env -i erlang bash -c "make coveralls"
  121. - name: cat rebar.crashdump
  122. if: failure()
  123. run: if [ -f 'rebar3.crashdump' ];then cat 'rebar3.crashdump'; fi
  124. - uses: actions/upload-artifact@v1
  125. if: failure()
  126. with:
  127. name: logs
  128. path: _build/test/logs
  129. - uses: actions/upload-artifact@v1
  130. with:
  131. name: cover
  132. path: _build/test/cover
  133. finish:
  134. needs: run_common_test
  135. runs-on: ubuntu-20.04
  136. steps:
  137. - name: Coveralls Finished
  138. env:
  139. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  140. run: |
  141. curl -v -k https://coveralls.io/webhook \
  142. --header "Content-Type: application/json" \
  143. --data "{\"repo_name\":\"$GITHUB_REPOSITORY\",\"repo_token\":\"$GITHUB_TOKEN\",\"payload\":{\"build_num\":$GITHUB_RUN_ID,\"status\":\"done\"}}" || true