mirror of
https://github.com/apricote/releaser-pleaser.git
synced 2026-01-13 13:21:00 +00:00
GitLab generates commit messages of the pattern "scope: message\n" if no body is present. This throws up the conventional commits parser we use, and results in the error message "missing a blank line". We now `strings.TrimSpace()` the commit message to avoid this problem.
139 lines
3.1 KiB
Go
139 lines
3.1 KiB
Go
package conventionalcommits
|
|
|
|
import (
|
|
"log/slog"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/apricote/releaser-pleaser/internal/commitparser"
|
|
"github.com/apricote/releaser-pleaser/internal/git"
|
|
)
|
|
|
|
func TestAnalyzeCommits(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
commits []git.Commit
|
|
expectedCommits []commitparser.AnalyzedCommit
|
|
wantErr assert.ErrorAssertionFunc
|
|
}{
|
|
{
|
|
name: "empty commits",
|
|
commits: []git.Commit{},
|
|
expectedCommits: []commitparser.AnalyzedCommit{},
|
|
wantErr: assert.NoError,
|
|
},
|
|
{
|
|
name: "skips malformed commit message",
|
|
commits: []git.Commit{
|
|
{
|
|
Message: "aksdjaklsdjka",
|
|
},
|
|
},
|
|
expectedCommits: []commitparser.AnalyzedCommit{},
|
|
wantErr: assert.NoError,
|
|
},
|
|
{
|
|
// GitLab seems to create commits with pattern "scope: message\n" if no body is added.
|
|
// This has previously caused a parser error "missing a blank line".
|
|
// We added a workaround with `strings.TrimSpace()` and this test make sure that it does not break again.
|
|
name: "handles title with new line",
|
|
commits: []git.Commit{
|
|
{
|
|
Message: "aksdjaklsdjka",
|
|
},
|
|
},
|
|
expectedCommits: []commitparser.AnalyzedCommit{},
|
|
wantErr: assert.NoError,
|
|
},
|
|
{
|
|
name: "drops unreleasable",
|
|
commits: []git.Commit{
|
|
{
|
|
Message: "chore: foobar",
|
|
},
|
|
},
|
|
expectedCommits: []commitparser.AnalyzedCommit{},
|
|
wantErr: assert.NoError,
|
|
},
|
|
{
|
|
name: "highest bump (patch)",
|
|
commits: []git.Commit{
|
|
{
|
|
Message: "chore: foobar",
|
|
},
|
|
{
|
|
Message: "fix: blabla",
|
|
},
|
|
},
|
|
expectedCommits: []commitparser.AnalyzedCommit{
|
|
{
|
|
Commit: git.Commit{Message: "fix: blabla"},
|
|
Type: "fix",
|
|
Description: "blabla",
|
|
},
|
|
},
|
|
wantErr: assert.NoError,
|
|
},
|
|
{
|
|
name: "highest bump (minor)",
|
|
commits: []git.Commit{
|
|
{
|
|
Message: "fix: blabla",
|
|
},
|
|
{
|
|
Message: "feat: foobar",
|
|
},
|
|
},
|
|
expectedCommits: []commitparser.AnalyzedCommit{
|
|
{
|
|
Commit: git.Commit{Message: "fix: blabla"},
|
|
Type: "fix",
|
|
Description: "blabla",
|
|
},
|
|
{
|
|
Commit: git.Commit{Message: "feat: foobar"},
|
|
Type: "feat",
|
|
Description: "foobar",
|
|
},
|
|
},
|
|
wantErr: assert.NoError,
|
|
},
|
|
|
|
{
|
|
name: "highest bump (major)",
|
|
commits: []git.Commit{
|
|
{
|
|
Message: "fix: blabla",
|
|
},
|
|
{
|
|
Message: "feat!: foobar",
|
|
},
|
|
},
|
|
expectedCommits: []commitparser.AnalyzedCommit{
|
|
{
|
|
Commit: git.Commit{Message: "fix: blabla"},
|
|
Type: "fix",
|
|
Description: "blabla",
|
|
},
|
|
{
|
|
Commit: git.Commit{Message: "feat!: foobar"},
|
|
Type: "feat",
|
|
Description: "foobar",
|
|
BreakingChange: true,
|
|
},
|
|
},
|
|
wantErr: assert.NoError,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
analyzedCommits, err := NewParser(slog.Default()).Analyze(tt.commits)
|
|
if !tt.wantErr(t, err) {
|
|
return
|
|
}
|
|
|
|
assert.Equal(t, tt.expectedCommits, analyzedCommits)
|
|
})
|
|
}
|
|
}
|