2022-02-03 20:18:00 +01:00
|
|
|
package db_test
|
2021-12-07 02:36:12 +01:00
|
|
|
|
|
|
|
import (
|
2022-01-10 04:09:18 +01:00
|
|
|
"bytes"
|
2021-12-24 13:17:53 +01:00
|
|
|
"encoding/csv"
|
2021-12-11 23:22:45 +01:00
|
|
|
"encoding/hex"
|
|
|
|
"log"
|
2021-12-24 13:17:53 +01:00
|
|
|
"os"
|
2022-02-28 22:09:54 +01:00
|
|
|
"strings"
|
2021-12-07 02:36:12 +01:00
|
|
|
"testing"
|
2021-12-11 23:22:45 +01:00
|
|
|
|
2022-02-03 20:18:00 +01:00
|
|
|
dbpkg "github.com/lbryio/hub/db"
|
2021-12-11 23:22:45 +01:00
|
|
|
"github.com/lbryio/hub/db/prefixes"
|
2022-02-22 13:22:00 +01:00
|
|
|
"github.com/lbryio/lbry.go/v2/extras/util"
|
2021-12-24 13:17:53 +01:00
|
|
|
"github.com/linxGnu/grocksdb"
|
2021-12-07 02:36:12 +01:00
|
|
|
)
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Utility functions for testing
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// OpenAndFillTmpDBColumnFamlies opens a db and fills it with data from a csv file using the given column family names
|
2022-02-18 11:15:00 +01:00
|
|
|
func OpenAndFillTmpDBColumnFamlies(filePath string) (*dbpkg.ReadOnlyDBColumnFamily, [][]string, func(), error) {
|
|
|
|
|
|
|
|
log.Println(filePath)
|
|
|
|
file, err := os.Open(filePath)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
reader := csv.NewReader(file)
|
|
|
|
records, err := reader.ReadAll()
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
wOpts := grocksdb.NewDefaultWriteOptions()
|
|
|
|
opts := grocksdb.NewDefaultOptions()
|
|
|
|
opts.SetCreateIfMissing(true)
|
|
|
|
db, err := grocksdb.OpenDb(opts, "tmp")
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
var handleMap map[string]*grocksdb.ColumnFamilyHandle = make(map[string]*grocksdb.ColumnFamilyHandle)
|
|
|
|
|
2022-02-28 22:09:54 +01:00
|
|
|
// Make sure we always create the TxCounts column family
|
|
|
|
var cfNameRunes string = records[0][0]
|
|
|
|
txCountPrefix := string(prefixes.TxCount)
|
|
|
|
if !strings.Contains(cfNameRunes, txCountPrefix) {
|
|
|
|
cfNameRunes = cfNameRunes + txCountPrefix
|
|
|
|
}
|
|
|
|
for _, cfNameRune := range cfNameRunes {
|
2022-02-18 11:15:00 +01:00
|
|
|
cfName := string(cfNameRune)
|
|
|
|
log.Println(cfName)
|
|
|
|
handle, err := db.CreateColumnFamily(opts, cfName)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
handleMap[cfName] = handle
|
|
|
|
}
|
|
|
|
toDefer := func() {
|
|
|
|
db.Close()
|
|
|
|
err = os.RemoveAll("./tmp")
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for _, record := range records[1:] {
|
|
|
|
cf := record[0]
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
handle := handleMap[string(cf)]
|
|
|
|
key, err := hex.DecodeString(record[1])
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
val, err := hex.DecodeString(record[2])
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
db.PutCF(wOpts, handle, key, val)
|
|
|
|
}
|
|
|
|
|
|
|
|
myDB := &dbpkg.ReadOnlyDBColumnFamily{
|
2022-02-28 22:09:54 +01:00
|
|
|
DB: db,
|
|
|
|
Handles: handleMap,
|
|
|
|
Opts: grocksdb.NewDefaultReadOptions(),
|
|
|
|
BlockedStreams: make(map[string][]byte),
|
|
|
|
BlockedChannels: make(map[string][]byte),
|
|
|
|
FilteredStreams: make(map[string][]byte),
|
|
|
|
FilteredChannels: make(map[string][]byte),
|
|
|
|
TxCounts: nil,
|
|
|
|
LastState: nil,
|
|
|
|
Height: 0,
|
|
|
|
Headers: nil,
|
2022-02-18 11:15:00 +01:00
|
|
|
}
|
|
|
|
|
2022-02-28 22:09:54 +01:00
|
|
|
// err = dbpkg.ReadDBState(myDB) //TODO: Figure out right place for this
|
|
|
|
// if err != nil {
|
|
|
|
// return nil, nil, nil, err
|
|
|
|
// }
|
|
|
|
|
|
|
|
err = dbpkg.InitTxCounts(myDB)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// err = dbpkg.InitHeaders(myDB)
|
|
|
|
// if err != nil {
|
|
|
|
// return nil, nil, nil, err
|
|
|
|
// }
|
|
|
|
|
2022-02-18 11:15:00 +01:00
|
|
|
return myDB, records, toDefer, nil
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// OpenAndFillTmpDBCF opens a db and fills it with data from a csv file
|
|
|
|
// using the given column family handle. Old version, should probably remove.
|
2022-02-03 20:18:00 +01:00
|
|
|
func OpenAndFillTmpDBCF(filePath string) (*grocksdb.DB, [][]string, func(), *grocksdb.ColumnFamilyHandle, error) {
|
2022-01-10 04:09:18 +01:00
|
|
|
|
|
|
|
log.Println(filePath)
|
|
|
|
file, err := os.Open(filePath)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
reader := csv.NewReader(file)
|
|
|
|
records, err := reader.ReadAll()
|
|
|
|
if err != nil {
|
2022-02-03 20:18:00 +01:00
|
|
|
return nil, nil, nil, nil, err
|
2022-01-10 04:09:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
wOpts := grocksdb.NewDefaultWriteOptions()
|
|
|
|
opts := grocksdb.NewDefaultOptions()
|
|
|
|
opts.SetCreateIfMissing(true)
|
|
|
|
db, err := grocksdb.OpenDb(opts, "tmp")
|
2022-02-03 20:18:00 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, nil, err
|
|
|
|
}
|
|
|
|
handle, err := db.CreateColumnFamily(opts, records[0][0])
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, nil, err
|
|
|
|
}
|
|
|
|
toDefer := func() {
|
|
|
|
db.Close()
|
|
|
|
err = os.RemoveAll("./tmp")
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for _, record := range records[1:] {
|
|
|
|
key, err := hex.DecodeString(record[0])
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, nil, err
|
|
|
|
}
|
|
|
|
val, err := hex.DecodeString(record[1])
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, nil, err
|
|
|
|
}
|
|
|
|
db.PutCF(wOpts, handle, key, val)
|
|
|
|
}
|
|
|
|
|
|
|
|
return db, records, toDefer, handle, nil
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// OpenAndFillTmpDB opens a db and fills it with data from a csv file.
|
|
|
|
// Old funciont, should probably remove.
|
2022-02-03 20:18:00 +01:00
|
|
|
func OpenAndFillTmpDB(filePath string) (*grocksdb.DB, [][]string, func(), error) {
|
|
|
|
|
|
|
|
log.Println(filePath)
|
|
|
|
file, err := os.Open(filePath)
|
2022-01-10 04:09:18 +01:00
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
2022-02-03 20:18:00 +01:00
|
|
|
reader := csv.NewReader(file)
|
|
|
|
records, err := reader.ReadAll()
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
wOpts := grocksdb.NewDefaultWriteOptions()
|
|
|
|
opts := grocksdb.NewDefaultOptions()
|
|
|
|
opts.SetCreateIfMissing(true)
|
|
|
|
db, err := grocksdb.OpenDb(opts, "tmp")
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
toDefer := func() {
|
2022-01-10 05:46:52 +01:00
|
|
|
db.Close()
|
|
|
|
err = os.RemoveAll("./tmp")
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
2022-02-03 20:18:00 +01:00
|
|
|
}
|
2022-01-10 04:09:18 +01:00
|
|
|
for _, record := range records {
|
|
|
|
key, err := hex.DecodeString(record[0])
|
|
|
|
if err != nil {
|
2022-02-03 20:18:00 +01:00
|
|
|
return nil, nil, nil, err
|
2022-01-10 04:09:18 +01:00
|
|
|
}
|
|
|
|
val, err := hex.DecodeString(record[1])
|
|
|
|
if err != nil {
|
2022-02-03 20:18:00 +01:00
|
|
|
return nil, nil, nil, err
|
2022-01-10 04:09:18 +01:00
|
|
|
}
|
|
|
|
db.Put(wOpts, key, val)
|
|
|
|
}
|
2022-02-03 20:18:00 +01:00
|
|
|
|
|
|
|
return db, records, toDefer, nil
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// CatCSV Reads a csv version of the db and prints it to stdout,
|
|
|
|
// while decoding types.
|
2022-02-18 11:15:00 +01:00
|
|
|
func CatCSV(filePath string) {
|
|
|
|
log.Println(filePath)
|
|
|
|
file, err := os.Open(filePath)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
reader := csv.NewReader(file)
|
|
|
|
records, err := reader.ReadAll()
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
for _, record := range records[1:] {
|
|
|
|
log.Println(record[1])
|
|
|
|
keyRaw, err := hex.DecodeString(record[1])
|
|
|
|
key, _ := prefixes.UnpackGenericKey(keyRaw)
|
|
|
|
log.Println(key)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
valRaw, err := hex.DecodeString(record[2])
|
|
|
|
// val := prefixes.ClaimTakeoverValueUnpack(valRaw)
|
|
|
|
val, _ := prefixes.UnpackGenericValue(keyRaw, valRaw)
|
|
|
|
log.Println(val)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
func TestCatFullDB(t *testing.T) {
|
2022-02-22 01:21:18 +01:00
|
|
|
t.Skip("Skipping full db test")
|
2022-02-20 14:03:27 +01:00
|
|
|
// url := "lbry://@lothrop#2/lothrop-livestream-games-and-code#c"
|
|
|
|
// "lbry://@lbry", "lbry://@lbry#3", "lbry://@lbry3f", "lbry://@lbry#3fda836a92faaceedfe398225fb9b2ee2ed1f01a", "lbry://@lbry:1", "lbry://@lbry$1"
|
|
|
|
// url := "lbry://@Styxhexenhammer666#2/legacy-media-baron-les-moonves-(cbs#9"
|
|
|
|
// url := "lbry://@lbry"
|
|
|
|
// url := "lbry://@lbry#3fda836a92faaceedfe398225fb9b2ee2ed1f01a"
|
2022-03-07 20:28:36 +01:00
|
|
|
dbPath := "/mnt/sda/wallet_server/_data/lbry-rocksdb/"
|
|
|
|
// dbPath := "/mnt/d/data/snapshot_1072108/lbry-rocksdb/"
|
2022-03-02 16:39:06 +01:00
|
|
|
secondaryPath := "asdf"
|
2022-03-07 21:25:56 +01:00
|
|
|
db, toDefer, err := dbpkg.GetProdDB(dbPath, secondaryPath)
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
defer toDefer()
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
ch := dbpkg.ClaimShortIdIter(db, "@lbry", "")
|
|
|
|
for row := range ch {
|
|
|
|
key := row.Key.(*prefixes.ClaimShortIDKey)
|
|
|
|
val := row.Value.(*prefixes.ClaimShortIDValue)
|
|
|
|
log.Printf("%#v, %#v\n", key, val)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
// End utility functions
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// TestOpenFullDB Tests running a resolve on a full db.
|
2022-02-18 11:15:00 +01:00
|
|
|
func TestOpenFullDB(t *testing.T) {
|
2022-03-07 20:32:27 +01:00
|
|
|
t.Skip("Skipping full db test")
|
2022-02-20 14:03:27 +01:00
|
|
|
// url := "lbry://@lothrop#2/lothrop-livestream-games-and-code#c"
|
|
|
|
// "lbry://@lbry", "lbry://@lbry#3", "lbry://@lbry3f", "lbry://@lbry#3fda836a92faaceedfe398225fb9b2ee2ed1f01a", "lbry://@lbry:1", "lbry://@lbry$1"
|
2022-03-07 20:28:36 +01:00
|
|
|
// url := "lbry://@Styxhexenhammer666#2/legacy-media-baron-les-moonves-(cbs#9"
|
2022-02-20 14:03:27 +01:00
|
|
|
// url := "lbry://@lbry"
|
|
|
|
// url := "lbry://@lbry#3fda836a92faaceedfe398225fb9b2ee2ed1f01a"
|
2022-02-22 01:21:18 +01:00
|
|
|
// url := "lbry://@lbry$1"
|
2022-03-07 21:25:56 +01:00
|
|
|
url := "https://lbry.tv/@lothrop:2/lothrop-livestream-games-and-code:c"
|
2022-03-07 20:28:36 +01:00
|
|
|
dbPath := "/mnt/sda/wallet_server/_data/lbry-rocksdb/"
|
|
|
|
// dbPath := "/mnt/d/data/snapshot_1072108/lbry-rocksdb/"
|
2022-03-02 16:39:06 +01:00
|
|
|
secondaryPath := "asdf"
|
2022-03-07 21:25:56 +01:00
|
|
|
db, toDefer, err := dbpkg.GetProdDB(dbPath, secondaryPath)
|
2022-02-18 11:15:00 +01:00
|
|
|
defer toDefer()
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
expandedResolveResult := dbpkg.Resolve(db, url)
|
2022-02-20 14:03:27 +01:00
|
|
|
log.Printf("expandedResolveResult: %#v\n", expandedResolveResult)
|
2022-02-24 01:43:52 +01:00
|
|
|
log.Printf("expandedResolveResult: %s\n", expandedResolveResult)
|
2022-02-18 11:15:00 +01:00
|
|
|
}
|
|
|
|
|
2022-02-24 01:43:52 +01:00
|
|
|
// TODO: Finish the constructed data set for the stream part of this resolve.
|
2022-02-03 20:18:00 +01:00
|
|
|
func TestResolve(t *testing.T) {
|
2022-02-24 01:43:52 +01:00
|
|
|
url := "lbry://@Styxhexenhammer666#2/legacy-media-baron-les-moonves-(cbs#9"
|
|
|
|
filePath := "../testdata/FULL_resolve.csv"
|
2022-02-18 11:15:00 +01:00
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
2022-02-03 20:18:00 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
defer toDefer()
|
2022-02-24 01:43:52 +01:00
|
|
|
expandedResolveResult := dbpkg.Resolve(db, url)
|
|
|
|
log.Printf("%#v\n", expandedResolveResult)
|
|
|
|
if expandedResolveResult != nil && expandedResolveResult.Channel != nil {
|
|
|
|
log.Println(expandedResolveResult.Channel.GetError())
|
|
|
|
}
|
|
|
|
if expandedResolveResult != nil && expandedResolveResult.Stream != nil {
|
|
|
|
log.Println(expandedResolveResult.Stream.GetError())
|
|
|
|
}
|
2022-02-03 20:18:00 +01:00
|
|
|
}
|
|
|
|
|
2022-02-22 01:21:18 +01:00
|
|
|
func TestGetDBState(t *testing.T) {
|
|
|
|
filePath := "../testdata/s_resolve.csv"
|
|
|
|
want := uint32(1072108)
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
state, err := dbpkg.GetDBState(db)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
log.Printf("state: %#v\n", state)
|
|
|
|
if state.Height != want {
|
|
|
|
t.Errorf("Expected %d, got %d", want, state.Height)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-23 23:26:43 +01:00
|
|
|
func TestGetRepostedClaim(t *testing.T) {
|
|
|
|
channelHash, _ := hex.DecodeString("2556ed1cab9d17f2a9392030a9ad7f5d138f11bd")
|
|
|
|
want := 5
|
|
|
|
// Should be non-existent
|
|
|
|
channelHash2, _ := hex.DecodeString("2556ed1cab9d17f2a9392030a9ad7f5d138f11bf")
|
|
|
|
filePath := "../testdata/W_resolve.csv"
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
|
|
|
|
count, err := dbpkg.GetRepostedCount(db, channelHash)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Println(count)
|
|
|
|
|
|
|
|
if count != want {
|
|
|
|
t.Errorf("Expected %d, got %d", want, count)
|
|
|
|
}
|
|
|
|
|
|
|
|
count2, err := dbpkg.GetRepostedCount(db, channelHash2)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if count2 != 0 {
|
|
|
|
t.Errorf("Expected 0, got %d", count2)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPrintRepost(t *testing.T) {
|
|
|
|
filePath := "../testdata/V_resolve.csv"
|
|
|
|
CatCSV(filePath)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetRepost(t *testing.T) {
|
|
|
|
channelHash, _ := hex.DecodeString("2556ed1cab9d17f2a9392030a9ad7f5d138f11bd")
|
|
|
|
channelHash2, _ := hex.DecodeString("000009ca6e0caaaef16872b4bd4f6f1b8c2363e2")
|
|
|
|
filePath := "../testdata/V_resolve.csv"
|
|
|
|
// want := uint32(3670)
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
|
|
|
|
res, err := dbpkg.GetRepost(db, channelHash)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if !bytes.Equal(res, []byte{}) {
|
|
|
|
t.Errorf("Expected empty, got %#v", res)
|
|
|
|
}
|
|
|
|
|
|
|
|
res2, err := dbpkg.GetRepost(db, channelHash2)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if bytes.Equal(res2, []byte{}) {
|
|
|
|
t.Errorf("Expected non empty, got %#v", res2)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-22 01:21:18 +01:00
|
|
|
func TestPrintChannelCount(t *testing.T) {
|
|
|
|
filePath := "../testdata/Z_resolve.csv"
|
|
|
|
CatCSV(filePath)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetClaimsInChannelCount(t *testing.T) {
|
|
|
|
channelHash, _ := hex.DecodeString("2556ed1cab9d17f2a9392030a9ad7f5d138f11bd")
|
|
|
|
filePath := "../testdata/Z_resolve.csv"
|
|
|
|
want := uint32(3670)
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
count, err := dbpkg.GetClaimsInChannelCount(db, channelHash)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
if count != want {
|
|
|
|
t.Errorf("Expected %d, got %d", want, count)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-18 11:15:00 +01:00
|
|
|
func TestPrintClaimShortId(t *testing.T) {
|
2022-02-24 01:43:52 +01:00
|
|
|
filePath := "../testdata/F_resolve.csv"
|
2022-02-18 11:15:00 +01:00
|
|
|
CatCSV(filePath)
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// TestGetShortClaimIdUrl tests resolving a claim to a short url.
|
|
|
|
func TestGetShortClaimIdUrl(t *testing.T) {
|
2022-02-24 01:43:52 +01:00
|
|
|
name := "@Styxhexenhammer666"
|
|
|
|
normalName := util.NormalizeName(name)
|
|
|
|
claimHash, _ := hex.DecodeString("2556ed1cab9d17f2a9392030a9ad7f5d138f11bd")
|
|
|
|
// claimHash := []byte{}
|
|
|
|
var rootTxNum uint32 = 0x61ec7c
|
2022-02-20 14:03:27 +01:00
|
|
|
var position uint16 = 0
|
2022-02-24 01:43:52 +01:00
|
|
|
filePath := "../testdata/F_resolve.csv"
|
|
|
|
log.Println(filePath)
|
2022-02-20 14:03:27 +01:00
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
shortUrl, err := dbpkg.GetShortClaimIdUrl(db, name, normalName, claimHash, rootTxNum, position)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
log.Println(shortUrl)
|
|
|
|
}
|
|
|
|
|
|
|
|
// TestClaimShortIdIter Tests the function to get an iterator of ClaimShortIds
|
|
|
|
// with a noramlized name and a partial claim id.
|
2022-02-18 11:15:00 +01:00
|
|
|
func TestClaimShortIdIter(t *testing.T) {
|
|
|
|
filePath := "../testdata/F_cat.csv"
|
|
|
|
normalName := "cat"
|
|
|
|
claimId := "0"
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
|
|
|
|
ch := dbpkg.ClaimShortIdIter(db, normalName, claimId)
|
|
|
|
|
|
|
|
for row := range ch {
|
|
|
|
key := row.Key.(*prefixes.ClaimShortIDKey)
|
|
|
|
log.Println(key)
|
|
|
|
if key.NormalizedName != normalName {
|
|
|
|
t.Errorf("Expected %s, got %s", normalName, key.NormalizedName)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// TestPrintTXOToCLaim Utility function to cat the TXOToClaim csv.
|
|
|
|
func TestPrintTXOToClaim(t *testing.T) {
|
|
|
|
filePath := "../testdata/G_2.csv"
|
|
|
|
CatCSV(filePath)
|
|
|
|
}
|
|
|
|
|
|
|
|
// TestGetTXOToClaim Tests getting a claim hash from the db given
|
|
|
|
// a txNum and position.
|
|
|
|
func TestGetTXOToClaim(t *testing.T) {
|
|
|
|
//&{[71] 1456296 0}
|
|
|
|
var txNum uint32 = 1456296
|
|
|
|
var position uint16 = 0
|
|
|
|
filePath := "../testdata/G_2.csv"
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
val, err := dbpkg.GetCachedClaimHash(db, txNum, position)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
} else if val.Name != "one" {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-23 23:26:43 +01:00
|
|
|
func TestGetClaimToChannel(t *testing.T) {
|
|
|
|
streamHashStr := "9a0ed686ecdad9b6cb965c4d6681c02f0bbc66a6"
|
|
|
|
claimHashStr := "2556ed1cab9d17f2a9392030a9ad7f5d138f11bd"
|
|
|
|
claimHash, _ := hex.DecodeString(claimHashStr)
|
|
|
|
streamHash, _ := hex.DecodeString(streamHashStr)
|
|
|
|
|
|
|
|
txNum := uint32(0x6284e3)
|
|
|
|
position := uint16(0x0)
|
|
|
|
|
|
|
|
streamTxNum := uint32(0x369e2b2)
|
|
|
|
streamPosition := uint16(0x0)
|
|
|
|
|
|
|
|
var val []byte = nil
|
|
|
|
|
|
|
|
filePath := "../testdata/I_resolve.csv"
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
|
|
|
|
val, err = dbpkg.GetChannelForClaim(db, claimHash, txNum, position)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
if val != nil {
|
|
|
|
t.Errorf("Expected nil, got %s", hex.EncodeToString(val))
|
|
|
|
}
|
|
|
|
|
|
|
|
val, err = dbpkg.GetChannelForClaim(db, streamHash, streamTxNum, streamPosition)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
valStr := hex.EncodeToString(val)
|
|
|
|
if valStr != claimHashStr {
|
|
|
|
t.Errorf("Expected %s, got %s", claimHashStr, valStr)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-22 19:12:34 +01:00
|
|
|
func TestGetEffectiveAmount(t *testing.T) {
|
|
|
|
filePath := "../testdata/S_resolve.csv"
|
|
|
|
want := uint64(586370959900)
|
2022-02-22 18:12:19 +01:00
|
|
|
claimHashStr := "2556ed1cab9d17f2a9392030a9ad7f5d138f11bd"
|
2022-02-22 19:12:34 +01:00
|
|
|
claimHash, _ := hex.DecodeString(claimHashStr)
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
db.Height = 1116054
|
|
|
|
|
|
|
|
amount, err := dbpkg.GetEffectiveAmount(db, claimHash, true)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if amount != want {
|
|
|
|
t.Errorf("Expected %d, got %d", want, amount)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetSupportAmount(t *testing.T) {
|
2022-02-22 18:12:19 +01:00
|
|
|
want := uint64(8654754160700)
|
2022-02-22 19:12:34 +01:00
|
|
|
claimHashStr := "2556ed1cab9d17f2a9392030a9ad7f5d138f11bd"
|
2022-02-22 18:12:19 +01:00
|
|
|
claimHash, err := hex.DecodeString(claimHashStr)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
filePath := "../testdata/a_resolve.csv"
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
res, err := dbpkg.GetSupportAmount(db, claimHash)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
if res != want {
|
|
|
|
t.Errorf("Expected %d, got %d", want, res)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-22 18:34:23 +01:00
|
|
|
// TODO: verify where this hash comes from exactly.
|
|
|
|
func TestGetTxHash(t *testing.T) {
|
|
|
|
txNum := uint32(0x6284e3)
|
|
|
|
want := "54e14ff0c404c29b3d39ae4d249435f167d5cd4ce5a428ecb745b3df1c8e3dde"
|
|
|
|
|
|
|
|
filePath := "../testdata/X_resolve.csv"
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
resHash, err := dbpkg.GetTxHash(db, txNum)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
resStr := hex.EncodeToString(resHash)
|
|
|
|
if want != resStr {
|
|
|
|
t.Errorf("Expected %s, got %s", want, resStr)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-22 18:02:10 +01:00
|
|
|
func TestGetExpirationHeight(t *testing.T) {
|
|
|
|
var lastUpdated uint32 = 0
|
|
|
|
var expHeight uint32 = 0
|
|
|
|
|
|
|
|
expHeight = dbpkg.GetExpirationHeight(lastUpdated)
|
|
|
|
if lastUpdated+dbpkg.NOriginalClaimExpirationTime != expHeight {
|
|
|
|
t.Errorf("Expected %d, got %d", lastUpdated+dbpkg.NOriginalClaimExpirationTime, expHeight)
|
|
|
|
}
|
|
|
|
|
|
|
|
lastUpdated = dbpkg.NExtendedClaimExpirationForkHeight + 1
|
|
|
|
expHeight = dbpkg.GetExpirationHeight(lastUpdated)
|
|
|
|
if lastUpdated+dbpkg.NExtendedClaimExpirationTime != expHeight {
|
|
|
|
t.Errorf("Expected %d, got %d", lastUpdated+dbpkg.NExtendedClaimExpirationTime, expHeight)
|
|
|
|
}
|
|
|
|
|
|
|
|
lastUpdated = 0
|
|
|
|
expHeight = dbpkg.GetExpirationHeightFull(lastUpdated, true)
|
|
|
|
if lastUpdated+dbpkg.NExtendedClaimExpirationTime != expHeight {
|
|
|
|
t.Errorf("Expected %d, got %d", lastUpdated+dbpkg.NExtendedClaimExpirationTime, expHeight)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetActivation(t *testing.T) {
|
|
|
|
filePath := "../testdata/R_resolve.csv"
|
|
|
|
txNum := uint32(0x6284e3)
|
|
|
|
position := uint16(0x0)
|
|
|
|
want := uint32(0xa6b65)
|
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
defer toDefer()
|
|
|
|
activation, err := dbpkg.GetActivation(db, txNum, position)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
if activation != want {
|
|
|
|
t.Errorf("Expected %d, got %d", want, activation)
|
|
|
|
}
|
|
|
|
log.Printf("activation: %#v\n", activation)
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// TestPrintClaimToTXO Utility function to cat the ClaimToTXO csv.
|
2022-02-18 11:15:00 +01:00
|
|
|
func TestPrintClaimToTXO(t *testing.T) {
|
2022-02-22 13:22:00 +01:00
|
|
|
filePath := "../testdata/E_resolve.csv"
|
2022-02-18 11:15:00 +01:00
|
|
|
CatCSV(filePath)
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// TestGetClaimToTXO Tests getting a ClaimToTXO value from the db.
|
2022-02-18 11:15:00 +01:00
|
|
|
func TestGetClaimToTXO(t *testing.T) {
|
2022-02-22 13:22:00 +01:00
|
|
|
claimHashStr := "2556ed1cab9d17f2a9392030a9ad7f5d138f11bd"
|
|
|
|
want := uint32(0x6284e3)
|
2022-02-18 11:15:00 +01:00
|
|
|
claimHash, err := hex.DecodeString(claimHashStr)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
return
|
|
|
|
}
|
2022-02-22 13:22:00 +01:00
|
|
|
filePath := "../testdata/E_resolve.csv"
|
2022-02-18 11:15:00 +01:00
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
defer toDefer()
|
2022-03-10 19:31:54 +01:00
|
|
|
res, err := dbpkg.GetCachedClaimTxo(db, claimHash, true)
|
2022-02-18 11:15:00 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
return
|
|
|
|
}
|
2022-02-22 13:22:00 +01:00
|
|
|
if res.TxNum != want {
|
|
|
|
t.Errorf("Expected %d, got %d", want, res.TxNum)
|
|
|
|
}
|
|
|
|
log.Printf("res: %#v\n", res)
|
2022-02-18 11:15:00 +01:00
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// TestPrintClaimTakeover Utility function to cat the ClaimTakeover csv.
|
2022-02-18 11:15:00 +01:00
|
|
|
func TestPrintClaimTakeover(t *testing.T) {
|
2022-02-22 13:22:00 +01:00
|
|
|
filePath := "../testdata/P_resolve.csv"
|
2022-02-18 11:15:00 +01:00
|
|
|
CatCSV(filePath)
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// TestGetControlingClaim Tests getting a controlling claim value from the db
|
|
|
|
// based on a name.
|
2022-02-18 11:15:00 +01:00
|
|
|
func TestGetControllingClaim(t *testing.T) {
|
2022-02-22 13:22:00 +01:00
|
|
|
claimName := util.NormalizeName("@Styxhexenhammer666")
|
|
|
|
claimHash := "2556ed1cab9d17f2a9392030a9ad7f5d138f11bd"
|
|
|
|
filePath := "../testdata/P_resolve.csv"
|
2022-02-18 11:15:00 +01:00
|
|
|
db, _, toDefer, err := OpenAndFillTmpDBColumnFamlies(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
defer toDefer()
|
2022-02-22 13:22:00 +01:00
|
|
|
res, err := dbpkg.GetControllingClaim(db, claimName)
|
2022-02-18 11:15:00 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
2022-02-22 13:22:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
got := hex.EncodeToString(res.ClaimHash)
|
|
|
|
if claimHash != got {
|
|
|
|
t.Errorf("Expected %s, got %s", claimHash, got)
|
2022-02-18 11:15:00 +01:00
|
|
|
}
|
|
|
|
log.Println(res)
|
|
|
|
}
|
|
|
|
|
2022-02-20 14:03:27 +01:00
|
|
|
// TestIter Tests the db iterator. Probably needs data format updated.
|
2022-02-03 20:18:00 +01:00
|
|
|
func TestIter(t *testing.T) {
|
|
|
|
|
2022-02-08 18:50:37 +01:00
|
|
|
filePath := "../testdata/W.csv"
|
2022-02-03 20:18:00 +01:00
|
|
|
|
|
|
|
db, records, toDefer, handle, err := OpenAndFillTmpDBCF(filePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
// skip the cf
|
|
|
|
records = records[1:]
|
|
|
|
defer toDefer()
|
2022-01-10 04:09:18 +01:00
|
|
|
// test prefix
|
2022-02-03 20:18:00 +01:00
|
|
|
options := dbpkg.NewIterateOptions().WithPrefix([]byte{prefixes.RepostedClaim}).WithIncludeValue(true)
|
|
|
|
options = options.WithCfHandle(handle)
|
|
|
|
// ch := dbpkg.Iter(db, options)
|
|
|
|
ch := dbpkg.IterCF(db, options)
|
2022-01-10 04:09:18 +01:00
|
|
|
var i = 0
|
|
|
|
for kv := range ch {
|
|
|
|
// log.Println(kv.Key)
|
2022-01-10 05:46:52 +01:00
|
|
|
gotKey := kv.Key.(*prefixes.RepostedKey).PackKey()
|
|
|
|
|
|
|
|
keyPartial3 := prefixes.RepostedKeyPackPartial(kv.Key.(*prefixes.RepostedKey), 3)
|
|
|
|
keyPartial2 := prefixes.RepostedKeyPackPartial(kv.Key.(*prefixes.RepostedKey), 2)
|
|
|
|
keyPartial1 := prefixes.RepostedKeyPackPartial(kv.Key.(*prefixes.RepostedKey), 1)
|
|
|
|
|
|
|
|
// Check pack partial for sanity
|
|
|
|
if !bytes.HasPrefix(gotKey, keyPartial3) {
|
|
|
|
t.Errorf("%+v should be prefix of %+v\n", keyPartial3, gotKey)
|
|
|
|
}
|
|
|
|
if !bytes.HasPrefix(gotKey, keyPartial2) {
|
|
|
|
t.Errorf("%+v should be prefix of %+v\n", keyPartial2, gotKey)
|
|
|
|
}
|
|
|
|
if !bytes.HasPrefix(gotKey, keyPartial1) {
|
|
|
|
t.Errorf("%+v should be prefix of %+v\n", keyPartial1, gotKey)
|
|
|
|
}
|
|
|
|
|
|
|
|
got := kv.Value.(*prefixes.RepostedValue).PackValue()
|
2022-01-10 04:09:18 +01:00
|
|
|
wantKey, err := hex.DecodeString(records[i][0])
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
want, err := hex.DecodeString(records[i][1])
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
if !bytes.Equal(gotKey, wantKey) {
|
|
|
|
t.Errorf("gotKey: %+v, wantKey: %+v\n", got, want)
|
|
|
|
}
|
|
|
|
if !bytes.Equal(got, want) {
|
|
|
|
t.Errorf("got: %+v, want: %+v\n", got, want)
|
|
|
|
}
|
|
|
|
i++
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test start / stop
|
|
|
|
start, err := hex.DecodeString(records[0][0])
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
stop, err := hex.DecodeString(records[9][0])
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
2022-02-03 20:18:00 +01:00
|
|
|
options2 := dbpkg.NewIterateOptions().WithStart(start).WithStop(stop).WithIncludeValue(true)
|
|
|
|
options2 = options2.WithCfHandle(handle)
|
|
|
|
ch2 := dbpkg.IterCF(db, options2)
|
2022-01-10 04:09:18 +01:00
|
|
|
i = 0
|
|
|
|
for kv := range ch2 {
|
2022-01-10 05:46:52 +01:00
|
|
|
got := kv.Value.(*prefixes.RepostedValue).PackValue()
|
2022-01-10 04:09:18 +01:00
|
|
|
want, err := hex.DecodeString(records[i][1])
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
if !bytes.Equal(got, want) {
|
|
|
|
t.Errorf("got: %+v, want: %+v\n", got, want)
|
|
|
|
}
|
|
|
|
i++
|
|
|
|
}
|
2021-12-11 23:22:45 +01:00
|
|
|
}
|