-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add Golangci lint, replace statik with embed and test swagger (#566)
* use Github workflow testing/linting instead of Docker * replace statik with embed * fail build if swagger is changed * install swagger * Add comment * add warning on breaking change to api * create a bootstrap target to ensure toolchain * create a bootstrap target to ensure toolchain * remove statik from gitignore --------- Co-authored-by: Richard Hagen <richard.hagen@bouvet.no>
- Loading branch information
Showing
24 changed files
with
159 additions
and
100 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
name: Pull-Request Testing | ||
on: | ||
pull_request: | ||
workflow_dispatch: | ||
|
||
jobs: | ||
lint: | ||
name: Lint | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 2 | ||
- uses: actions/setup-go@v4 | ||
with: | ||
go-version: '1.21' | ||
- name: Install dependencies | ||
run: go mod download | ||
- name: Install GolangCI Lint | ||
run: curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.55.2 | ||
- name: Install StaticCheck | ||
run: go install honnef.co/go/tools/cmd/staticcheck@2023.1.6 | ||
|
||
- name: golangci-lint | ||
run: golangci-lint run --timeout=30m --max-same-issues=0 --out-format=github-actions --new | ||
|
||
# Add legacy checks since golangci-lint only tests changed files for now | ||
- name: StaticCheck | ||
run: staticcheck -f text `go list ./... | grep -v "pkg/client"` | ||
- name: Go Vet | ||
run: go vet `go list ./... | grep -v "pkg/client"` | ||
test: | ||
name: Unit Test | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: actions/setup-go@v4 | ||
with: | ||
go-version: '1.21' | ||
- name: Install dependencies | ||
run: go mod download | ||
- name: Run Tests | ||
run: go test -cover `go list ./... | grep -v 'pkg/client'` | ||
|
||
test-swagger: | ||
name: Test Swagger | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- uses: actions/setup-go@v4 | ||
with: | ||
go-version: '1.21' | ||
- name: Install dependencies | ||
run: go mod download | ||
- name: Install Swagger | ||
run: go install github.com/go-swagger/go-swagger/cmd/swagger@v0.30.5 | ||
- name: Generate Swagger | ||
run: swagger generate spec -o ./swagger.json --scan-models --exclude-deps | ||
- name: Validate no changes | ||
run: diff swagger.json ./swaggerui/html/swagger.json | ||
- name: Check breaking changes | ||
if: always() | ||
id: breaking | ||
continue-on-error: true | ||
run: swagger diff --break <(git show master:swaggerui/html/swagger.json) swagger.json > /tmp/swagger_breaking_changes.txt | ||
- name: Add comment | ||
if: failure() && steps.breaking.outcome == 'failure' | ||
uses: mshick/add-pr-comment@v2 | ||
with: | ||
message-id: breaking-comment | ||
preformatted: true | ||
message-path: /tmp/swagger_breaking_changes.txt | ||
|
||
build: | ||
name: Build | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- name: Build docker image | ||
run: docker build . |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -17,7 +17,6 @@ bin/* | |
vendor | ||
|
||
debug | ||
swaggerui/statik.go | ||
|
||
__debug_bin | ||
.dccache | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
File renamed without changes
File renamed without changes
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
2 changes: 1 addition & 1 deletion
2
swaggerui_src/swagger-ui-bundle.js → swaggerui/html/swagger-ui-bundle.js
Large diffs are not rendered by default.
Oops, something went wrong.
File renamed without changes.
2 changes: 1 addition & 1 deletion
2
swaggerui_src/swagger-ui-es-bundle.js → swaggerui/html/swagger-ui-es-bundle.js
Large diffs are not rendered by default.
Oops, something went wrong.
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,8 +6,8 @@ | |
"application/json" | ||
], | ||
"schemes": [ | ||
"http", | ||
"https" | ||
"https", | ||
"http" | ||
], | ||
"swagger": "2.0", | ||
"info": { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
package swaggerui | ||
|
||
import ( | ||
"embed" | ||
"io/fs" | ||
|
||
_ "github.com/go-swagger/go-swagger" | ||
) | ||
|
||
//go:embed html | ||
var swaggerFS embed.FS | ||
|
||
// FS returns a FS with SwaggerUI files in root | ||
func FS() fs.FS { | ||
rootFS, err := fs.Sub(swaggerFS, "html") | ||
if err != nil { | ||
panic(err) | ||
} | ||
return rootFS | ||
} |