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: |
|
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
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
|
4
Makefile
4
Makefile
@ -88,10 +88,10 @@ linux-mips64le:
|
|||||||
GOARCH=mips64le GOOS=linux $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
|
GOARCH=mips64le GOOS=linux $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
|
||||||
|
|
||||||
linux-riscv64:
|
linux-riscv64:
|
||||||
GOARCH=riscv64 GOOS=linux $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
|
GOARCH=riscv64 GOOS=linux $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
|
||||||
|
|
||||||
linux-loong64:
|
linux-loong64:
|
||||||
GOARCH=loong64 GOOS=linux $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
|
GOARCH=loong64 GOOS=linux $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
|
||||||
|
|
||||||
freebsd-386:
|
freebsd-386:
|
||||||
GOARCH=386 GOOS=freebsd $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
|
GOARCH=386 GOOS=freebsd $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
|
||||||
|
@ -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,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user