Files
indra/pkg/codec/ad/load/load_test.go
2023-09-05 00:47:25 +01:00

63 lines
1.3 KiB
Go

package load
import (
"git.indra-labs.org/dev/ind/pkg/codec"
"git.indra-labs.org/dev/ind/pkg/util/ci"
"testing"
"time"
"git.indra-labs.org/dev/ind/pkg/codec/reg"
"git.indra-labs.org/dev/ind/pkg/crypto"
"git.indra-labs.org/dev/ind/pkg/crypto/nonce"
"git.indra-labs.org/dev/ind/pkg/util/splice"
)
func TestNew(t *testing.T) {
ci.TraceIfNot()
var e error
pr, _, _ := crypto.NewSigner()
id := nonce.NewID()
aa := New(id, pr, 10, time.Now().Add(time.Hour))
s := splice.New(aa.Len())
if e = aa.Encode(s); fails(e) {
t.FailNow()
}
s.SetCursor(0)
var onc codec.Codec
if onc = reg.Recognise(s); onc == nil {
t.Error("did not unwrap")
t.FailNow()
}
if e = onc.Decode(s); fails(e) {
t.Error("did not decode")
t.FailNow()
}
var ad *Ad
var ok bool
if ad, ok = onc.(*Ad); !ok {
t.Error("did not unwrap expected type")
t.FailNow()
}
log.D.S(ad)
if ad.ID != aa.ID {
t.Errorf("ID did not decode correctly")
t.FailNow()
}
if ad.Expiry.Unix() != aa.Expiry.Unix() {
t.Errorf("expiry did not decode correctly")
t.FailNow()
}
if !ad.Key.Equals(crypto.DerivePub(pr)) {
t.Errorf("public key did not decode correctly")
t.FailNow()
}
if ad.Load != aa.Load {
t.Errorf("received ad did not have same load")
t.FailNow()
}
if !ad.Validate() {
t.Errorf("received ad did not validate")
t.FailNow()
}
}