| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- package tests
- import (
- "testing"
- "github.com/modern-go/reflect2"
- "github.com/modern-go/test"
- "github.com/modern-go/test/must"
- "unsafe"
- "github.com/modern-go/test/should"
- "fmt"
- "context"
- )
- func Test_slice_eface(t *testing.T) {
- t.Run("MakeSlice", testOp(func(api reflect2.API) interface{} {
- valType := api.TypeOf([]interface{}{}).(reflect2.SliceType)
- obj := valType.MakeSlice(5, 10)
- obj.([]interface{})[0] = 100
- obj.([]interface{})[4] = 20
- return obj
- }))
- t.Run("SetIndex", testOp(func(api reflect2.API) interface{} {
- obj := []interface{}{1, nil}
- valType := api.TypeOf(obj).(reflect2.SliceType)
- elem0 := interface{}(100)
- valType.SetIndex(obj, 0, &elem0)
- elem1 := interface{}(20)
- valType.SetIndex(obj, 1, &elem1)
- return obj
- }))
- t.Run("UnsafeSetIndex", test.Case(func(ctx context.Context) {
- obj := []interface{}{1, 2}
- valType := reflect2.TypeOf(obj).(reflect2.SliceType)
- var elem0 interface{} = 100
- valType.UnsafeSetIndex(reflect2.PtrOf(obj), 0, unsafe.Pointer(&elem0))
- var elem1 interface{} = 10
- valType.UnsafeSetIndex(reflect2.PtrOf(obj), 1, unsafe.Pointer(&elem1))
- must.Equal([]interface{}{100, 10}, obj)
- }))
- t.Run("GetIndex", testOp(func(api reflect2.API) interface{} {
- obj := []interface{}{1, nil}
- valType := api.TypeOf(obj).(reflect2.SliceType)
- fmt.Println(api, *valType.GetIndex(obj, 0).(*interface{}))
- return []interface{}{
- valType.GetIndex(obj, 0),
- valType.GetIndex(obj, 1),
- }
- }))
- t.Run("UnsafeGetIndex", test.Case(func(ctx context.Context) {
- obj := []interface{}{1, nil}
- valType := reflect2.TypeOf(obj).(reflect2.SliceType)
- elem0 := valType.UnsafeGetIndex(reflect2.PtrOf(obj), 0)
- must.Equal(1, *(*interface{})(elem0))
- }))
- t.Run("Append", testOp(func(api reflect2.API) interface{} {
- obj := make([]interface{}, 2, 3)
- obj[0] = 1
- obj[1] = 2
- valType := api.TypeOf(obj).(reflect2.SliceType)
- valType.Append(&obj, 3)
- // will trigger grow
- valType.Append(&obj, 4)
- return obj
- }))
- t.Run("UnsafeAppend", test.Case(func(ctx context.Context) {
- obj := make([]interface{}, 2, 3)
- obj[0] = 1
- obj[1] = 2
- valType := reflect2.TypeOf(obj).(reflect2.SliceType)
- ptr := reflect2.PtrOf(obj)
- var elem2 interface{} = 3
- valType.UnsafeAppend(ptr, unsafe.Pointer(&elem2))
- var elem3 interface{} = 4
- valType.UnsafeAppend(ptr, unsafe.Pointer(&elem3))
- should.Equal([]interface{}{1, 2, 3, 4}, valType.PackEFace(ptr))
- }))
- }
|