integration.yaml 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. name: Integration
  2. # Run this workflow every time a new commit pushed to your repository
  3. on:
  4. push:
  5. branches:
  6. - master
  7. pull_request:
  8. branches:
  9. - master
  10. jobs:
  11. # Set the job key. The key is displayed as the job name
  12. # when a job name is not provided
  13. lint:
  14. name: Lint code
  15. runs-on: ubuntu-latest
  16. strategy:
  17. matrix:
  18. python-version: [ '3.8' ]
  19. steps:
  20. - name: Checkout code
  21. uses: actions/checkout@v2
  22. - uses: actions/setup-python@v2
  23. with:
  24. python-version: ${{ matrix.python-version }}
  25. - name: Cache pip dir
  26. uses: actions/cache@v2
  27. with:
  28. path: ~/.cache/pip
  29. key: pip-cache-${{ matrix.python-version }}-lint
  30. - name: Install required packages
  31. run: pip install tox
  32. - name: Run tox
  33. run: tox -e lint
  34. integration:
  35. # Name the Job
  36. name: Run mock integration tests
  37. needs: lint
  38. # Set the type of machine to run on
  39. runs-on: ubuntu-latest
  40. strategy:
  41. matrix:
  42. python-version: ['3.8']
  43. cloud-provider: ['aws', 'azure', 'gcp', 'mock', 'openstack']
  44. steps:
  45. - name: Checkout code
  46. uses: actions/checkout@v2
  47. - uses: actions/setup-python@v2
  48. with:
  49. python-version: ${{ matrix.python-version }}
  50. - name: Cache pip dir
  51. uses: actions/cache@v2
  52. with:
  53. path: ~/.cache/pip
  54. key: pip-cache-${{ matrix.python-version }}-${{ hashFiles('**/setup.py', '**/requirements.txt') }}
  55. - name: Install required packages
  56. run: pip install tox
  57. - name: Run tox
  58. run: tox -e py${{ matrix.python-version }}-${{ matrix.cloud-provider }}
  59. env:
  60. PYTHONUNBUFFERED: "True"
  61. # aws
  62. AWS_ACCESS_KEY: ${{ secrets.AWS_ACCESS_KEY }}
  63. AWS_SECRET_KEY: ${{ secrets.AWS_SECRET_KEY }}
  64. # azure
  65. AZURE_CLIENT_ID: ${{ secrets.AZURE_CLIENT_ID }}
  66. AZURE_SUBSCRIPTION_ID: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
  67. AZURE_SECRET: ${{ secrets.AZURE_SECRET }}
  68. AZURE_TENANT: ${{ secrets.AZURE_TENANT }}
  69. AZURE_RESOURCE_GROUP: ${{ secrets.AZURE_RESOURCE_GROUP }}
  70. AZURE_STORAGE_ACCOUNT: ${{ secrets.AZURE_STORAGE_ACCOUNT }}
  71. CB_IMAGE_AZURE: ${{ secrets.CB_IMAGE_AZURE }}
  72. CB_VM_TYPE_AZURE: ${{ secrets.CB_VM_TYPE_AZURE }}
  73. # gcp
  74. GCP_SERVICE_CREDS_DICT: ${{ secrets.GCP_SERVICE_CREDS_DICT }}
  75. CB_IMAGE_GCP: ${{ secrets.CB_IMAGE_GCP }}
  76. # openstack
  77. OS_AUTH_URL: ${{ secrets.OS_AUTH_URL }}
  78. OS_PASSWORD: ${{ secrets.OS_PASSWORD }}
  79. OS_PROJECT_NAME: ${{ secrets.OS_PROJECT_NAME }}
  80. OS_PROJECT_DOMAIN_NAME: ${{ secrets.OS_PROJECT_DOMAIN_NAME }}
  81. OS_TENANT_NAME: ${{ secrets.OS_TENANT_NAME }}
  82. OS_USERNAME: ${{ secrets.OS_USERNAME }}
  83. OS_REGION_NAME: ${{ secrets.OS_REGION_NAME }}
  84. OS_USER_DOMAIN_NAME: ${{ secrets.OS_USER_DOMAIN_NAME }}
  85. CB_IMAGE_OS: ${{ secrets.CB_IMAGE_OS }}
  86. CB_PLACEMENT_OS: ${{ secrets.CB_PLACEMENT_OS }}
  87. - name: Coveralls
  88. uses: coverallsapp/github-action@master
  89. with:
  90. github-token: ${{ secrets.GITHUB_TOKEN }}
  91. flag-name: run-${{ matrix.python-version }}-${{ matrix.cloud-provider }}
  92. parallel: true
  93. finish:
  94. needs: integration
  95. runs-on: ubuntu-latest
  96. steps:
  97. - name: Coveralls Finished
  98. uses: coverallsapp/github-action@master
  99. with:
  100. github-token: ${{ secrets.github_token }}
  101. parallel-finished: true