summaryrefslogtreecommitdiff
path: root/.github/workflows/ci-build.yml
blob: 2aa6c5f82bc13c5c473315e4413998d45830cede (plain)
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
name: CI

on:
  push:
    branches: '**'
    tags: '**'
  pull_request:

jobs:
  build:
    name: Build (PHP ${{ matrix.php }}, Go ${{ matrix.go }})
    runs-on: ubuntu-latest
    strategy:
      fail-fast: false
      matrix:
        php: [7.1, 7.2, 7.3, 7.4]
        go: [1.12]
    env:
      GO111MODULE: on
    steps:
    - name: Set up Go ${{ matrix.go }}
      uses: actions/setup-go@v1
      with:
        go-version: ${{ matrix.go }}

    - name: Set up PHP ${{ matrix.php }}
      uses: shivammathur/setup-php@v1
      with:
        php-version: ${{ matrix.php }}
        extensions: dom
        coverage: xdebug

    - name: Check out code
      uses: actions/checkout@v2
      with:
        fetch-depth: 1

    - name: Show versions
      run: php -v && composer -V && go version

    - name: Debug if needed
      env:
        DEBUG: ${{ secrets.DEBUG }}
      run: if [[ "$DEBUG" == "true" ]]; then env && go env; fi

    - name: Syntax check only (lint)
      run: find ./src/ -name "*.php" -print0 | xargs -0 -n1 -P8 php -l

    - name: Check PHP sources using phpstan
      run: composer require phpstan/phpstan '~0.12' && php ./vendor/bin/phpstan analyze --level max --no-progress --ansi ./src

    - name: Get Composer Cache Directory # Docs: <https://github.com/actions/cache/blob/master/examples.md#php---composer>
      id: composer-cache
      run: echo "::set-output name=dir::$(composer config cache-files-dir)"

    - name: Cache dependencies # Docs: <https://github.com/actions/cache/blob/master/examples.md#php---composer>
      uses: actions/cache@v1
      with:
        path: ${{ steps.composer-cache.outputs.dir }}
        key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }}
        restore-keys: ${{ runner.os }}-composer-

    - name: Install Composer dependencies
      run: composer install --prefer-dist --no-interaction --no-suggest # --prefer-source

    - name: Install Go dependencies
      run: go mod download

    - name: Download binary roadrunner
      run: php ./bin/rr get-binary

    - name: Run golang tests
      run: |
        go test -race -v -coverprofile=lib.txt -covermode=atomic
        go test ./util -race -v -coverprofile=util.txt -covermode=atomic
        go test ./service -race -v -coverprofile=service.txt -covermode=atomic
        go test ./service/env -race -v -coverprofile=env.txt -covermode=atomic
        go test ./service/rpc -race -v -coverprofile=rpc.txt -covermode=atomic
        go test ./service/http -race -v -coverprofile=http.txt -covermode=atomic
        go test ./service/static -race -v -coverprofile=static.txt -covermode=atomic
        go test ./service/limit -race -v -coverprofile=limit.txt -covermode=atomic
        go test ./service/headers -race -v -coverprofile=headers.txt -covermode=atomic
        go test ./service/metrics -race -v -coverprofile=metrics.txt -covermode=atomic
        go test ./service/health -race -v -coverprofile=health.txt -covermode=atomic

    - name: Run code coverage
      env:
        CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
      run: |
        if [[ "$CODECOV_TOKEN" != "" ]]; then
          curl https://codecov.io/bash -o codecov-bash
          chmod +x codecov-bash
          ./codecov-bash -f lib.txt
          ./codecov-bash -f util.txt
          ./codecov-bash -f service.txt
          ./codecov-bash -f env.txt
          ./codecov-bash -f rpc.txt
          ./codecov-bash -f http.txt
          ./codecov-bash -f static.txt
          ./codecov-bash -f limit.txt
          ./codecov-bash -f headers.txt
          ./codecov-bash -f metrics.txt
          ./codecov-bash -f health.txt
        fi

  image:
    name: Build docker image
    runs-on: ubuntu-latest
    steps:
      - name: Check out code
        uses: actions/checkout@v2
        with:
          fetch-depth: 1

      - name: Build image
        run: docker build -t rr:local -f Dockerfile .

      - name: Try to execute
        run: docker run --rm rr:local -v