Chore: added a new test CI to run unit test and build test for Pull Requests (#2883)
This commit is contained in:
parent
218c3b4e89
commit
a19a9feb52
4
.github/workflows/release.yml
vendored
4
.github/workflows/release.yml
vendored
@ -23,10 +23,6 @@ jobs:
|
||||
restore-keys: |
|
||||
${{ runner.os }}-go-
|
||||
|
||||
- name: Get dependencies, run test
|
||||
run: |
|
||||
go test ./...
|
||||
|
||||
- name: Build
|
||||
if: startsWith(github.ref, 'refs/tags/')
|
||||
env:
|
||||
|
60
.github/workflows/test.yaml
vendored
Normal file
60
.github/workflows/test.yaml
vendored
Normal 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
|
@ -119,13 +119,15 @@ func TestParseRule(t *testing.T) {
|
||||
tp: C.RuleConfigIPSet,
|
||||
payload: "example",
|
||||
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,
|
||||
payload: "example",
|
||||
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,
|
||||
|
Loading…
x
Reference in New Issue
Block a user