| // 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/tint/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) |
| } |
| } |