storj/pkg/accounting/rollup/rollup_test.go

87 lines
2.1 KiB
Go
Raw Normal View History

2019-01-24 20:15:10 +00:00
// Copyright (C) 2019 Storj Labs, Inc.
// See LICENSE for copying information.
2019-01-23 19:58:44 +00:00
package rollup_test
import (
"testing"
"time"
"github.com/stretchr/testify/assert"
"go.uber.org/zap"
"storj.io/storj/internal/testcontext"
"storj.io/storj/internal/teststorj"
2019-01-23 19:58:44 +00:00
"storj.io/storj/pkg/accounting/rollup"
"storj.io/storj/pkg/storj"
"storj.io/storj/satellite"
"storj.io/storj/satellite/satellitedb"
)
func TestQueryOneDay(t *testing.T) {
2019-01-23 19:58:44 +00:00
// TODO: use testplanet
ctx, r, db, nodeData, cleanup := createRollup(t)
defer cleanup()
now := time.Now().UTC()
later := now.Add(time.Hour * 24)
2019-01-23 19:58:44 +00:00
err := db.Accounting().SaveAtRestRaw(ctx, now, true, nodeData)
assert.NoError(t, err)
// test should return error because we delete latest day's rollup
err = r.Query(ctx)
assert.NoError(t, err)
2019-01-23 19:58:44 +00:00
rows, err := db.Accounting().QueryPaymentInfo(ctx, now, later)
assert.Equal(t, 0, len(rows))
assert.NoError(t, err)
}
func TestQueryTwoDays(t *testing.T) {
2019-01-23 19:58:44 +00:00
// TODO: use testplanet
ctx, _, db, nodeData, cleanup := createRollup(t)
defer cleanup()
now := time.Now().UTC()
then := now.Add(time.Hour * -24)
2019-01-23 19:58:44 +00:00
err := db.Accounting().SaveAtRestRaw(ctx, now, true, nodeData)
assert.NoError(t, err)
// db.db.Exec("UPDATE accounting_raws SET created_at= WHERE ")
// err = r.Query(ctx)
// assert.NoError(t, err)
2019-01-23 19:58:44 +00:00
_, err = db.Accounting().QueryPaymentInfo(ctx, then, now)
//assert.Equal(t, 10, len(rows))
assert.NoError(t, err)
}
2019-01-23 19:58:44 +00:00
func createRollup(t *testing.T) (*testcontext.Context, *rollup.Rollup, satellite.DB, map[storj.NodeID]float64, func()) {
ctx := testcontext.New(t)
db, err := satellitedb.NewInMemory()
assert.NoError(t, err)
assert.NoError(t, db.CreateTables())
cleanup := func() {
defer ctx.Cleanup()
defer ctx.Check(db.Close)
}
statdb := db.StatDB()
// generate nodeData
nodeData := make(map[storj.NodeID]float64)
for i := 1; i <= 10; i++ {
id := teststorj.NodeIDFromString(string(i))
nodeData[id] = float64(i * 100)
_, err := statdb.Create(ctx, id, nil)
assert.NoError(t, err)
_, err = statdb.Get(ctx, id)
assert.NoError(t, err)
}
2019-01-23 19:58:44 +00:00
return ctx, rollup.New(zap.NewNop(), db.Accounting(), time.Second), db, nodeData, cleanup
}