Skip to content

Commit

Permalink
chore: relint & update
Browse files Browse the repository at this point in the history
* updated go version requirement to go1.19
* updated dependencies, excepted:
   * yaml (upgrade to v3 deferred to another PR)
   * otel (upgrade is breaking: deferred to another PR)

* ci: updated linting rules, in line with other go-openapi repos
   * exception: disabled the "nilerr" linter, which currently crashes for
     this repo
* ci:updated github actions, in line with other go-openapi repos
* doc: updated README links and badges

* major relinting of all test code
* relinting non-test code is deferred to another PR (hopefully with less changes)
* changes to non-test code are limited to:
  * addition of (temporary) nolint directives
  * gofmt/typos in comments
  * unused params

TODO in forthcoming PRs:
* [ ] upgrade to yaml/v3
* [ ] upgrade OTEL packages
* [ ] gradually remove most "nolint" directives in non-test code
* [ ] complete test refactoring: some nolint directives have been added
      to skip more complex refacoring (e.g. duplicate code)

Signed-off-by: Frederic BIDON <fredbi@yahoo.com>
  • Loading branch information
fredbi committed Dec 7, 2023
1 parent 1ade6d4 commit e4cc157
Show file tree
Hide file tree
Showing 72 changed files with 2,145 additions and 1,897 deletions.
32 changes: 0 additions & 32 deletions .github/workflows/ci.yaml

This file was deleted.

50 changes: 50 additions & 0 deletions .github/workflows/go-test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
name: go test

on: [push, pull_request]

jobs:
lint:
name: Lint
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-go@v4
with:
go-version: stable
check-latest: true
cache: true
- name: golangci-lint
uses: golangci/golangci-lint-action@v3
with:
version: latest
only-new-issues: true

test:
name: Unit tests
runs-on: ${{ matrix.os }}

strategy:
matrix:
os: [ ubuntu-latest, macos-latest, windows-latest ]
go_version: ['oldstable', 'stable' ]

steps:
- name: Run unit tests
uses: actions/setup-go@v4
with:
go-version: '${{ matrix.go_version }}'
check-latest: true
cache: true

- uses: actions/checkout@v3

- run: go test -v -race -coverprofile="coverage-${{ matrix.os }}.${{ matrix.go_version }}.out" -covermode=atomic ./...

- name: Upload coverage to codecov
uses: codecov/codecov-action@v3
with:
files: './coverage-${{ matrix.os }}.${{ matrix.go_version }}.out'
flags: '${{ matrix.go_version }}'
os: '${{ matrix.os }}'
fail_ci_if_error: false
verbose: true
12 changes: 0 additions & 12 deletions .github/workflows/lint.yaml

This file was deleted.

56 changes: 37 additions & 19 deletions .golangci.yml
Original file line number Diff line number Diff line change
@@ -1,44 +1,62 @@
linters-settings:
govet:
# Using err repeatedly considered as shadowing.
check-shadowing: false
check-shadowing: true
golint:
min-confidence: 0
gocyclo:
min-complexity: 30
min-complexity: 45
maligned:
suggest-new: true
dupl:
threshold: 100
threshold: 200
goconst:
min-len: 2
min-occurrences: 4
min-occurrences: 3

linters:
enable-all: true
disable:
- nilerr # nilerr crashes on this repo
- maligned
- unparam
- lll
- gochecknoinits
- gochecknoglobals
- funlen
- godox
- gocognit
- whitespace
- wsl
- funlen
- gochecknoglobals
- gochecknoinits
- scopelint
- wrapcheck
- exhaustivestruct
- exhaustive
- nlreturn
- testpackage
- gci
- gofumpt
- goerr113
- nlreturn
- gomnd
- tparallel
- exhaustivestruct
- goerr113
- errorlint
- nestif
- godot
- errorlint
- noctx
- gofumpt
- paralleltest
- tparallel
- thelper
- ifshort
- exhaustruct
- varnamelen
- gci
- depguard
- errchkjson
- inamedparam
- nonamedreturns
- musttag
- ireturn
- forcetypeassert
- cyclop
# deprecated linters
- deadcode
- interfacer
- nilerr
- scopelint
- varcheck
- structcheck
- golint
- nosnakecase
11 changes: 7 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
# runtime [![Build Status](https://travis-ci.org/go-openapi/runtime.svg?branch=client-context)](https://travis-ci.org/go-openapi/runtime) [![codecov](https://codecov.io/gh/go-openapi/runtime/branch/master/graph/badge.svg)](https://codecov.io/gh/go-openapi/runtime) [![Slack Status](https://slackin.goswagger.io/badge.svg)](https://slackin.goswagger.io)
# runtime [![Build Status](https://github.com/go-openapi/runtime/actions/workflows/go-test.yml/badge.svg)](https://github.com/go-openapi/runtime/actions?query=workflow%3A"go+test") [![codecov](https://codecov.io/gh/go-openapi/runtime/branch/master/graph/badge.svg)](https://codecov.io/gh/go-openapi/runtime)

[![license](http://img.shields.io/badge/license-Apache%20v2-orange.svg)](https://raw.githubusercontent.com/go-openapi/runtime/master/LICENSE) [![GoDoc](https://godoc.org/github.com/go-openapi/runtime?status.svg)](http://godoc.org/github.com/go-openapi/runtime)
[![Slack Status](https://slackin.goswagger.io/badge.svg)](https://slackin.goswagger.io)
[![license](http://img.shields.io/badge/license-Apache%20v2-orange.svg)](https://raw.githubusercontent.com/go-openapi/runtime/master/LICENSE)
[![Go Reference](https://pkg.go.dev/badge/github.com/go-openapi/runtime.svg)](https://pkg.go.dev/github.com/go-openapi/runtime)
[![Go Report Card](https://goreportcard.com/badge/github.com/go-openapi/runtime)](https://goreportcard.com/report/github.com/go-openapi/runtime)

# golang Open-API toolkit - runtime
# go OpenAPI toolkit runtime

The runtime component for use in codegeneration or as untyped usage.
The runtime component for use in code generation or as untyped usage.
10 changes: 6 additions & 4 deletions authinfo_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,15 +19,17 @@ import (

"github.com/go-openapi/strfmt"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)

func TestAuthInfoWriter(t *testing.T) {
const bearerToken = "Bearer the-token-goes-here"

hand := ClientAuthInfoWriterFunc(func(r ClientRequest, _ strfmt.Registry) error {
return r.SetHeaderParam(HeaderAuthorization, "Bearer the-token-goes-here")
return r.SetHeaderParam(HeaderAuthorization, bearerToken)
})

tr := new(TestClientRequest)
err := hand.AuthenticateRequest(tr, nil)
assert.NoError(t, err)
assert.Equal(t, "Bearer the-token-goes-here", tr.Headers.Get(HeaderAuthorization))
require.NoError(t, hand.AuthenticateRequest(tr, nil))
assert.Equal(t, bearerToken, tr.Headers.Get(HeaderAuthorization))
}
8 changes: 4 additions & 4 deletions bytestream.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,10 +52,10 @@ func ByteStreamConsumer(opts ...byteStreamOpt) Consumer {
return errors.New("ByteStreamConsumer requires a reader") // early exit
}

close := defaultCloser
close := defaultCloser //nolint:revive,predeclared
if vals.Close {
if cl, ok := reader.(io.Closer); ok {
close = cl.Close
close = cl.Close //nolint:revive
}
}
//nolint:errcheck // closing a reader wouldn't fail.
Expand Down Expand Up @@ -109,10 +109,10 @@ func ByteStreamProducer(opts ...byteStreamOpt) Producer {
if writer == nil {
return errors.New("ByteStreamProducer requires a writer") // early exit
}
close := defaultCloser
close := defaultCloser //nolint:revive,predeclared
if vals.Close {
if cl, ok := writer.(io.Closer); ok {
close = cl.Close
close = cl.Close //nolint:revive
}
}
//nolint:errcheck // TODO: closing a writer would fail.
Expand Down
Loading

0 comments on commit e4cc157

Please sign in to comment.