mirror of
https://github.com/hay-kot/homebox.git
synced 2024-11-22 16:45:43 +00:00
db80f8a159
* move typegen code * update taskfile to fix code-gen caches and use 'dir' attribute * enable dumping stack traces for errors * log request start and stop * set zerolog stack handler * fix routes function * refactor context adapters to use requests directly * change some method signatures to support GID * start requiring validation tags * first pass on updating handlers to use adapters * add errs package * code gen * tidy * rework API to use external server package
86 lines
1.9 KiB
Go
86 lines
1.9 KiB
Go
package repo
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/hay-kot/homebox/backend/internal/data/types"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
// get the previous month from the current month, accounts for errors when run
|
|
// near the beginning or end of the month/year
|
|
func getPrevMonth(now time.Time) time.Time {
|
|
t := now.AddDate(0, -1, 0)
|
|
|
|
// avoid infinite loop
|
|
max := 15
|
|
for t.Month() == now.Month() {
|
|
t = t.AddDate(0, 0, -1)
|
|
|
|
max--
|
|
if max == 0 {
|
|
panic("max exceeded")
|
|
}
|
|
}
|
|
|
|
return t
|
|
}
|
|
|
|
func TestMaintenanceEntryRepository_GetLog(t *testing.T) {
|
|
item := useItems(t, 1)[0]
|
|
|
|
// Create 10 maintenance entries for the item
|
|
created := make([]MaintenanceEntryCreate, 10)
|
|
|
|
thisMonth := time.Now()
|
|
lastMonth := getPrevMonth(thisMonth)
|
|
|
|
for i := 0; i < 10; i++ {
|
|
dt := lastMonth
|
|
if i%2 == 0 {
|
|
dt = thisMonth
|
|
}
|
|
|
|
created[i] = MaintenanceEntryCreate{
|
|
CompletedDate: types.DateFromTime(dt),
|
|
Name: "Maintenance",
|
|
Description: "Maintenance description",
|
|
Cost: 10,
|
|
}
|
|
}
|
|
|
|
for _, entry := range created {
|
|
_, err := tRepos.MaintEntry.Create(context.Background(), item.ID, entry)
|
|
if err != nil {
|
|
t.Fatalf("failed to create maintenance entry: %v", err)
|
|
}
|
|
}
|
|
|
|
// Get the log for the item
|
|
log, err := tRepos.MaintEntry.GetLog(context.Background(), tGroup.ID, item.ID, MaintenanceLogQuery{
|
|
Completed: true,
|
|
})
|
|
if err != nil {
|
|
t.Fatalf("failed to get maintenance log: %v", err)
|
|
}
|
|
|
|
assert.Equal(t, item.ID, log.ItemID)
|
|
assert.Equal(t, 10, len(log.Entries))
|
|
|
|
// Calculate the average cost
|
|
var total float64
|
|
|
|
for _, entry := range log.Entries {
|
|
total += entry.Cost
|
|
}
|
|
|
|
assert.Equal(t, total, log.CostTotal, "total cost should be equal to the sum of all entries")
|
|
assert.Equal(t, total/2, log.CostAverage, "average cost should be the average of the two months")
|
|
|
|
for _, entry := range log.Entries {
|
|
err := tRepos.MaintEntry.Delete(context.Background(), entry.ID)
|
|
assert.NoError(t, err)
|
|
}
|
|
}
|