OSDN Git Service

fix commands
[bytom/shuttle.git] / vendor / github.com / bytom / vendor / github.com / stretchr / testify / vendor / github.com / stretchr / objx / codegen / template.txt
diff --git a/vendor/github.com/bytom/vendor/github.com/stretchr/testify/vendor/github.com/stretchr/objx/codegen/template.txt b/vendor/github.com/bytom/vendor/github.com/stretchr/testify/vendor/github.com/stretchr/objx/codegen/template.txt
new file mode 100644 (file)
index 0000000..b396900
--- /dev/null
@@ -0,0 +1,286 @@
+/*
+       {4} ({1} and []{1})
+       --------------------------------------------------
+*/
+
+// {4} gets the value as a {1}, returns the optionalDefault
+// value or a system default object if the value is the wrong type.
+func (v *Value) {4}(optionalDefault ...{1}) {1} {
+       if s, ok := v.data.({1}); ok {
+               return s
+       }
+       if len(optionalDefault) == 1 {
+               return optionalDefault[0]
+       }
+       return {3}
+}
+
+// Must{4} gets the value as a {1}.
+//
+// Panics if the object is not a {1}.
+func (v *Value) Must{4}() {1} {
+       return v.data.({1})
+}
+
+// {4}Slice gets the value as a []{1}, returns the optionalDefault
+// value or nil if the value is not a []{1}.
+func (v *Value) {4}Slice(optionalDefault ...[]{1}) []{1} {
+       if s, ok := v.data.([]{1}); ok {
+               return s
+       }
+       if len(optionalDefault) == 1 {
+               return optionalDefault[0]
+       }
+       return nil
+}
+
+// Must{4}Slice gets the value as a []{1}.
+//
+// Panics if the object is not a []{1}.
+func (v *Value) Must{4}Slice() []{1} {
+       return v.data.([]{1})
+}
+
+// Is{4} gets whether the object contained is a {1} or not.
+func (v *Value) Is{4}() bool {
+  _, ok := v.data.({1})
+  return ok
+}
+
+// Is{4}Slice gets whether the object contained is a []{1} or not.
+func (v *Value) Is{4}Slice() bool {
+       _, ok := v.data.([]{1})
+       return ok
+}
+
+// Each{4} calls the specified callback for each object
+// in the []{1}.
+//
+// Panics if the object is the wrong type.
+func (v *Value) Each{4}(callback func(int, {1}) bool) *Value {
+
+       for index, val := range v.Must{4}Slice() {
+               carryon := callback(index, val)
+               if carryon == false {
+                       break
+               }
+       }
+
+       return v
+
+}
+
+// Where{4} uses the specified decider function to select items
+// from the []{1}.  The object contained in the result will contain
+// only the selected items.
+func (v *Value) Where{4}(decider func(int, {1}) bool) *Value {
+
+       var selected []{1}
+
+       v.Each{4}(func(index int, val {1}) bool {
+               shouldSelect := decider(index, val)
+               if shouldSelect == false {
+                       selected = append(selected, val)
+               }
+               return true
+       })
+
+       return &Value{data:selected}
+
+}
+
+// Group{4} uses the specified grouper function to group the items
+// keyed by the return of the grouper.  The object contained in the
+// result will contain a map[string][]{1}.
+func (v *Value) Group{4}(grouper func(int, {1}) string) *Value {
+
+       groups := make(map[string][]{1})
+
+       v.Each{4}(func(index int, val {1}) bool {
+               group := grouper(index, val)
+               if _, ok := groups[group]; !ok {
+                       groups[group] = make([]{1}, 0)
+               }
+               groups[group] = append(groups[group], val)
+               return true
+       })
+
+       return &Value{data:groups}
+
+}
+
+// Replace{4} uses the specified function to replace each {1}s
+// by iterating each item.  The data in the returned result will be a
+// []{1} containing the replaced items.
+func (v *Value) Replace{4}(replacer func(int, {1}) {1}) *Value {
+
+       arr := v.Must{4}Slice()
+       replaced := make([]{1}, len(arr))
+
+       v.Each{4}(func(index int, val {1}) bool {
+               replaced[index] = replacer(index, val)
+               return true
+       })
+
+       return &Value{data:replaced}
+
+}
+
+// Collect{4} uses the specified collector function to collect a value
+// for each of the {1}s in the slice.  The data returned will be a
+// []interface{}.
+func (v *Value) Collect{4}(collector func(int, {1}) interface{}) *Value {
+
+       arr := v.Must{4}Slice()
+       collected := make([]interface{}, len(arr))
+
+       v.Each{4}(func(index int, val {1}) bool {
+               collected[index] = collector(index, val)
+               return true
+       })
+
+       return &Value{data:collected}
+}
+
+// ************************************************************
+// TESTS
+// ************************************************************
+
+func Test{4}(t *testing.T) {
+
+  val := {1}( {2} )
+       m := map[string]interface{}{"value": val, "nothing": nil}
+       assert.Equal(t, val, New(m).Get("value").{4}())
+       assert.Equal(t, val, New(m).Get("value").Must{4}())
+       assert.Equal(t, {1}({3}), New(m).Get("nothing").{4}())
+       assert.Equal(t, val, New(m).Get("nothing").{4}({2}))
+
+       assert.Panics(t, func() {
+               New(m).Get("age").Must{4}()
+       })
+
+}
+
+func Test{4}Slice(t *testing.T) {
+
+  val := {1}( {2} )
+       m := map[string]interface{}{"value": []{1}{ val }, "nothing": nil}
+       assert.Equal(t, val, New(m).Get("value").{4}Slice()[0])
+       assert.Equal(t, val, New(m).Get("value").Must{4}Slice()[0])
+       assert.Equal(t, []{1}(nil), New(m).Get("nothing").{4}Slice())
+       assert.Equal(t, val, New(m).Get("nothing").{4}Slice( []{1}{ {1}({2}) } )[0])
+
+       assert.Panics(t, func() {
+               New(m).Get("nothing").Must{4}Slice()
+       })
+
+}
+
+func TestIs{4}(t *testing.T) {
+
+       var v *Value
+
+       v = &Value{data: {1}({2})}
+       assert.True(t, v.Is{4}())
+
+       v = &Value{data: []{1}{ {1}({2}) }}
+       assert.True(t, v.Is{4}Slice())
+
+}
+
+func TestEach{4}(t *testing.T) {
+
+       v := &Value{data: []{1}{ {1}({2}), {1}({2}), {1}({2}), {1}({2}), {1}({2}) }}
+       count := 0
+       replacedVals := make([]{1}, 0)
+       assert.Equal(t, v, v.Each{4}(func(i int, val {1}) bool {
+
+               count++
+               replacedVals = append(replacedVals, val)
+
+               // abort early
+               if i == 2 {
+                       return false
+               }
+
+               return true
+
+       }))
+
+       assert.Equal(t, count, 3)
+       assert.Equal(t, replacedVals[0], v.Must{4}Slice()[0])
+       assert.Equal(t, replacedVals[1], v.Must{4}Slice()[1])
+       assert.Equal(t, replacedVals[2], v.Must{4}Slice()[2])
+
+}
+
+func TestWhere{4}(t *testing.T) {
+
+       v := &Value{data: []{1}{ {1}({2}), {1}({2}), {1}({2}), {1}({2}), {1}({2}), {1}({2}) }}
+
+       selected := v.Where{4}(func(i int, val {1}) bool {
+               return i%2==0
+       }).Must{4}Slice()
+
+       assert.Equal(t, 3, len(selected))
+
+}
+
+func TestGroup{4}(t *testing.T) {
+
+       v := &Value{data: []{1}{ {1}({2}), {1}({2}), {1}({2}), {1}({2}), {1}({2}), {1}({2}) }}
+
+       grouped := v.Group{4}(func(i int, val {1}) string {
+               return fmt.Sprintf("%v", i%2==0)
+       }).data.(map[string][]{1})
+
+       assert.Equal(t, 2, len(grouped))
+       assert.Equal(t, 3, len(grouped["true"]))
+       assert.Equal(t, 3, len(grouped["false"]))
+
+}
+
+func TestReplace{4}(t *testing.T) {
+
+       v := &Value{data: []{1}{ {1}({2}), {1}({2}), {1}({2}), {1}({2}), {1}({2}), {1}({2}) }}
+
+       rawArr := v.Must{4}Slice()
+
+       replaced := v.Replace{4}(func(index int, val {1}) {1} {
+               if index < len(rawArr)-1 {
+                       return rawArr[index+1]
+               }
+               return rawArr[0]
+       })
+
+       replacedArr := replaced.Must{4}Slice()
+       if assert.Equal(t, 6, len(replacedArr)) {
+               assert.Equal(t, replacedArr[0], rawArr[1])
+               assert.Equal(t, replacedArr[1], rawArr[2])
+               assert.Equal(t, replacedArr[2], rawArr[3])
+               assert.Equal(t, replacedArr[3], rawArr[4])
+               assert.Equal(t, replacedArr[4], rawArr[5])
+               assert.Equal(t, replacedArr[5], rawArr[0])
+       }
+
+}
+
+func TestCollect{4}(t *testing.T) {
+
+       v := &Value{data: []{1}{ {1}({2}), {1}({2}), {1}({2}), {1}({2}), {1}({2}), {1}({2}) }}
+
+       collected := v.Collect{4}(func(index int, val {1}) interface{} {
+               return index
+       })
+
+       collectedArr := collected.MustInterSlice()
+       if assert.Equal(t, 6, len(collectedArr)) {
+               assert.Equal(t, collectedArr[0], 0)
+               assert.Equal(t, collectedArr[1], 1)
+               assert.Equal(t, collectedArr[2], 2)
+               assert.Equal(t, collectedArr[3], 3)
+               assert.Equal(t, collectedArr[4], 4)
+               assert.Equal(t, collectedArr[5], 5)
+       }
+
+}