fix: remove GitHub Action problem matchers (#4700)
This commit is contained in:
		
							parent
							
								
									ee97dbf75b
								
							
						
					
					
						commit
						6767d7c2c9
					
				| @ -60,7 +60,17 @@ run: | ||||
| # output configuration options | ||||
| output: | ||||
|   # The formats used to render issues. | ||||
|   # Format: `colored-line-number`, `line-number`, `json`, `colored-tab`, `tab`, `checkstyle`, `code-climate`, `junit-xml`, `github-actions`, `teamcity` | ||||
|   # Formats: | ||||
|   # - `colored-line-number` | ||||
|   # - `line-number` | ||||
|   # - `json` | ||||
|   # - `colored-tab` | ||||
|   # - `tab` | ||||
|   # - `checkstyle` | ||||
|   # - `code-climate` | ||||
|   # - `junit-xml` | ||||
|   # - `github-actions` | ||||
|   # - `teamcity` | ||||
|   # Output path can be either `stdout`, `stderr` or path to the file to write to. | ||||
|   # | ||||
|   # For the CLI flag (`--out-format`), multiple formats can be specified by separating them by comma. | ||||
|  | ||||
| @ -60,7 +60,17 @@ run: | ||||
| # output configuration options | ||||
| output: | ||||
|   # The formats used to render issues. | ||||
|   # Format: `colored-line-number`, `line-number`, `json`, `colored-tab`, `tab`, `checkstyle`, `code-climate`, `junit-xml`, `github-actions`, `teamcity` | ||||
|   # Formats: | ||||
|   # - `colored-line-number` | ||||
|   # - `line-number` | ||||
|   # - `json` | ||||
|   # - `colored-tab` | ||||
|   # - `tab` | ||||
|   # - `checkstyle` | ||||
|   # - `code-climate` | ||||
|   # - `junit-xml` | ||||
|   # - `github-actions` | ||||
|   # - `teamcity` | ||||
|   # Output path can be either `stdout`, `stderr` or path to the file to write to. | ||||
|   # | ||||
|   # For the CLI flag (`--out-format`), multiple formats can be specified by separating them by comma. | ||||
|  | ||||
| @ -1,157 +0,0 @@ | ||||
| package printers | ||||
| 
 | ||||
| import ( | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"io" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 
 | ||||
| 	"github.com/golangci/golangci-lint/pkg/result" | ||||
| ) | ||||
| 
 | ||||
| const defaultGitHubSeverity = "error" | ||||
| 
 | ||||
| const filenameGitHubActionProblemMatchers = "golangci-lint-action-problem-matchers.json" | ||||
| 
 | ||||
| // GitHubProblemMatchers defines the root of problem matchers. | ||||
| // - https://github.com/actions/toolkit/blob/main/docs/problem-matchers.md | ||||
| // - https://github.com/actions/toolkit/blob/main/docs/commands.md#problem-matchers | ||||
| type GitHubProblemMatchers struct { | ||||
| 	Matchers []GitHubMatcher `json:"problemMatcher,omitempty"` | ||||
| } | ||||
| 
 | ||||
| // GitHubMatcher defines a problem matcher. | ||||
| type GitHubMatcher struct { | ||||
| 	// Owner an ID field that can be used to remove or replace the problem matcher. | ||||
| 	// **required** | ||||
| 	Owner string `json:"owner,omitempty"` | ||||
| 	// Severity indicates the default severity, either 'warning' or 'error' case-insensitive. | ||||
| 	// Defaults to 'error'. | ||||
| 	Severity string          `json:"severity,omitempty"` | ||||
| 	Pattern  []GitHubPattern `json:"pattern,omitempty"` | ||||
| } | ||||
| 
 | ||||
| // GitHubPattern defines a pattern for a problem matcher. | ||||
| type GitHubPattern struct { | ||||
| 	// Regexp the regexp pattern that provides the groups to match against. | ||||
| 	// **required** | ||||
| 	Regexp string `json:"regexp,omitempty"` | ||||
| 	// File a group number containing the file name. | ||||
| 	File int `json:"file,omitempty"` | ||||
| 	// FromPath a group number containing a filepath used to root the file (e.g. a project file). | ||||
| 	FromPath int `json:"fromPath,omitempty"` | ||||
| 	// Line a group number containing the line number. | ||||
| 	Line int `json:"line,omitempty"` | ||||
| 	// Column a group number containing the column information. | ||||
| 	Column int `json:"column,omitempty"` | ||||
| 	// Severity a group number containing either 'warning' or 'error' case-insensitive. | ||||
| 	// Defaults to `error`. | ||||
| 	Severity int `json:"severity,omitempty"` | ||||
| 	// Code a group number containing the error code. | ||||
| 	Code int `json:"code,omitempty"` | ||||
| 	// Message a group number containing the error message. | ||||
| 	// **required** at least one pattern must set the message. | ||||
| 	Message int `json:"message,omitempty"` | ||||
| 	// Loop whether to loop until a match is not found, | ||||
| 	// only valid on the last pattern of a multi-pattern matcher. | ||||
| 	Loop bool `json:"loop,omitempty"` | ||||
| } | ||||
| 
 | ||||
| type GitHub struct { | ||||
| 	tempPath string | ||||
| 	w        io.Writer | ||||
| } | ||||
| 
 | ||||
| // NewGitHub output format outputs issues according to GitHub actions the problem matcher regexp. | ||||
| func NewGitHub(w io.Writer) *GitHub { | ||||
| 	return &GitHub{ | ||||
| 		tempPath: filepath.Join(os.TempDir(), filenameGitHubActionProblemMatchers), | ||||
| 		w:        w, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (p *GitHub) Print(issues []result.Issue) error { | ||||
| 	// Note: the file with the problem matcher definition should not be removed. | ||||
| 	// A sleep can mitigate this problem but this will be flaky. | ||||
| 	// | ||||
| 	// Result if the file is removed prematurely: | ||||
| 	// Error: Unable to process command '::add-matcher::/tmp/golangci-lint-action-problem-matchers.json' successfully. | ||||
| 	// Error: Could not find file '/tmp/golangci-lint-action-problem-matchers.json'. | ||||
| 	filename, err := p.storeProblemMatcher() | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	_, _ = fmt.Fprintln(p.w, "::debug::problem matcher definition file: "+filename) | ||||
| 
 | ||||
| 	_, _ = fmt.Fprintln(p.w, "::add-matcher::"+filename) | ||||
| 
 | ||||
| 	for ind := range issues { | ||||
| 		_, err := fmt.Fprintln(p.w, formatIssueAsGitHub(&issues[ind])) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	_, _ = fmt.Fprintln(p.w, "::remove-matcher owner=golangci-lint-action::") | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (p *GitHub) storeProblemMatcher() (string, error) { | ||||
| 	file, err := os.Create(p.tempPath) | ||||
| 	if err != nil { | ||||
| 		return "", err | ||||
| 	} | ||||
| 
 | ||||
| 	defer file.Close() | ||||
| 
 | ||||
| 	err = json.NewEncoder(file).Encode(generateProblemMatcher()) | ||||
| 	if err != nil { | ||||
| 		return "", err | ||||
| 	} | ||||
| 
 | ||||
| 	return file.Name(), nil | ||||
| } | ||||
| 
 | ||||
| func generateProblemMatcher() GitHubProblemMatchers { | ||||
| 	return GitHubProblemMatchers{ | ||||
| 		Matchers: []GitHubMatcher{ | ||||
| 			{ | ||||
| 				Owner:    "golangci-lint-action", | ||||
| 				Severity: "error", | ||||
| 				Pattern: []GitHubPattern{ | ||||
| 					{ | ||||
| 						Regexp:   `^([^\s]+)\s+([^:]+):(\d+):(?:(\d+):)?\s+(.+)$`, | ||||
| 						Severity: 1, | ||||
| 						File:     2, | ||||
| 						Line:     3, | ||||
| 						Column:   4, | ||||
| 						Message:  5, | ||||
| 					}, | ||||
| 				}, | ||||
| 			}, | ||||
| 		}, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func formatIssueAsGitHub(issue *result.Issue) string { | ||||
| 	severity := defaultGitHubSeverity | ||||
| 	if issue.Severity != "" { | ||||
| 		severity = issue.Severity | ||||
| 	} | ||||
| 
 | ||||
| 	// Convert backslashes to forward slashes. | ||||
| 	// This is needed when running on windows. | ||||
| 	// Otherwise, GitHub won't be able to show the annotations pointing to the file path with backslashes. | ||||
| 	file := filepath.ToSlash(issue.FilePath()) | ||||
| 
 | ||||
| 	ret := fmt.Sprintf("%s\t%s:%d:", severity, file, issue.Line()) | ||||
| 	if issue.Pos.Column != 0 { | ||||
| 		ret += fmt.Sprintf("%d:", issue.Pos.Column) | ||||
| 	} | ||||
| 
 | ||||
| 	ret += fmt.Sprintf("\t%s (%s)", issue.Text, issue.FromLinter) | ||||
| 	return ret | ||||
| } | ||||
| @ -1,197 +0,0 @@ | ||||
| package printers | ||||
| 
 | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"fmt" | ||||
| 	"go/token" | ||||
| 	"path/filepath" | ||||
| 	"regexp" | ||||
| 	"runtime" | ||||
| 	"strings" | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| 	"github.com/stretchr/testify/require" | ||||
| 
 | ||||
| 	"github.com/golangci/golangci-lint/pkg/result" | ||||
| ) | ||||
| 
 | ||||
| func TestGitHub_Print(t *testing.T) { | ||||
| 	issues := []result.Issue{ | ||||
| 		{ | ||||
| 			FromLinter: "linter-a", | ||||
| 			Severity:   "warning", | ||||
| 			Text:       "some issue", | ||||
| 			Pos: token.Position{ | ||||
| 				Filename: "path/to/filea.go", | ||||
| 				Offset:   2, | ||||
| 				Line:     10, | ||||
| 				Column:   4, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			FromLinter: "linter-b", | ||||
| 			Severity:   "error", | ||||
| 			Text:       "another issue", | ||||
| 			SourceLines: []string{ | ||||
| 				"func foo() {", | ||||
| 				"\tfmt.Println(\"bar\")", | ||||
| 				"}", | ||||
| 			}, | ||||
| 			Pos: token.Position{ | ||||
| 				Filename: "path/to/fileb.go", | ||||
| 				Offset:   5, | ||||
| 				Line:     300, | ||||
| 				Column:   9, | ||||
| 			}, | ||||
| 		}, | ||||
| 	} | ||||
| 
 | ||||
| 	buf := new(bytes.Buffer) | ||||
| 
 | ||||
| 	printer := NewGitHub(buf) | ||||
| 	printer.tempPath = filepath.Join(t.TempDir(), filenameGitHubActionProblemMatchers) | ||||
| 
 | ||||
| 	err := printer.Print(issues) | ||||
| 	require.NoError(t, err) | ||||
| 
 | ||||
| 	expected := `::debug::problem matcher definition file: /tmp/golangci-lint-action-problem-matchers.json | ||||
| ::add-matcher::/tmp/golangci-lint-action-problem-matchers.json | ||||
| warning	path/to/filea.go:10:4:	some issue (linter-a) | ||||
| error	path/to/fileb.go:300:9:	another issue (linter-b) | ||||
| ::remove-matcher owner=golangci-lint-action:: | ||||
| ` | ||||
| 	// To support all the OS. | ||||
| 	expected = strings.ReplaceAll(expected, "/tmp/golangci-lint-action-problem-matchers.json", printer.tempPath) | ||||
| 
 | ||||
| 	assert.Equal(t, expected, buf.String()) | ||||
| } | ||||
| 
 | ||||
| func Test_formatIssueAsGitHub(t *testing.T) { | ||||
| 	sampleIssue := result.Issue{ | ||||
| 		FromLinter: "sample-linter", | ||||
| 		Text:       "some issue", | ||||
| 		Pos: token.Position{ | ||||
| 			Filename: "path/to/file.go", | ||||
| 			Offset:   2, | ||||
| 			Line:     10, | ||||
| 			Column:   4, | ||||
| 		}, | ||||
| 	} | ||||
| 	require.Equal(t, "error\tpath/to/file.go:10:4:\tsome issue (sample-linter)", formatIssueAsGitHub(&sampleIssue)) | ||||
| 
 | ||||
| 	sampleIssue.Pos.Column = 0 | ||||
| 	require.Equal(t, "error\tpath/to/file.go:10:\tsome issue (sample-linter)", formatIssueAsGitHub(&sampleIssue)) | ||||
| } | ||||
| 
 | ||||
| func Test_formatIssueAsGitHub_Windows(t *testing.T) { | ||||
| 	if runtime.GOOS != "windows" { | ||||
| 		t.Skip("Skipping test on non Windows") | ||||
| 	} | ||||
| 
 | ||||
| 	sampleIssue := result.Issue{ | ||||
| 		FromLinter: "sample-linter", | ||||
| 		Text:       "some issue", | ||||
| 		Pos: token.Position{ | ||||
| 			Filename: "path\\to\\file.go", | ||||
| 			Offset:   2, | ||||
| 			Line:     10, | ||||
| 			Column:   4, | ||||
| 		}, | ||||
| 	} | ||||
| 	require.Equal(t, "error\tpath/to/file.go:10:4:\tsome issue (sample-linter)", formatIssueAsGitHub(&sampleIssue)) | ||||
| 
 | ||||
| 	sampleIssue.Pos.Column = 0 | ||||
| 	require.Equal(t, "error\tpath/to/file.go:10:\tsome issue (sample-linter)", formatIssueAsGitHub(&sampleIssue)) | ||||
| } | ||||
| 
 | ||||
| func Test_generateProblemMatcher(t *testing.T) { | ||||
| 	pattern := generateProblemMatcher().Matchers[0].Pattern[0] | ||||
| 
 | ||||
| 	exp := regexp.MustCompile(pattern.Regexp) | ||||
| 
 | ||||
| 	testCases := []struct { | ||||
| 		desc     string | ||||
| 		line     string | ||||
| 		expected string | ||||
| 	}{ | ||||
| 		{ | ||||
| 			desc: "error", | ||||
| 			line: "error\tpath/to/filea.go:10:4:\tsome issue (sample-linter)", | ||||
| 			expected: `File: path/to/filea.go | ||||
| Line: 10 | ||||
| Column: 4 | ||||
| Severity: error | ||||
| Message: some issue (sample-linter)`, | ||||
| 		}, | ||||
| 		{ | ||||
| 			desc: "warning", | ||||
| 			line: "warning\tpath/to/fileb.go:1:4:\tsome issue (sample-linter)", | ||||
| 			expected: `File: path/to/fileb.go | ||||
| Line: 1 | ||||
| Column: 4 | ||||
| Severity: warning | ||||
| Message: some issue (sample-linter)`, | ||||
| 		}, | ||||
| 		{ | ||||
| 			desc: "no column", | ||||
| 			line: "error\t \tpath/to/fileb.go:40:\t Foo bar", | ||||
| 			expected: `File: path/to/fileb.go | ||||
| Line: 40 | ||||
| Column:  | ||||
| Severity: error | ||||
| Message: Foo bar`, | ||||
| 		}, | ||||
| 	} | ||||
| 
 | ||||
| 	for _, test := range testCases { | ||||
| 		test := test | ||||
| 		t.Run(test.desc, func(t *testing.T) { | ||||
| 			t.Parallel() | ||||
| 
 | ||||
| 			assert.True(t, exp.MatchString(test.line), test.line) | ||||
| 
 | ||||
| 			actual := exp.ReplaceAllString(test.line, createReplacement(&pattern)) | ||||
| 
 | ||||
| 			assert.Equal(t, test.expected, actual) | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func createReplacement(pattern *GitHubPattern) string { | ||||
| 	var repl []string | ||||
| 
 | ||||
| 	if pattern.File > 0 { | ||||
| 		repl = append(repl, fmt.Sprintf("File: $%d", pattern.File)) | ||||
| 	} | ||||
| 
 | ||||
| 	if pattern.FromPath > 0 { | ||||
| 		repl = append(repl, fmt.Sprintf("FromPath: $%d", pattern.FromPath)) | ||||
| 	} | ||||
| 
 | ||||
| 	if pattern.Line > 0 { | ||||
| 		repl = append(repl, fmt.Sprintf("Line: $%d", pattern.Line)) | ||||
| 	} | ||||
| 
 | ||||
| 	if pattern.Column > 0 { | ||||
| 		repl = append(repl, fmt.Sprintf("Column: $%d", pattern.Column)) | ||||
| 	} | ||||
| 
 | ||||
| 	if pattern.Severity > 0 { | ||||
| 		repl = append(repl, fmt.Sprintf("Severity: $%d", pattern.Severity)) | ||||
| 	} | ||||
| 
 | ||||
| 	if pattern.Code > 0 { | ||||
| 		repl = append(repl, fmt.Sprintf("Code: $%d", pattern.Code)) | ||||
| 	} | ||||
| 
 | ||||
| 	if pattern.Message > 0 { | ||||
| 		repl = append(repl, fmt.Sprintf("Message: $%d", pattern.Message)) | ||||
| 	} | ||||
| 
 | ||||
| 	if pattern.Loop { | ||||
| 		repl = append(repl, fmt.Sprintf("Loop: $%v", pattern.Loop)) | ||||
| 	} | ||||
| 
 | ||||
| 	return strings.Join(repl, "\n") | ||||
| } | ||||
							
								
								
									
										51
									
								
								pkg/printers/githubaction.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								pkg/printers/githubaction.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,51 @@ | ||||
| package printers | ||||
| 
 | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"io" | ||||
| 	"path/filepath" | ||||
| 
 | ||||
| 	"github.com/golangci/golangci-lint/pkg/result" | ||||
| ) | ||||
| 
 | ||||
| const defaultGithubSeverity = "error" | ||||
| 
 | ||||
| type GitHubAction struct { | ||||
| 	w io.Writer | ||||
| } | ||||
| 
 | ||||
| // NewGitHubAction output format outputs issues according to GitHub actions. | ||||
| func NewGitHubAction(w io.Writer) *GitHubAction { | ||||
| 	return &GitHubAction{w: w} | ||||
| } | ||||
| 
 | ||||
| func (p *GitHubAction) Print(issues []result.Issue) error { | ||||
| 	for ind := range issues { | ||||
| 		_, err := fmt.Fprintln(p.w, formatIssueAsGitHub(&issues[ind])) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // print each line as: ::error file=app.js,line=10,col=15::Something went wrong | ||||
| func formatIssueAsGitHub(issue *result.Issue) string { | ||||
| 	severity := defaultGithubSeverity | ||||
| 	if issue.Severity != "" { | ||||
| 		severity = issue.Severity | ||||
| 	} | ||||
| 
 | ||||
| 	// Convert backslashes to forward slashes. | ||||
| 	// This is needed when running on windows. | ||||
| 	// Otherwise, GitHub won't be able to show the annotations pointing to the file path with backslashes. | ||||
| 	file := filepath.ToSlash(issue.FilePath()) | ||||
| 
 | ||||
| 	ret := fmt.Sprintf("::%s file=%s,line=%d", severity, file, issue.Line()) | ||||
| 	if issue.Pos.Column != 0 { | ||||
| 		ret += fmt.Sprintf(",col=%d", issue.Pos.Column) | ||||
| 	} | ||||
| 
 | ||||
| 	ret += fmt.Sprintf("::%s (%s)", issue.Text, issue.FromLinter) | ||||
| 	return ret | ||||
| } | ||||
							
								
								
									
										95
									
								
								pkg/printers/githubaction_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								pkg/printers/githubaction_test.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,95 @@ | ||||
| package printers | ||||
| 
 | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"go/token" | ||||
| 	"runtime" | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| 	"github.com/stretchr/testify/require" | ||||
| 
 | ||||
| 	"github.com/golangci/golangci-lint/pkg/result" | ||||
| ) | ||||
| 
 | ||||
| func TestGitHubAction_Print(t *testing.T) { | ||||
| 	issues := []result.Issue{ | ||||
| 		{ | ||||
| 			FromLinter: "linter-a", | ||||
| 			Severity:   "warning", | ||||
| 			Text:       "some issue", | ||||
| 			Pos: token.Position{ | ||||
| 				Filename: "path/to/filea.go", | ||||
| 				Offset:   2, | ||||
| 				Line:     10, | ||||
| 				Column:   4, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			FromLinter: "linter-b", | ||||
| 			Severity:   "error", | ||||
| 			Text:       "another issue", | ||||
| 			SourceLines: []string{ | ||||
| 				"func foo() {", | ||||
| 				"\tfmt.Println(\"bar\")", | ||||
| 				"}", | ||||
| 			}, | ||||
| 			Pos: token.Position{ | ||||
| 				Filename: "path/to/fileb.go", | ||||
| 				Offset:   5, | ||||
| 				Line:     300, | ||||
| 				Column:   9, | ||||
| 			}, | ||||
| 		}, | ||||
| 	} | ||||
| 
 | ||||
| 	buf := new(bytes.Buffer) | ||||
| 	printer := NewGitHubAction(buf) | ||||
| 
 | ||||
| 	err := printer.Print(issues) | ||||
| 	require.NoError(t, err) | ||||
| 
 | ||||
| 	expected := `::warning file=path/to/filea.go,line=10,col=4::some issue (linter-a) | ||||
| ::error file=path/to/fileb.go,line=300,col=9::another issue (linter-b) | ||||
| ` | ||||
| 
 | ||||
| 	assert.Equal(t, expected, buf.String()) | ||||
| } | ||||
| 
 | ||||
| func Test_formatIssueAsGitHub(t *testing.T) { | ||||
| 	sampleIssue := result.Issue{ | ||||
| 		FromLinter: "sample-linter", | ||||
| 		Text:       "some issue", | ||||
| 		Pos: token.Position{ | ||||
| 			Filename: "path/to/file.go", | ||||
| 			Offset:   2, | ||||
| 			Line:     10, | ||||
| 			Column:   4, | ||||
| 		}, | ||||
| 	} | ||||
| 	require.Equal(t, "::error file=path/to/file.go,line=10,col=4::some issue (sample-linter)", formatIssueAsGitHub(&sampleIssue)) | ||||
| 
 | ||||
| 	sampleIssue.Pos.Column = 0 | ||||
| 	require.Equal(t, "::error file=path/to/file.go,line=10::some issue (sample-linter)", formatIssueAsGitHub(&sampleIssue)) | ||||
| } | ||||
| 
 | ||||
| func Test_formatIssueAsGitHub_Windows(t *testing.T) { | ||||
| 	if runtime.GOOS != "windows" { | ||||
| 		t.Skip("Skipping test on non Windows") | ||||
| 	} | ||||
| 
 | ||||
| 	sampleIssue := result.Issue{ | ||||
| 		FromLinter: "sample-linter", | ||||
| 		Text:       "some issue", | ||||
| 		Pos: token.Position{ | ||||
| 			Filename: "path\\to\\file.go", | ||||
| 			Offset:   2, | ||||
| 			Line:     10, | ||||
| 			Column:   4, | ||||
| 		}, | ||||
| 	} | ||||
| 	require.Equal(t, "::error file=path/to/file.go,line=10,col=4::some issue (sample-linter)", formatIssueAsGitHub(&sampleIssue)) | ||||
| 
 | ||||
| 	sampleIssue.Pos.Column = 0 | ||||
| 	require.Equal(t, "::error file=path/to/file.go,line=10::some issue (sample-linter)", formatIssueAsGitHub(&sampleIssue)) | ||||
| } | ||||
| @ -132,7 +132,7 @@ func (c *Printer) createPrinter(format string, w io.Writer) (issuePrinter, error | ||||
| 	case config.OutFormatJunitXML: | ||||
| 		p = NewJunitXML(w) | ||||
| 	case config.OutFormatGithubActions: | ||||
| 		p = NewGitHub(w) | ||||
| 		p = NewGitHubAction(w) | ||||
| 	case config.OutFormatTeamCity: | ||||
| 		p = NewTeamCity(w) | ||||
| 	default: | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Ludovic Fernandez
						Ludovic Fernandez