Client is a fake implementation of an xds client. It exposes a bunch of channels to signal the occurrence of various events.
type Client struct { // Embed XDSClient so this fake client implements the interface, but it's // never set (it's always nil). This may cause nil panic since not all the // methods are implemented. xdsclient.XDSClient // contains filtered or unexported fields }
func NewClient() *Client
NewClient returns a new fake xds client.
func NewClientWithName(name string) *Client
NewClientWithName returns a new fake xds client with the provided name. This is used in cases where multiple clients are created in the tests and we need to make sure the client is created for the expected balancer name.
func (xdsC *Client) BootstrapConfig() *bootstrap.Config
BootstrapConfig returns the bootstrap config.
func (xdsC *Client) LoadStore() *load.Store
LoadStore returns the underlying load data store.
func (xdsC *Client) Name() string
Name returns the name of the xds client.
func (xdsC *Client) ReportLoad(server *bootstrap.ServerConfig) (loadStore *load.Store, cancel func())
ReportLoad starts reporting load about clusterName to server.
func (xdsC *Client) SetBootstrapConfig(cfg *bootstrap.Config)
SetBootstrapConfig updates the bootstrap config.
func (xdsC *Client) WaitForCancelReportLoad(ctx context.Context) error
WaitForCancelReportLoad waits for a load report to be cancelled and returns context.DeadlineExceeded otherwise.
func (xdsC *Client) WaitForReportLoad(ctx context.Context) (ReportLoadArgs, error)
WaitForReportLoad waits for ReportLoad to be invoked on this client and returns the arguments passed to it.
ReportLoadArgs wraps the arguments passed to ReportLoad.
type ReportLoadArgs struct { // Server is the name of the server to which the load is reported. Server *bootstrap.ServerConfig }