Compare commits

...

10 Commits
0.10.1 ... main

Author SHA1 Message Date
964ea60e55 chore: bump 0.12.0 → 0.13.0 [CI SKIP]
All checks were successful
continuous-integration/drone/tag Build is passing
2024-10-25 16:16:43 +00:00
2386e278c7 Merge branch 'main' of https://gitea.dikurium.ch/InnoPeak/drone-gitea-release into main
Some checks failed
continuous-integration/drone/push Build is failing
2024-10-25 18:16:24 +02:00
66de41874d feat: use time.Time.Before() instead of Sub() 2024-10-25 18:16:24 +02:00
9aace7aa2b chore: bump 0.11.1 → 0.12.0 [CI SKIP]
All checks were successful
continuous-integration/drone/tag Build is passing
2024-10-25 16:14:51 +00:00
6c787535a8 feat: use tagger.when to find latest tag
Some checks failed
continuous-integration/drone/push Build is failing
2024-10-25 18:14:25 +02:00
e65c52c67c chore: bump 0.11.0 → 0.11.1 [CI SKIP]
All checks were successful
continuous-integration/drone/tag Build is passing
2024-07-11 17:54:57 +02:00
d19022dad8 fix: 🐛 append newline after success message, use logger [CI SKIP] 2024-07-11 17:54:33 +02:00
2daf8b0d53 chore: bump 0.10.1 → 0.11.0 [CI SKIP]
All checks were successful
continuous-integration/drone/tag Build is passing
2024-07-11 15:34:11 +00:00
d9f25a2613 Merge branch 'main' of https://gitea.dikurium.ch/InnoPeak/drone-gitea-release into main
Some checks failed
continuous-integration/drone/push Build is failing
2024-07-11 17:33:48 +02:00
b2c43a5f3d feat: use log.textformatter 2024-07-11 17:33:47 +02:00
5 changed files with 50 additions and 29 deletions

View File

@ -1,3 +1,27 @@
## 0.13.0 (2024-10-25)
### Feat
- :sparkles: use time.Time.Before() instead of Sub()
## 0.12.0 (2024-10-25)
### Feat
- :sparkles: use tagger.when to find latest tag
## 0.11.1 (2024-07-11)
### Fix
- :bug: append newline after success message, use logger [CI SKIP]
## 0.11.0 (2024-07-11)
### Feat
- :sparkles: use log.textformatter
## 0.10.1 (2024-07-11)
### Fix

View File

@ -5,5 +5,5 @@ commitizen:
name: cz_conventional_commits
tag_format: $version
update_changelog_on_bump: true
version: 0.10.1
version: 0.13.0
version_scheme: semver

19
main.go
View File

@ -55,14 +55,14 @@ func init() {
}
func main() {
log.SetFormatter(new(formatter))
log.SetFormatter(&log.TextFormatter{
DisableTimestamp: true,
})
switch args.Level {
case "debug":
log.SetFormatter(textFormatter)
log.SetLevel(log.DebugLevel)
case "trace":
log.SetFormatter(textFormatter)
log.SetLevel(log.TraceLevel)
}
@ -70,16 +70,3 @@ func main() {
log.Fatalln(err)
}
}
// default formatter that writes logs without including timestamp
// or level information.
type formatter struct{}
func (*formatter) Format(entry *log.Entry) ([]byte, error) {
return []byte(entry.Message), nil
}
// text formatter that writes logs with level information
var textFormatter = &log.TextFormatter{
DisableTimestamp: true,
}

View File

@ -172,7 +172,7 @@ func Exec(ctx context.Context, args Args) error {
}
releaseURL := fmt.Sprintf("%s/%s/%s/releases/tag/%s", args.GiteaUrl, args.Owner, args.Repo, release.TagName)
fmt.Printf("Successfully created release at %s", releaseURL)
log.WithField("url", releaseURL).Info("Successfully created release")
writeCard(
args.Pipeline.Card.Path,

View File

@ -11,7 +11,7 @@ import (
"io"
"net/http"
"os"
"strings"
"time"
"github.com/go-git/go-git/v5"
"github.com/go-git/go-git/v5/plumbing/transport/client"
@ -50,7 +50,7 @@ func SetBasicAuth(username, password string) func(repo *git.Repository) error {
func FetchTags() func(repo *git.Repository) error {
return func(repo *git.Repository) error {
log.Info("Fetching latest git tags")
log.Info("Fetching git tags")
err := repo.Fetch(&git.FetchOptions{Tags: git.AllTags})
@ -62,28 +62,34 @@ func FetchTags() func(repo *git.Repository) error {
}
}
func getLatestGitTag(options ...GetLatestGitTagOption) (tag string, err error) {
r, err := git.PlainOpen(".")
func getLatestGitTag(options ...GetLatestGitTagOption) (string, error) {
var (
tag string
tagDate *time.Time
err error
)
repo, err := git.PlainOpen(".")
if err != nil {
return "", fmt.Errorf("error opening git repo at %s: %w", ".", err)
}
for _, opt := range options {
err := opt(r)
err := opt(repo)
if err != nil {
return "", err
}
}
tagRefs, err := r.Tags()
tags, err := repo.TagObjects()
if err != nil {
return "", fmt.Errorf("error getting git tag refs %w", err)
return "", fmt.Errorf("error getting git tags %w", err)
}
for {
r, err := tagRefs.Next()
t, err := tags.Next()
if err == io.EOF {
break
@ -93,15 +99,19 @@ func getLatestGitTag(options ...GetLatestGitTagOption) (tag string, err error) {
return "", fmt.Errorf("error iterating tags %w", err)
}
parts := strings.Split(string(r.Name()), "/")
tag = strings.Join(parts[2:], "/")
if tagDate != nil && t.Tagger.When.Before(*tagDate) {
continue
}
tagDate = &t.Tagger.When
tag = t.Name
}
if tag == "" {
return tag, fmt.Errorf("couldn't find any git tags")
}
return
return tag, err
}
func writeCard(path, schema string, card interface{}) {