blob: dd5b5a0e099b860310032962d90444dd11414f11 (
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
|
name: CI
on:
push:
branches: '**'
tags: '**'
pull_request:
jobs:
build:
name: Execute tests (using PHP ${{ matrix.php }} and Go ${{ matrix.go }})
runs-on: ubuntu-latest
strategy:
matrix:
php: [7.1, 7.2, 7.3, 7.4]
go: [1.12]
env:
GO111MODULE: on
steps:
- name: Set up PHP ${{ matrix.php }}
uses: shivammathur/setup-php@master
with:
php-version: ${{ matrix.php }}
extension-csv: dom
coverage: xdebug
- name: Set up Go ${{ matrix.go }}
uses: actions/setup-go@v2
with:
go-version: ${{ matrix.go }}
- 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: 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
|