Documentation ¶
Overview ¶
Package zookeeper has a common interface and mock objects to implement and test Zookeeper connections.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func GetBrokerIDs ¶
func GetBrokerIDs(zkConn Connection) ([]string, error)
GetBrokerIDs retrieves the broker ids from Zookeeper
Types ¶
type BrokerConnection ¶
BrokerConnection struct to allow for multiple connection setups.
func GetBrokerConnections ¶
func GetBrokerConnections(brokerID int, zkConn Connection) (brokerConnections []BrokerConnection, err error)
GetBrokerConnections Collects Broker connection info from Zookeeper
type Connection ¶
type Connection interface { Get(string) ([]byte, *zk.Stat, error) Children(string) ([]string, *zk.Stat, error) CreateClient() (connection.Client, error) CreateClusterAdmin() (sarama.ClusterAdmin, error) }
Connection interface to allow easy mocking of a Zookeeper connection
func NewConnection ¶
func NewConnection(kafkaArgs *args.KafkaArguments) (Connection, error)
NewConnection creates a new Connection with the given arguments. If not hosts are specified then a nil Connection and error will be returned
Waiting on issue https://github.com/samuel/go-zookeeper/issues/108 so we can change this function and allow us to mock out the zk.Connect function
type MockConnection ¶
MockConnection implements Connection to facilitate testing.
func (MockConnection) CreateClient ¶
func (m MockConnection) CreateClient() (connection.Client, error)
CreateClient mocks the CreateClient method
func (MockConnection) CreateClusterAdmin ¶
func (m MockConnection) CreateClusterAdmin() (sarama.ClusterAdmin, error)
CreateClusterAdmin mocks the CreateClusterAdmin method