本文整理匯總了Golang中github.com/mailgun/kafka-pixy/config.Default函數的典型用法代碼示例。如果您正苦於以下問題:Golang Default函數的具體用法?Golang Default怎麽用?Golang Default使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Default函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestClaimPartitionCanceled
// If a partition is claimed by another group member then `ClaimPartition` call
// blocks until it is released.
func (s *GroupRegistratorSuite) TestClaimPartitionCanceled(c *C) {
// Given
cfg := config.Default()
gr1 := spawnGroupRegistrator("gr_test", "m1", cfg, s.kazooConn)
defer gr1.stop()
gr2 := spawnGroupRegistrator("gr_test", "m2", cfg, s.kazooConn)
defer gr2.stop()
cancelCh1 := make(chan none)
cancelCh2 := make(chan none)
wg := &sync.WaitGroup{}
claim1 := gr1.claimPartition(s.cid, "foo", 1, cancelCh1)
spawn(wg, func() {
time.Sleep(300 * time.Millisecond)
claim1()
})
// This goroutine will cancel the claim of m2 before, m1 releases the partition.
spawn(wg, func() {
time.Sleep(150 * time.Millisecond)
close(cancelCh2)
})
// When
claim2 := gr2.claimPartition(s.cid, "foo", 1, cancelCh2)
defer claim2()
// Then: the partition is still claimed by m1.
owner, err := gr2.partitionOwner("foo", 1)
c.Assert(err, IsNil)
c.Assert(owner, Equals, "m1")
// Wait for all test goroutines to stop.
wg.Wait()
}
示例2: GenMessages
func GenMessages(c *C, prefix, topic string, keys map[string]int) map[string][]*sarama.ProducerMessage {
config := config.Default()
config.ClientID = "producer"
config.Kafka.SeedPeers = testKafkaPeers
producer, err := SpawnGracefulProducer(config)
c.Assert(err, IsNil)
messages := make(map[string][]*sarama.ProducerMessage)
var wg sync.WaitGroup
var lock sync.Mutex
for key, count := range keys {
for i := 0; i < count; i++ {
key := key
message := fmt.Sprintf("%s:%s:%d", prefix, key, i)
spawn(&wg, func() {
keyEncoder := sarama.StringEncoder(key)
msgEncoder := sarama.StringEncoder(message)
prodMsg, err := producer.Produce(topic, keyEncoder, msgEncoder)
c.Assert(err, IsNil)
log.Infof("*** produced: topic=%s, partition=%d, offset=%d, message=%s",
topic, prodMsg.Partition, prodMsg.Offset, message)
lock.Lock()
messages[key] = append(messages[key], prodMsg)
lock.Unlock()
})
}
}
wg.Wait()
// Sort the produced messages in ascending order of their offsets.
for _, keyMessages := range messages {
sort.Sort(MessageSlice(keyMessages))
}
return messages
}
示例3: TestReSubscribe
// If a group registrator resubscribes to the same list of topics, every group
// member gets a membership change notification same as the previous one.
func (s *GroupRegistratorSuite) TestReSubscribe(c *C) {
// Given
cfg := config.Default()
cfg.Consumer.RebalanceDelay = 100 * time.Millisecond
gr1 := spawnGroupRegistrator("gr_test", "m1", cfg, s.kazooConn)
defer gr1.stop()
gr1.topics() <- []string{"foo", "bar"}
gr2 := spawnGroupRegistrator("gr_test", "m2", cfg, s.kazooConn)
defer gr2.stop()
gr2.topics() <- []string{"bazz", "bar"}
membership := map[string][]string{
"m1": {"bar", "foo"},
"m2": {"bar", "bazz"},
}
c.Assert(<-gr1.membershipChanges(), DeepEquals, membership)
c.Assert(<-gr2.membershipChanges(), DeepEquals, membership)
// When
gr1.topics() <- []string{"foo", "bar"}
// Then
c.Assert(<-gr1.membershipChanges(), DeepEquals, membership)
c.Assert(<-gr2.membershipChanges(), DeepEquals, membership)
}
示例4: SetUpSuite
func (s *AdminSuite) SetUpSuite(c *C) {
logging.InitTest()
s.config = config.Default()
s.config.ClientID = "producer"
s.config.Kafka.SeedPeers = testKafkaPeers
s.config.ZooKeeper.SeedPeers = testZookeeperPeers
}
示例5: TestResolvePartitions
func (s *GroupConsumerSuite) TestResolvePartitions(c *C) {
cfg := config.Default()
cfg.ClientID = "c"
gc := groupConsumer{
cfg: cfg,
fetchTopicPartitionsFn: func(topic string) ([]int32, error) {
return map[string][]int32{
"t1": {1, 2, 3, 4, 5},
"t2": {1, 2},
"t3": {1, 2, 3, 4, 5},
"t4": {1, 2, 3},
"t5": {1, 2, 3},
}[topic], nil
},
}
// When
topicsToPartitions, err := gc.resolvePartitions(
map[string][]string{
"a": {"t1", "t2", "t3"},
"b": {"t1", "t2", "t3"},
"c": {"t1", "t2", "t4", "t5"},
"d": {"t1", "t4"},
})
// Then
c.Assert(err, IsNil)
c.Assert(topicsToPartitions, DeepEquals, map[string][]int32{
"t1": {4},
"t4": {1, 2},
"t5": {1, 2, 3},
})
}
示例6: SetUpTest
func (s *GracefulProducerSuite) SetUpTest(c *C) {
s.deadMessageCh = make(chan *sarama.ProducerMessage, 100)
s.config = config.Default()
s.config.Kafka.SeedPeers = testKafkaPeers
s.config.Producer.DeadMessageCh = s.deadMessageCh
s.tkc = NewTestKafkaClient(s.config.Kafka.SeedPeers)
}
示例7: SetUpTest
func (s *ProducerSuite) SetUpTest(c *C) {
s.deadMessageCh = make(chan *sarama.ProducerMessage, 100)
s.cfg = config.Default()
s.cfg.Kafka.SeedPeers = testhelpers.KafkaPeers
s.cfg.Producer.DeadMessageCh = s.deadMessageCh
s.kh = testhelpers.NewKafkaHelper(c)
}
示例8: SetUpSuite
func (s *AdminSuite) SetUpSuite(c *C) {
testhelpers.InitLogging(c)
s.cfg = config.Default()
s.cfg.ClientID = "producer"
s.cfg.Kafka.SeedPeers = testhelpers.KafkaPeers
s.cfg.ZooKeeper.SeedPeers = testhelpers.ZookeeperPeers
s.kh = testhelpers.NewKafkaHelper(c)
}
示例9: SetUpSuite
func (s *SmartConsumerSuite) SetUpSuite(c *C) {
logging.InitTest()
var err error
config := config.Default()
config.ClientID = "producer"
config.Kafka.SeedPeers = testKafkaPeers
config.ChannelBufferSize = 1
s.producer, err = SpawnGracefulProducer(config)
c.Assert(err, IsNil)
}
示例10: NewTestConfig
func NewTestConfig(clientID string) *config.T {
cfg := config.Default()
cfg.UnixAddr = path.Join(os.TempDir(), "kafka-pixy.sock")
cfg.ClientID = clientID
cfg.Kafka.SeedPeers = KafkaPeers
cfg.ZooKeeper.SeedPeers = ZookeeperPeers
cfg.Consumer.LongPollingTimeout = 3000 * time.Millisecond
cfg.Consumer.BackOffTimeout = 100 * time.Millisecond
cfg.Consumer.RebalanceDelay = 100 * time.Millisecond
return cfg
}
示例11: TestSimpleSubscribe
// When a list of topics is sent to the `topics()` channel, a membership change
// is received with the same list of topics for the registrator name.
func (s *GroupRegistratorSuite) TestSimpleSubscribe(c *C) {
// Given
cfg := config.Default()
cfg.Consumer.RebalanceDelay = 200 * time.Millisecond
gr := spawnGroupRegistrator("gr_test", "m1", cfg, s.kazooConn)
defer gr.stop()
// When
gr.topics() <- []string{"foo", "bar"}
// Then
c.Assert(<-gr.membershipChanges(), DeepEquals,
map[string][]string{"m1": {"bar", "foo"}})
}
示例12: TestResubscribe
func (s *ConsumerGroupRegistrySuite) TestResubscribe(c *C) {
// Given
config := config.Default()
config.Consumer.RebalanceDelay = 200 * time.Millisecond
cgr := spawnConsumerGroupRegister("cgr_test", "m1", config, s.kazooConn)
defer cgr.stop()
cgr.topics() <- []string{"foo", "bar"}
// When
cgr.topics() <- []string{"blah", "bazz"}
// Then
c.Assert(<-cgr.membershipChanges(), DeepEquals,
map[string][]string{"m1": {"bazz", "blah"}})
}
示例13: TestResolvePartitionsEmpty
func (s *GroupConsumerSuite) TestResolvePartitionsEmpty(c *C) {
cfg := config.Default()
cfg.ClientID = "c"
gc := groupConsumer{
cfg: cfg,
fetchTopicPartitionsFn: func(topic string) ([]int32, error) {
return nil, nil
},
}
// When
topicsToPartitions, err := gc.resolvePartitions(nil)
// Then
c.Assert(err, IsNil)
c.Assert(topicsToPartitions, DeepEquals, map[string][]int32{})
}
示例14: TestResolvePartitionsError
func (s *GroupConsumerSuite) TestResolvePartitionsError(c *C) {
cfg := config.Default()
cfg.ClientID = "c"
gc := groupConsumer{
cfg: cfg,
fetchTopicPartitionsFn: func(topic string) ([]int32, error) {
return nil, errors.New("Kaboom!")
},
}
// When
topicsToPartitions, err := gc.resolvePartitions(map[string][]string{"c": {"t1"}})
// Then
c.Assert(err.Error(), Equals, "failed to get partition list: topic=t1, err=(Kaboom!)")
c.Assert(topicsToPartitions, IsNil)
}
示例15: TestClaimPartitionTwice
// It is ok to claim the same partition twice by the same group member.
func (s *GroupRegistratorSuite) TestClaimPartitionTwice(c *C) {
// Given
cfg := config.Default()
gr := spawnGroupRegistrator("gr_test", "m1", cfg, s.kazooConn)
defer gr.stop()
cancelCh := make(chan none)
// When
claim1 := gr.claimPartition(s.cid, "foo", 1, cancelCh)
defer claim1()
claim2 := gr.claimPartition(s.cid, "foo", 1, cancelCh)
defer claim2()
// Then
owner, err := gr.partitionOwner("foo", 1)
c.Assert(err, IsNil)
c.Assert(owner, Equals, "m1")
}