testutil

package
v0.29.6 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 26, 2023 License: Apache-2.0 Imports: 11 Imported by: 3

Documentation

Overview

Package testutil contains a set of utilities that are useful within tests of ygot-related data.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func GenerateUnifiedDiff

func GenerateUnifiedDiff(want, got string) (string, error)

GenerateUnifiedDiff takes two strings and generates a diff that can be shown to the user in a test error message.

func GetResponseEqual

func GetResponseEqual(a, b *gnmipb.GetResponse, opts ...ComparerOpt) bool

GetResponseEqual compares the contents of a and b and returns true if they are equal. Extensions in the GetResponse are ignored. The supplied ComparerOpt options are used to influnce the equality comparison between a and b.

func JSONIETFComparer

func JSONIETFComparer(a, b []byte) bool

JSONIETFComparer compares the two provided JSON IETF TypedValues to determine whether their contents are the same. If either value is invalid JSON, the function returns false.

func NotificationComparer added in v0.29.0

func NotificationComparer() cmp.Option

NotificationComparer returns a cmp.Option that can be used to compare two gnmipb.Notification messages where the order of updates and deletes are not significant.

func NotificationLess

func NotificationLess(a, b *gnmipb.Notification) bool

NotificationLess compares the two notifications a and b, returning true if a is less than b, and false if not. Less is defined by:

  • Comparing the timestamp.
  • If equal timestamps, comparing the prefix using PathLess.
  • If equal prefixes, comparing the Updates using UpdateLess.
  • If equal updates, comparing the Deletes using deleteLess.

If all fields are equal, the function returns false to ensure that the irreflexive property required by cmpopts.SortSlices is implemented.

func NotificationSetEqual

func NotificationSetEqual(a, b []*gnmipb.Notification, opts ...ComparerOpt) bool

NotificationSetEqual compares the contents of a and b and returns true if they are equal. Order of the slices is ignored. The set of ComparerOpts supplied are used to influnce the equality comparison between members of a and b.

func PathLess

func PathLess(a, b *gnmipb.Path) bool

PathLess provides a function which determines whether a gNMI Path messages A is less than the gNMI Path message b. It can be used to allow sorting of gNMI path messages - for example, in cmpopts.SortSlices.

func SubscribeResponseEqual

func SubscribeResponseEqual(a, b *gnmipb.SubscribeResponse) bool

SubscribeResponseEqual compares the contents of a and b and returns true if they are equal. Extensions in the SubscribeResponse are ignored.

func SubscribeResponseSetEqual

func SubscribeResponseSetEqual(a, b []*gnmipb.SubscribeResponse) bool

SubscribeResponseSetEqual compares the contents of the slices of SubscribeResponse messages in a and b and returns true if they are equal. Order of the slices is ignored.

func UpdateLess

func UpdateLess(a, b *gnmipb.Update) bool

UpdateLess compares two gNMI Update messages and returns true if a < b. The less-than comparison is done by first comparing the paths of the updates, and subquently comparing the typedValue fields of the updates, followed by the duplicates fields. If all fields are equal, returns false.

func UpdateSetEqual

func UpdateSetEqual(a, b []*gnmipb.Update) bool

UpdateSetEqual compares the contents of a and b and returns true if they are equal. Order of the slices is ignored.

Types

type Binary added in v0.8.8

type Binary []byte

Binary is a type that is used for fields that have a YANG type of binary. It is used such that binary fields can be distinguished from leaf-lists of uint8s (which are mapped to []uint8, equivalent to []byte in reflection).

func (Binary) IsExampleUnion added in v0.8.8

func (Binary) IsExampleUnion()

func (Binary) IsTestUnion added in v0.8.8

func (Binary) IsTestUnion()

func (Binary) IsTestUnion2 added in v0.8.8

func (Binary) IsTestUnion2()

func (Binary) IsUnion added in v0.8.8

func (Binary) IsUnion()

func (Binary) Is_UnionLeafTypeSimple added in v0.8.8

func (Binary) Is_UnionLeafTypeSimple()

type ComparerOpt

type ComparerOpt interface {
	IsComparerOpt()
}

ComparerOpt is an interface that all comparison options must implement.

type CustomComparer

type CustomComparer map[reflect.Type]cmp.Option

CustomComparer allows for a comparer for a particular type to be overloaded such that an external caller can inject a new way to compare a specific field of a gNMI message. It is a map, keyed by a reflect.Type of the message field, with a value of a cmp.Option produced by cmp.Comparer(). NOTE: Proto comparison is done through protocmp -- this means any custom comparison of a proto field can only be done by supplying a protocmp-created cmp.Option.

func (CustomComparer) IsComparerOpt

func (CustomComparer) IsComparerOpt()

IsComparerOpt marks CustomComparer as a ComparerOpt.

type IgnoreTimestamp

type IgnoreTimestamp struct{}

IgnoreTimestamp is a comparison option that ignores timestamp values in gNMI messages.

func (IgnoreTimestamp) IsComparerOpt

func (IgnoreTimestamp) IsComparerOpt()

IsComparerOpt marks IgnoreTimestamp as a ComparerOpt.

type TestUnion added in v0.8.8

type TestUnion interface {
	IsTestUnion()
}

TestUnion is an interface defined within *this* (testutil) package that is satisfied by a subset of the above union types to aid testing within other packages. Enumerations defined within other test packages can still satisfy this interface by defining an IsTestUnion() method.

type TestUnion2 added in v0.8.8

type TestUnion2 interface {
	IsTestUnion2()
}

type UnionBool added in v0.8.8

type UnionBool bool

UnionBool is a bool type assignable to unions of which it is a subtype.

func (UnionBool) IsExampleUnion added in v0.8.8

func (UnionBool) IsExampleUnion()

func (UnionBool) IsTestUnion2 added in v0.8.8

func (UnionBool) IsTestUnion2()

type UnionFloat64 added in v0.8.8

type UnionFloat64 float64

UnionFloat64 is a float64 type assignable to unions of which it is a subtype.

func (UnionFloat64) IsExampleUnion added in v0.8.8

func (UnionFloat64) IsExampleUnion()

type UnionInt16 added in v0.8.8

type UnionInt16 int16

UnionInt16 is an int16 type assignable to unions of which it is a subtype.

func (UnionInt16) IsTestUnion added in v0.8.8

func (UnionInt16) IsTestUnion()

func (UnionInt16) IsTestUnion2 added in v0.8.8

func (UnionInt16) IsTestUnion2()

type UnionInt32 added in v0.8.8

type UnionInt32 int32

UnionInt32 is an int32 type assignable to unions of which it is a subtype.

type UnionInt64 added in v0.8.8

type UnionInt64 int64

UnionInt64 is an int64 type assignable to unions of which it is a subtype.

func (UnionInt64) IsExampleUnion added in v0.8.8

func (UnionInt64) IsExampleUnion()

func (UnionInt64) IsTestUnion added in v0.8.8

func (UnionInt64) IsTestUnion()

func (UnionInt64) IsTestUnion2 added in v0.8.8

func (UnionInt64) IsTestUnion2()

func (UnionInt64) IsUnion added in v0.8.8

func (UnionInt64) IsUnion()

type UnionInt8 added in v0.8.8

type UnionInt8 int8

UnionInt8 is an int8 type assignable to unions of which it is a subtype.

type UnionString added in v0.8.8

type UnionString string

UnionString is a string type assignable to unions of which it is a subtype.

func (UnionString) IsExampleUnion added in v0.8.8

func (UnionString) IsExampleUnion()

func (UnionString) IsTestUnion added in v0.8.8

func (UnionString) IsTestUnion()

func (UnionString) IsUnion added in v0.8.8

func (UnionString) IsUnion()

func (UnionString) Is_UnionLeafTypeSimple added in v0.8.8

func (UnionString) Is_UnionLeafTypeSimple()

type UnionUint16 added in v0.8.8

type UnionUint16 uint16

UnionUint16 is a uint16 type assignable to unions of which it is a subtype.

type UnionUint32 added in v0.8.8

type UnionUint32 uint32

UnionUint32 is a uint32 type assignable to unions of which it is a subtype.

func (UnionUint32) Is_UnionLeafTypeSimple added in v0.8.8

func (UnionUint32) Is_UnionLeafTypeSimple()

type UnionUint64 added in v0.8.8

type UnionUint64 uint64

UnionUint64 is a uint64 type assignable to unions of which it is a subtype.

type UnionUint8 added in v0.8.8

type UnionUint8 uint8

UnionUint8 is a uint8 type assignable to unions of which it is a subtype.

type UnionUnsupported added in v0.8.8

type UnionUnsupported struct {
	Value interface{}
}

UnionUnsupported is an interface{} wrapper type for unsupported types. It is assignable to unions of which it is a subtype.

func (*UnionUnsupported) IsExampleUnion added in v0.8.8

func (*UnionUnsupported) IsExampleUnion()

func (*UnionUnsupported) IsU added in v0.8.8

func (*UnionUnsupported) IsU()

type YANGEmpty added in v0.8.8

type YANGEmpty bool

YANGEmpty is a type that is used for fields that have a YANG type of empty. It is used such that empty fields can be distinguished from boolean fields in the generated code.

func (YANGEmpty) IsExampleUnion added in v0.8.8

func (YANGEmpty) IsExampleUnion()

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL