7802ab714f
Initially there were pkg and private packages, however for all practical purposes there's no significant difference between them. It's clearer to have a single private package - and when we do get a specific abstraction that needs to be reused, we can move it to storj.io/common or storj.io/private. Change-Id: Ibc2036e67f312f5d63cb4a97f5a92e38ae413aa5
49 lines
1.2 KiB
Go
49 lines
1.2 KiB
Go
// Copyright (C) 2019 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package testrevocation
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"storj.io/common/peertls/extensions"
|
|
"storj.io/common/testcontext"
|
|
"storj.io/storj/private/revocation"
|
|
"storj.io/storj/private/testredis"
|
|
"storj.io/storj/storage"
|
|
)
|
|
|
|
// RunDBs runs the passed test function with each type of revocation database.
|
|
func RunDBs(t *testing.T, test func(*testing.T, extensions.RevocationDB, storage.KeyValueStore)) {
|
|
t.Run("Redis", func(t *testing.T) {
|
|
ctx := testcontext.New(t)
|
|
defer ctx.Cleanup()
|
|
|
|
redis, err := testredis.Mini(ctx)
|
|
require.NoError(t, err)
|
|
defer ctx.Check(redis.Close)
|
|
|
|
// Test using redis-backed revocation DB
|
|
dbURL := "redis://" + redis.Addr() + "?db=0"
|
|
db, err := revocation.OpenDB(ctx, dbURL)
|
|
require.NoError(t, err)
|
|
defer ctx.Check(db.Close)
|
|
|
|
test(t, db, db.TestGetStore())
|
|
})
|
|
|
|
t.Run("Bolt", func(t *testing.T) {
|
|
ctx := testcontext.New(t)
|
|
defer ctx.Cleanup()
|
|
|
|
// Test using bolt-backed revocation DB
|
|
db, err := revocation.OpenDB(ctx, "bolt://"+ctx.File("revocations.db"))
|
|
require.NoError(t, err)
|
|
defer ctx.Check(db.Close)
|
|
|
|
test(t, db, db.TestGetStore())
|
|
})
|
|
}
|