"code.gitea.io/gitea/models/db"
user_model "code.gitea.io/gitea/models/user"
"code.gitea.io/gitea/modules/timeutil"
+ "code.gitea.io/gitea/modules/util"
)
// ErrIssueStopwatchNotExist represents an error that stopwatch is not exist
// Duration returns a human-readable duration string based on local server time
func (s Stopwatch) Duration() string {
- return SecToTime(s.Seconds())
+ return util.SecToTime(s.Seconds())
}
func getStopwatch(ctx context.Context, userID, issueID int64) (sw *Stopwatch, exists bool, err error) {
Doer: user,
Issue: issue,
Repo: issue.Repo,
- Content: SecToTime(timediff),
+ Content: util.SecToTime(timediff),
Type: CommentTypeStopTracking,
TimeID: tt.ID,
}); err != nil {
}
return nil
}
-
-// SecToTime converts an amount of seconds to a human-readable string (example: 66s -> 1min 6s)
-func SecToTime(duration int64) string {
- seconds := duration % 60
- minutes := (duration / (60)) % 60
- hours := duration / (60 * 60)
-
- var hrs string
-
- if hours > 0 {
- hrs = fmt.Sprintf("%dh", hours)
- }
- if minutes > 0 {
- if hours == 0 {
- hrs = fmt.Sprintf("%dmin", minutes)
- } else {
- hrs = fmt.Sprintf("%s %dmin", hrs, minutes)
- }
- }
- if seconds > 0 {
- if hours == 0 && minutes == 0 {
- hrs = fmt.Sprintf("%ds", seconds)
- } else {
- hrs = fmt.Sprintf("%s %ds", hrs, seconds)
- }
- }
-
- return hrs
-}
"code.gitea.io/gitea/models/db"
user_model "code.gitea.io/gitea/models/user"
"code.gitea.io/gitea/modules/setting"
+ "code.gitea.io/gitea/modules/util"
"xorm.io/builder"
)
Issue: issue,
Repo: issue.Repo,
Doer: user,
- Content: SecToTime(amount),
+ Content: util.SecToTime(amount),
Type: CommentTypeAddTimeManual,
TimeID: t.ID,
}); err != nil {
}
return nil, err
}
- totalTimes[user] = SecToTime(total)
+ totalTimes[user] = util.SecToTime(total)
}
return totalTimes, nil
}
Issue: issue,
Repo: issue.Repo,
Doer: user,
- Content: "- " + SecToTime(removedTime),
+ Content: "- " + util.SecToTime(removedTime),
Type: CommentTypeDeleteTimeManual,
}); err != nil {
return err
Issue: t.Issue,
Repo: t.Issue.Repo,
Doer: t.User,
- Content: "- " + SecToTime(t.Time),
+ Content: "- " + util.SecToTime(t.Time),
Type: CommentTypeDeleteTimeManual,
}); err != nil {
return err
assert.Equal(t, int64(3661), tt.Time)
comment := unittest.AssertExistsAndLoadBean(t, &Comment{Type: CommentTypeAddTimeManual, PosterID: 3, IssueID: 1}).(*Comment)
- assert.Equal(t, comment.Content, "1h 1min 1s")
+ assert.Equal(t, comment.Content, "1h 1m 1s")
}
func TestGetTrackedTimes(t *testing.T) {
assert.Len(t, total, 1)
for user, time := range total {
assert.Equal(t, int64(1), user.ID)
- assert.Equal(t, "6min 40s", time)
+ assert.Equal(t, "6m 40s", time)
}
total, err = TotalTimes(&FindTrackedTimesOptions{IssueID: 2})
assert.Len(t, total, 2)
for user, time := range total {
if user.ID == 2 {
- assert.Equal(t, "1h 1min 2s", time)
+ assert.Equal(t, "1h 1m 2s", time)
} else if user.ID == 1 {
assert.Equal(t, "20s", time)
} else {
},
"Printf": fmt.Sprintf,
"Escape": Escape,
- "Sec2Time": models.SecToTime,
+ "Sec2Time": util.SecToTime,
"ParseDeadline": func(deadline string) []string {
return strings.Split(deadline, "|")
},
},
"Printf": fmt.Sprintf,
"Escape": Escape,
- "Sec2Time": models.SecToTime,
+ "Sec2Time": util.SecToTime,
"ParseDeadline": func(deadline string) []string {
return strings.Split(deadline, "|")
},
--- /dev/null
+// Copyright 2022 Gitea. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package util
+
+import "fmt"
+
+// SecToTime converts an amount of seconds to a human-readable string (example: 66s -> 1min 6s)
+func SecToTime(duration int64) string {
+ seconds := duration % 60
+ minutes := (duration / (60)) % 60
+ hours := duration / (60 * 60) % 24
+ days := duration / (60 * 60) / 24
+
+ var formattedTime string
+
+ if days > 0 {
+ formattedTime = fmt.Sprintf("%dd", days)
+ }
+ if hours > 0 {
+ if formattedTime == "" {
+ formattedTime = fmt.Sprintf("%dh", hours)
+ } else {
+ formattedTime = fmt.Sprintf("%s %dh", formattedTime, hours)
+ }
+ }
+ if minutes > 0 {
+ if formattedTime == "" {
+ formattedTime = fmt.Sprintf("%dm", minutes)
+ } else {
+ formattedTime = fmt.Sprintf("%s %dm", formattedTime, minutes)
+ }
+ }
+ if seconds > 0 {
+ if formattedTime == "" {
+ formattedTime = fmt.Sprintf("%ds", seconds)
+ } else {
+ formattedTime = fmt.Sprintf("%s %ds", formattedTime, seconds)
+ }
+ }
+
+ return formattedTime
+}
--- /dev/null
+// Copyright 2022 Gitea. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package util
+
+import (
+ "testing"
+
+ "github.com/stretchr/testify/assert"
+)
+
+func TestSecToTime(t *testing.T) {
+ assert.Equal(t, SecToTime(10), "10s")
+ assert.Equal(t, SecToTime(100), "1m 40s")
+ assert.Equal(t, SecToTime(1000), "16m 40s")
+ assert.Equal(t, SecToTime(10000), "2h 46m 40s")
+ assert.Equal(t, SecToTime(100000), "1d 3h 46m 40s")
+ assert.Equal(t, SecToTime(1000000), "11d 13h 46m 40s")
+}
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/context"
+ "code.gitea.io/gitea/modules/util"
"code.gitea.io/gitea/modules/web"
"code.gitea.io/gitea/services/forms"
)
return
}
- c.Flash.Success(c.Tr("repo.issues.del_time_history", models.SecToTime(t.Time)))
+ c.Flash.Success(c.Tr("repo.issues.del_time_history", util.SecToTime(t.Time)))
c.Redirect(issue.HTMLURL())
}