|
| 1 | +package kafkastreamer |
| 2 | + |
| 3 | +import ( |
| 4 | + "testing" |
| 5 | + |
| 6 | + "github.com/IBM/sarama" |
| 7 | + "github.com/stretchr/testify/require" |
| 8 | +) |
| 9 | + |
| 10 | +func TestWithConfig(t *testing.T) { |
| 11 | + brokers := []string{"localhost:9092"} |
| 12 | + customConfig := sarama.NewConfig() |
| 13 | + customConfig.Producer.MaxMessageBytes = 2000000 |
| 14 | + customConfig.Consumer.Fetch.Default = 2048576 |
| 15 | + |
| 16 | + sc := New(brokers, WithConfig(customConfig)) |
| 17 | + |
| 18 | + // Since this is an internal test, we can access private fields |
| 19 | + require.Equal(t, 2000000, sc.sharedConfig.Producer.MaxMessageBytes) |
| 20 | + require.Equal(t, int32(2048576), sc.sharedConfig.Consumer.Fetch.Default) |
| 21 | +} |
| 22 | + |
| 23 | +func TestWithConfigOverridesDefaults(t *testing.T) { |
| 24 | + brokers := []string{"localhost:9092"} |
| 25 | + |
| 26 | + // First verify our default config |
| 27 | + defaultSC := New(brokers) |
| 28 | + require.True(t, defaultSC.sharedConfig.Producer.Return.Successes) |
| 29 | + require.True(t, defaultSC.sharedConfig.Producer.Return.Errors) |
| 30 | + |
| 31 | + // Now test that custom config overrides defaults |
| 32 | + customConfig := sarama.NewConfig() |
| 33 | + customConfig.Producer.Return.Successes = false |
| 34 | + customConfig.Producer.Return.Errors = false |
| 35 | + |
| 36 | + customSC := New(brokers, WithConfig(customConfig)) |
| 37 | + |
| 38 | + // Verify that the custom config completely replaced the default |
| 39 | + require.False(t, customSC.sharedConfig.Producer.Return.Successes) |
| 40 | + require.False(t, customSC.sharedConfig.Producer.Return.Errors) |
| 41 | +} |
| 42 | + |
| 43 | +func TestDefaultConfig(t *testing.T) { |
| 44 | + brokers := []string{"localhost:9092"} |
| 45 | + sc := New(brokers) |
| 46 | + |
| 47 | + // Verify default config values |
| 48 | + require.True(t, sc.sharedConfig.Producer.Return.Successes) |
| 49 | + require.True(t, sc.sharedConfig.Producer.Return.Errors) |
| 50 | +} |
| 51 | + |
| 52 | +func TestPanicIfConfigNil(t *testing.T) { |
| 53 | + require.PanicsWithValue(t, |
| 54 | + "sarama config cannot be nil", |
| 55 | + func() { |
| 56 | + _ = New([]string{""}, WithConfig(nil)) |
| 57 | + }, "") |
| 58 | +} |
0 commit comments