1
0

Chore: added a new test CI to run unit test and build test for Pull Requests (#2883)

This commit is contained in:
Neko Ayaka 2023-08-16 22:29:36 +08:00 committed by GitHub
parent 218c3b4e89
commit a19a9feb52
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 69 additions and 11 deletions

View File

@ -23,10 +23,6 @@ jobs:
restore-keys: | restore-keys: |
${{ runner.os }}-go- ${{ runner.os }}-go-
- name: Get dependencies, run test
run: |
go test ./...
- name: Build - name: Build
if: startsWith(github.ref, 'refs/tags/') if: startsWith(github.ref, 'refs/tags/')
env: env:

60
.github/workflows/test.yaml vendored Normal file
View File

@ -0,0 +1,60 @@
name: Test
on: [push, pull_request]
jobs:
test:
name: Test
runs-on: ubuntu-latest
steps:
- name: Setup Go
uses: actions/setup-go@v4
with:
check-latest: true
go-version: '1.21'
- name: Check out code into the Go module directory
uses: actions/checkout@v3
- name: Cache go module
uses: actions/cache@v3
with:
path: |
~/go/pkg/mod
~/.cache/go-build
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-go-
- name: Get dependencies, run test
run: |
go test ./...
build-test:
name: Build Test
runs-on: ubuntu-latest
steps:
- name: Setup Go
uses: actions/setup-go@v4
with:
check-latest: true
go-version: '1.21'
- name: Check out code into the Go module directory
uses: actions/checkout@v3
- name: Cache go module
uses: actions/cache@v3
with:
path: |
~/go/pkg/mod
~/.cache/go-build
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-go-
- name: Build
env:
NAME: clash
BINDIR: bin
run: make -j $(go run ./test/main.go) all

View File

@ -116,16 +116,18 @@ func TestParseRule(t *testing.T) {
expectedRule: lo.Must(NewProcess("/opt/example/example", policy, false)), expectedRule: lo.Must(NewProcess("/opt/example/example", policy, false)),
}, },
{ {
tp: C.RuleConfigIPSet, tp: C.RuleConfigIPSet,
payload: "example", payload: "example",
target: policy, target: policy,
expectedRule: lo.Must(NewIPSet("example", policy, true)), // unit test runs on Linux machine and NewIPSet(...) won't be available
expectedError: errors.New("operation not permitted"),
}, },
{ {
tp: C.RuleConfigIPSet, tp: C.RuleConfigIPSet,
payload: "example", payload: "example",
target: policy, params: []string{noResolve}, target: policy, params: []string{noResolve},
expectedRule: lo.Must(NewIPSet("example", policy, false)), // unit test runs on Linux machine and NewIPSet(...) won't be available
expectedError: errors.New("operation not permitted"),
}, },
{ {
tp: C.RuleConfigMatch, tp: C.RuleConfigMatch,