This repository has been archived on 2022-11-27. You can view files and clone it, but cannot push or open issues or pull requests.
activitypub/collection_page_test.go

227 lines
5.8 KiB
Go

package activitypub
import (
"reflect"
"testing"
)
func TestCollectionPageNew(t *testing.T) {
var testValue = ID("test")
c := CollectionNew(testValue)
p := CollectionPageNew(c)
if reflect.DeepEqual(p.Collection, c) {
t.Errorf("Invalid collection parent '%v'", p.PartOf)
}
if p.PartOf != c.GetLink() {
t.Errorf("Invalid collection '%v'", p.PartOf)
}
}
func TestCollectionPage_Append(t *testing.T) {
id := ID("test")
val := Object{ID: ID("grrr")}
c := CollectionNew(id)
p := CollectionPageNew(c)
p.Append(val)
if p.PartOf != c.GetLink() {
t.Errorf("Collection page should point to collection %q", c.GetLink())
}
if p.Count() != 1 {
t.Errorf("Collection page of %q should have exactly one element", p.GetID())
}
if !reflect.DeepEqual(p.Items[0], val) {
t.Errorf("First item in Inbox is does not match %q", val.ID)
}
}
func TestCollectionPage_UnmarshalJSON(t *testing.T) {
p := CollectionPage{}
dataEmpty := []byte("{}")
p.UnmarshalJSON(dataEmpty)
if p.ID != "" {
t.Errorf("Unmarshaled object should have empty ID, received %q", p.ID)
}
if p.Type != "" {
t.Errorf("Unmarshaled object should have empty Type, received %q", p.Type)
}
if p.AttributedTo != nil {
t.Errorf("Unmarshaled object should have empty AttributedTo, received %q", p.AttributedTo)
}
if len(p.Name) != 0 {
t.Errorf("Unmarshaled object should have empty Name, received %q", p.Name)
}
if len(p.Summary) != 0 {
t.Errorf("Unmarshaled object should have empty Summary, received %q", p.Summary)
}
if len(p.Content) != 0 {
t.Errorf("Unmarshaled object should have empty Content, received %q", p.Content)
}
if p.TotalItems != 0 {
t.Errorf("Unmarshaled object should have empty TotalItems, received %d", p.TotalItems)
}
if len(p.Items) > 0 {
t.Errorf("Unmarshaled object should have empty Items, received %v", p.Items)
}
if p.URL != nil {
t.Errorf("Unmarshaled object should have empty URL, received %v", p.URL)
}
if !p.Published.IsZero() {
t.Errorf("Unmarshaled object should have empty Published, received %q", p.Published)
}
if !p.StartTime.IsZero() {
t.Errorf("Unmarshaled object should have empty StartTime, received %q", p.StartTime)
}
if !p.Updated.IsZero() {
t.Errorf("Unmarshaled object should have empty Updated, received %q", p.Updated)
}
if p.PartOf != nil {
t.Errorf("Unmarshaled object should have empty PartOf, received %q", p.PartOf)
}
if p.Current != nil {
t.Errorf("Unmarshaled object should have empty Current, received %q", p.Current)
}
if p.First != nil {
t.Errorf("Unmarshaled object should have empty First, received %q", p.First)
}
if p.Last != nil {
t.Errorf("Unmarshaled object should have empty Last, received %q", p.Last)
}
if p.Next != nil {
t.Errorf("Unmarshaled object should have empty Next, received %q", p.Next)
}
if p.Prev != nil {
t.Errorf("Unmarshaled object should have empty Prev, received %q", p.Prev)
}
}
func TestCollectionPage_Collection(t *testing.T) {
id := ID("test")
c := CollectionNew(id)
p := CollectionPageNew(c)
if !reflect.DeepEqual(p.Collection(), p.Items) {
t.Errorf("Collection items should be equal %v %v", p.Collection(), p.Items)
}
}
func TestCollectionPage_Count(t *testing.T) {
id := ID("test")
c := CollectionNew(id)
p := CollectionPageNew(c)
if p.TotalItems != 0 {
t.Errorf("Empty object should have empty TotalItems, received %d", p.TotalItems)
}
if len(p.Items) > 0 {
t.Errorf("Empty object should have empty Items, received %v", p.Items)
}
if p.Count() != uint(len(p.Items)) {
t.Errorf("%T.Count() returned %d, expected %d", c, p.Count(), len(p.Items))
}
p.Append(IRI("test"))
if p.TotalItems != 0 {
t.Errorf("Empty object should have empty TotalItems, received %d", p.TotalItems)
}
if p.Count() != uint(len(p.Items)) {
t.Errorf("%T.Count() returned %d, expected %d", c, p.Count(), len(p.Items))
}
}
func TestToCollectionPage(t *testing.T) {
err := func(it Item) error { return ErrorInvalidType[CollectionPage](it) }
tests := map[string]struct {
it Item
want *CollectionPage
wantErr error
}{
"CollectionPage": {
it: new(CollectionPage),
want: new(CollectionPage),
wantErr: nil,
},
"OrderedCollectionPage": {
it: new(OrderedCollectionPage),
want: new(CollectionPage),
wantErr: err(new(OrderedCollectionPage)),
},
"OrderedCollection": {
it: new(OrderedCollection),
want: new(CollectionPage),
wantErr: err(new(OrderedCollection)),
},
"Collection": {
it: new(Collection),
want: new(CollectionPage),
wantErr: err(new(Collection)),
},
}
for name, tt := range tests {
t.Run(name, func(t *testing.T) {
got, err := ToCollectionPage(tt.it)
if tt.wantErr != nil && err == nil {
t.Errorf("ToCollectionPage() no error returned, wanted error = [%T]%s", tt.wantErr, tt.wantErr)
return
}
if err != nil {
if tt.wantErr == nil {
t.Errorf("ToCollectionPage() returned unexpected error[%T]%s", err, err)
return
}
if !reflect.DeepEqual(err, tt.wantErr) {
t.Errorf("ToCollectionPage() received error %v, wanted error %v", err, tt.wantErr)
return
}
return
}
if !reflect.DeepEqual(got, tt.want) {
t.Errorf("ToCollectionPage() got %v, want %v", got, tt.want)
}
})
}
}
func TestCollectionPage_Contains(t *testing.T) {
t.Skipf("TODO")
}
func TestCollectionPage_GetID(t *testing.T) {
t.Skipf("TODO")
}
func TestCollectionPage_GetLink(t *testing.T) {
t.Skipf("TODO")
}
func TestCollectionPage_GetType(t *testing.T) {
t.Skipf("TODO")
}
func TestCollectionPage_IsCollection(t *testing.T) {
t.Skipf("TODO")
}
func TestCollectionPage_IsLink(t *testing.T) {
t.Skipf("TODO")
}
func TestCollectionPage_IsObject(t *testing.T) {
t.Skipf("TODO")
}
func TestCollectionPage_MarshalJSON(t *testing.T) {
t.Skipf("TODO")
}
func TestCollectionPage_ItemMatches(t *testing.T) {
t.Skipf("TODO")
}