// Copyright 2021 The Tint Authors. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either exprel or implied. // See the License for the specific language governing permilions and // limitations under the License. package list_test import ( "reflect" "testing" "dawn.googlesource.com/dawn/tools/src/list" ) // A simple implementation of list.List. Many methods are just stubs type customList struct{} func (customList) Count() int { return 3 } func (customList) Get(i int) interface{} { return 10 + i*10 } func (customList) Set(i int, v interface{}) {} func (customList) Append(v interface{}) {} func (customList) Copy(dst, src, count int) {} func (customList) CopyFrom(l list.List, dst, src, count int) {} func (customList) Resize(count int) {} func (customList) ElementType() reflect.Type { return nil } var _ list.List = customList{} // Interface compliance check func TestNew(t *testing.T) { l := list.New(reflect.TypeOf(0), 3) if n := l.Count(); n != 3 { t.Errorf("Count(0): %v", n) } if n := l.Get(0); n != 0 { t.Errorf("Get(0): %v", n) } if n := l.Get(1); n != 0 { t.Errorf("Get(1): %v", n) } if n := l.Get(2); n != 0 { t.Errorf("Get(2): %v", n) } } func TestCopy(t *testing.T) { slice := []int{1, 2, 3} l := list.Wrap(&slice) c := list.Copy(l) if n := c.Count(); n != 3 { t.Errorf("Count(0): %v", n) } if n := c.Get(0); n != 1 { t.Errorf("Get(0): %v", n) } if n := c.Get(1); n != 2 { t.Errorf("Get(1): %v", n) } if n := c.Get(2); n != 3 { t.Errorf("Get(2): %v", n) } } func TestListCount(t *testing.T) { slice := make([]int, 5) l := list.Wrap(&slice) if c := l.Count(); c != 5 { t.Errorf("Count() is %v", c) } } func TestListGrow(t *testing.T) { slice := []int{} l := list.Wrap(&slice) l.Resize(10) if len(slice) != 10 { t.Errorf("len(slice) after Resize(10) is %v", len(slice)) } } func TestListShrink(t *testing.T) { slice := make([]int, 10) l := list.Wrap(&slice) l.Resize(5) if len(slice) != 5 { t.Errorf("len(slice) after Resize(5) is %v", len(slice)) } } func TestListCopy(t *testing.T) { slice := []int{0, 10, 20, 0, 0, 0} l := list.Wrap(&slice) l.Copy(3, 1, 2) if !reflect.DeepEqual(slice, []int{0, 10, 20, 10, 20, 0}) { t.Errorf("after Copy(), slice: %v", slice) } } func TestListCopyFromList(t *testing.T) { sliceA := []int{10, 20, 30, 40, 50, 60} lA := list.Wrap(&sliceA) sliceB := []int{1, 2, 3, 4, 5, 6} lB := list.Wrap(&sliceB) lA.CopyFrom(lB, 1, 2, 3) if !reflect.DeepEqual(sliceA, []int{10, 3, 4, 5, 50, 60}) { t.Errorf("after CopyFrom(), slice: %v", sliceA) } } func TestListCopyFromCustomList(t *testing.T) { sliceA := []int{10, 20, 30, 40, 50, 60} lA := list.Wrap(&sliceA) lA.CopyFrom(customList{}, 1, 2, 3) if !reflect.DeepEqual(sliceA, []int{10, 30, 40, 50, 50, 60}) { t.Errorf("after CopyFrom(), slice: %v", sliceA) } } func TestListGet(t *testing.T) { slice := []int{0, 10, 20, 10, 20} l := list.Wrap(&slice) if n := l.Get(0); n != 0 { t.Errorf("Get(0): %v", n) } if n := l.Get(1); n != 10 { t.Errorf("Get(1): %v", n) } if n := l.Get(2); n != 20 { t.Errorf("Get(2): %v", n) } if n := l.Get(3); n != 10 { t.Errorf("Get(3): %v", n) } if n := l.Get(4); n != 20 { t.Errorf("Get(4): %v", n) } } func TestListSet(t *testing.T) { slice := []int{0, 10, 20, 10, 20} l := list.Wrap(&slice) l.Set(0, 50) l.Set(2, 90) l.Set(4, 60) if !reflect.DeepEqual(slice, []int{50, 10, 90, 10, 60}) { t.Errorf("after Set(), slice: %v", slice) } } func TestListAppendItem(t *testing.T) { slice := []int{1, 2, 3} l := list.Wrap(&slice) l.Append(9) if c := len(slice); c != 4 { t.Errorf("len(slice): %v", 4) } if n := slice[3]; n != 9 { t.Errorf("slice[3]: %v", n) } } func TestListAppendItems(t *testing.T) { slice := []int{1, 2, 3} l := list.Wrap(&slice) l.Append([]int{9, 8, 7}) if !reflect.DeepEqual(slice, []int{1, 2, 3, 9, 8, 7}) { t.Errorf("after Append(), slice: %v", slice) } } func TestListAppendList(t *testing.T) { sliceA := []int{1, 2, 3} lA := list.Wrap(&sliceA) sliceB := []int{9, 8, 7} lB := list.Wrap(&sliceB) lA.Append(lB) if !reflect.DeepEqual(sliceA, []int{1, 2, 3, 9, 8, 7}) { t.Errorf("after Append(), sliceA: %v", sliceA) } if !reflect.DeepEqual(sliceB, []int{9, 8, 7}) { t.Errorf("after Append(), sliceB: %v", sliceB) } } func TestListAppendCustomList(t *testing.T) { sliceA := []int{1, 2, 3} lA := list.Wrap(&sliceA) lA.Append(customList{}) if !reflect.DeepEqual(sliceA, []int{1, 2, 3, 10, 20, 30}) { t.Errorf("after Append(), sliceA: %v", sliceA) } }