|
11 | 11 | jobs: |
12 | 12 | build: |
13 | 13 | runs-on: ubuntu-latest |
14 | | - strategy: |
15 | | - max-parallel: 3 |
16 | | - matrix: |
17 | | - python-version: [3.5, 3.6, 3.7] |
18 | 14 | steps: |
19 | | - - name: Check Environment |
20 | | - run: | |
21 | | - if [[ -z $AWS_ACCESS_KEY_ID || -z $AWS_SECRET_ACCESS_KEY ]]; then |
22 | | - echo "Missing required environment variables." |
23 | | - echo "If this a pull request check your fork's action history." |
24 | | - exit 1 |
25 | | - fi |
26 | | - env: |
27 | | - AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} |
28 | | - AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |
29 | 15 | - uses: actions/checkout@v1 |
30 | | - - name: Setup Python ${{matrix.python-version}} |
| 16 | + - name: Setup Python 3.5 |
| 17 | + uses: actions/setup-python@v1 |
| 18 | + with: |
| 19 | + python-version: 3.5 |
| 20 | + - name: Setup Python 3.6 |
31 | 21 | uses: actions/setup-python@v1 |
32 | 22 | with: |
33 | | - python-version: ${{ matrix.python-version }} |
| 23 | + python-version: 3.6 |
| 24 | + - name: Setup Python 3.7 |
| 25 | + uses: actions/setup-python@v1 |
| 26 | + with: |
| 27 | + python-version: 3.7 |
34 | 28 | - name: Install Dependencies |
35 | | - run: pip install tox tox-gh-actions |
| 29 | + run: pip install tox |
36 | 30 | - name: Flake8 |
37 | 31 | run: tox -e flake8 |
38 | 32 | - name: Black Check |
39 | 33 | run: tox -e black-check |
40 | 34 | - name: Pylint |
41 | 35 | run: tox -e pylint |
42 | | - # starts 3 jobs, 1 for each python version |
43 | | - - name: Test |
44 | | - run: tox |
| 36 | + # runs unit tests for each python version |
| 37 | + - name: Unit Tests |
| 38 | + run: tox -- tests/unit |
| 39 | + env: |
| 40 | + AWS_DEFAULT_REGION: us-west-2 |
| 41 | + - name: Integration Tests |
| 42 | + # pull requests are untrusted and do not have access to secrets needed for integ tests |
| 43 | + if: github.event_name != 'pull_request' |
| 44 | + run: tox -e py36 -- tests/integ |
45 | 45 | env: |
46 | 46 | AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} |
47 | 47 | AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |
48 | 48 | AWS_DEFAULT_REGION: us-west-2 |
49 | | - CODECOV_UPLOAD_TOKEN: ${{ secrets.CODECOV_UPLOAD_TOKEN }} |
| 49 | + COVERAGE_FILE: .coverage.integ |
| 50 | + IGNORE_COVERAGE: '-' |
| 51 | + - name: Upload Code Coverage |
| 52 | + if: github.event_name == 'release' |
| 53 | + run: | |
| 54 | + coverage combine .coverage* |
| 55 | + codecov -t {env:CODECOV_UPLOAD_TOKEN} |
| 56 | + env: |
| 57 | + CODECOV_UPLOAD_TOKEN: ${{ secrets.AWS_ACCESS_KEY_ID }} |
50 | 58 |
|
51 | 59 | release: |
52 | 60 | needs: build |
|
0 commit comments