1
0
mirror of https://github.com/nxshock/gwp.git synced 2025-01-18 11:21:10 +05:00

Add custom duration formatter

This commit is contained in:
nxshock 2022-01-08 18:40:23 +05:00
parent 2a342398b9
commit 35416cd502
3 changed files with 64 additions and 2 deletions

46
durationformat.go Normal file
View File

@ -0,0 +1,46 @@
package gwp
import (
"fmt"
"time"
)
func fmtDuration(d time.Duration) string {
d = d.Round(time.Second)
days := d / time.Hour / 24
d -= days * 24 * time.Hour
hours := d / time.Hour
d -= hours * time.Hour
minites := d / time.Minute
d -= minites * time.Minute
seconds := d / time.Second
d -= seconds * time.Second
var resultStr string
if days > 0 {
resultStr += fmt.Sprintf("%3dd", days)
} else {
resultStr += " "
}
if hours > 0 {
resultStr += fmt.Sprintf(" %2dh", hours)
} else {
resultStr += " "
}
if minites > 0 {
resultStr += fmt.Sprintf(" %2dm", minites)
} else {
resultStr += " "
}
resultStr += fmt.Sprintf(" %2ds", seconds)
return resultStr
}

16
durationformat_test.go Normal file
View File

@ -0,0 +1,16 @@
package gwp
import (
"testing"
"time"
"github.com/stretchr/testify/assert"
)
func TestFmtDuration(t *testing.T) {
assert.Equal(t, " 1s", fmtDuration(time.Second))
assert.Equal(t, " 1m 0s", fmtDuration(time.Minute))
assert.Equal(t, " 1h 0s", fmtDuration(time.Hour))
assert.Equal(t, " 1d 0s", fmtDuration(time.Hour*24))
assert.Equal(t, "365d 0s", fmtDuration(time.Hour*24*365))
}

4
gwp.go
View File

@ -101,7 +101,7 @@ func (workerPool *WorkerPool) printProgress() {
}
if workerPool.EstimateCount > 0 && workerPool.currentSpeed > 0 {
fmt.Fprintf(os.Stderr, " ETA: %s at %.2f rps",
time.Second*time.Duration(float64(workerPool.EstimateCount-workerPool.processedCount)/workerPool.currentSpeed), workerPool.currentSpeed)
fmtDuration(time.Second*time.Duration(float64(workerPool.EstimateCount-workerPool.processedCount)/workerPool.currentSpeed)), workerPool.currentSpeed)
}
fmt.Fprint(os.Stderr, endLine)
}
@ -121,7 +121,7 @@ func (workerPool *WorkerPool) CloseAndWait() {
workerPool.printProgress()
}
// ErrorCount returns total error count
// ErrorCount returns total error count.
func (workerPool *WorkerPool) ErrorCount() int {
return workerPool.errorCount
}