1
0
Fork 0
mirror of https://code.forgejo.org/forgejo/runner.git synced 2025-09-15 18:57:01 +00:00

ci: replace superlinter with megalinter (#923)

* ci: replace superlinter with megalinter

Signed-off-by: hackercat <me@hackerc.at>

* fix: apply lint recommendations

Signed-off-by: hackercat <me@hackerc.at>
This commit is contained in:
Ryan 2021-12-22 18:29:43 +01:00 committed by GitHub
parent 06ef9ae6fe
commit 73c17d4258
8 changed files with 22 additions and 34 deletions

View file

@ -5,11 +5,11 @@
version: 2 version: 2
updates: updates:
- package-ecosystem: "github-actions" - package-ecosystem: 'github-actions'
directory: "/" directory: '/'
schedule: schedule:
interval: "weekly" interval: 'weekly'
- package-ecosystem: "gomod" - package-ecosystem: 'gomod'
directory: "/" directory: '/'
schedule: schedule:
interval: "weekly" interval: 'weekly'

View file

@ -1 +0,0 @@
../../.golangci.yml

View file

@ -1 +0,0 @@
../../.markdownlint.yml

View file

@ -5,6 +5,7 @@ env:
ACT_OWNER: ${{ github.repository_owner }} ACT_OWNER: ${{ github.repository_owner }}
ACT_REPOSITORY: ${{ github.repository }} ACT_REPOSITORY: ${{ github.repository }}
GO_VERSION: 1.17 GO_VERSION: 1.17
CGO_ENABLED: 0
jobs: jobs:
lint: lint:
@ -18,22 +19,15 @@ jobs:
with: with:
go-version: ${{ env.GO_VERSION }} go-version: ${{ env.GO_VERSION }}
- uses: golangci/golangci-lint-action@v2 - uses: golangci/golangci-lint-action@v2
env:
CGO_ENABLED: 0
with: with:
version: latest version: latest
- uses: github/super-linter@v3 - uses: megalinter/megalinter/flavors/go@v5
env: env:
DEFAULT_BRANCH: master DEFAULT_BRANCH: master
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
FILTER_REGEX_EXCLUDE: .*testdata/*
VALIDATE_ALL_CODEBASE: false VALIDATE_ALL_CODEBASE: false
VALIDATE_BASH: false GITHUB_STATUS_REPORTER: ${{ !env.ACT }}
VALIDATE_DOCKERFILE: false GITHUB_COMMENT_REPORTER: ${{ !env.ACT }}
VALIDATE_DOCKERFILE_HADOLINT: false
VALIDATE_GO: false # it's broken, see commit message
VALIDATE_JSCPD: false
VALIDATE_SHELL_SHFMT: false
test-linux: test-linux:
name: test-linux name: test-linux
@ -55,8 +49,6 @@ jobs:
restore-keys: | restore-keys: |
${{ runner.os }}-go- ${{ runner.os }}-go-
- run: go test -v -cover -coverprofile=coverage.txt -covermode=atomic ./... - run: go test -v -cover -coverprofile=coverage.txt -covermode=atomic ./...
env:
CGO_ENABLED: 0
- name: Upload Codecov report - name: Upload Codecov report
uses: codecov/codecov-action@v2.1.0 uses: codecov/codecov-action@v2.1.0
with: with:

View file

@ -88,8 +88,7 @@ func NewContainer(input *NewContainerInput) Container {
// supportsContainerImagePlatform returns true if the underlying Docker server // supportsContainerImagePlatform returns true if the underlying Docker server
// API version is 1.41 and beyond // API version is 1.41 and beyond
func supportsContainerImagePlatform(cli *client.Client) bool { func supportsContainerImagePlatform(ctx context.Context, cli *client.Client) bool {
ctx := context.TODO()
logger := common.Logger(ctx) logger := common.Logger(ctx)
ver, err := cli.ServerVersion(ctx) ver, err := cli.ServerVersion(ctx)
if err != nil { if err != nil {
@ -290,7 +289,7 @@ func (cr *containerReference) remove() common.Executor {
} }
logger := common.Logger(ctx) logger := common.Logger(ctx)
err := cr.cli.ContainerRemove(context.Background(), cr.id, types.ContainerRemoveOptions{ err := cr.cli.ContainerRemove(ctx, cr.id, types.ContainerRemoveOptions{
RemoveVolumes: true, RemoveVolumes: true,
Force: true, Force: true,
}) })
@ -333,7 +332,7 @@ func (cr *containerReference) create(capAdd []string, capDrop []string) common.E
} }
var platSpecs *specs.Platform var platSpecs *specs.Platform
if supportsContainerImagePlatform(cr.cli) && cr.input.Platform != "" { if supportsContainerImagePlatform(ctx, cr.cli) && cr.input.Platform != "" {
desiredPlatform := strings.SplitN(cr.input.Platform, `/`, 2) desiredPlatform := strings.SplitN(cr.input.Platform, `/`, 2)
if len(desiredPlatform) != 2 { if len(desiredPlatform) != 2 {

View file

@ -158,24 +158,24 @@ func (*expressionEvaluator) advString(w *strings.Builder, r *strings.Reader) err
return err return err
} }
if c != '\'' { if c != '\'' {
w.WriteRune(c) //nolint w.WriteRune(c)
continue continue
} }
// Handles a escaped string: ex. 'It''s ok' // Handles a escaped string: ex. 'It''s ok'
c, _, err = r.ReadRune() c, _, err = r.ReadRune()
if err != nil { if err != nil {
w.WriteString("'") //nolint w.WriteString("'")
return err return err
} }
if c != '\'' { if c != '\'' {
w.WriteString("'") //nolint w.WriteString("'")
if err := r.UnreadRune(); err != nil { if err := r.UnreadRune(); err != nil {
return err return err
} }
break break
} }
w.WriteString(`\'`) //nolint w.WriteString(`\'`)
} }
return nil return nil
} }
@ -192,7 +192,7 @@ func (*expressionEvaluator) advPropertyName(w *strings.Builder, r *strings.Reade
} }
break break
} }
w.WriteRune(c) //nolint w.WriteRune(c)
} }
return nil return nil
} }

View file

@ -342,7 +342,7 @@ func (rc *RunContext) newStepExecutor(step *model.Step) common.Executor {
rc.ExprEval = exprEval rc.ExprEval = exprEval
common.Logger(ctx).Infof("\u2B50 Run %s", sc.Step) common.Logger(ctx).Infof("\u2B50 Run %s", sc.Step)
err = sc.Executor()(ctx) err = sc.Executor(ctx)(ctx)
if err == nil { if err == nil {
common.Logger(ctx).Infof(" \u2705 Success - %s", sc.Step) common.Logger(ctx).Infof(" \u2705 Success - %s", sc.Step)
} else { } else {

View file

@ -46,7 +46,7 @@ func (e formatError) Error() string {
} }
// Executor for a step context // Executor for a step context
func (sc *StepContext) Executor() common.Executor { func (sc *StepContext) Executor(ctx context.Context) common.Executor {
rc := sc.RunContext rc := sc.RunContext
step := sc.Step step := sc.Step
@ -92,7 +92,7 @@ func (sc *StepContext) Executor() common.Executor {
Token: github.Token, Token: github.Token,
}) })
var ntErr common.Executor var ntErr common.Executor
if err := gitClone(context.TODO()); err != nil { if err := gitClone(ctx); err != nil {
if err.Error() == "short SHA references are not supported" { if err.Error() == "short SHA references are not supported" {
err = errors.Cause(err) err = errors.Cause(err)
return common.NewErrorExecutor(fmt.Errorf("Unable to resolve action `%s`, the provided ref `%s` is the shortened version of a commit SHA, which is not supported. Please use the full commit SHA `%s` instead", step.Uses, remoteAction.Ref, err.Error())) return common.NewErrorExecutor(fmt.Errorf("Unable to resolve action `%s`, the provided ref `%s` is the shortened version of a commit SHA, which is not supported. Please use the full commit SHA `%s` instead", step.Uses, remoteAction.Ref, err.Error()))
@ -482,7 +482,6 @@ func (sc *StepContext) getContainerActionPaths(step *model.Step, actionDir strin
return actionName, containerActionDir return actionName, containerActionDir
} }
// nolint: gocyclo
func (sc *StepContext) runAction(actionDir string, actionPath string, localAction bool) common.Executor { func (sc *StepContext) runAction(actionDir string, actionPath string, localAction bool) common.Executor {
rc := sc.RunContext rc := sc.RunContext
step := sc.Step step := sc.Step
@ -704,7 +703,7 @@ func (sc *StepContext) execAsComposite(ctx context.Context, step *model.Step, _
stepContext.Step = &stepClone stepContext.Step = &stepClone
executors = append(executors, stepContext.Executor()) executors = append(executors, stepContext.Executor(ctx))
} }
return common.NewPipelineExecutor(executors...)(ctx) return common.NewPipelineExecutor(executors...)(ctx)
} }