sync_producer_test.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. package mocks
  2. import (
  3. "testing"
  4. "github.com/Shopify/sarama"
  5. )
  6. func TestMockSyncProducerImplementsSyncProducerInterface(t *testing.T) {
  7. var mp interface{} = &SyncProducer{}
  8. if _, ok := mp.(sarama.SyncProducer); !ok {
  9. t.Error("The mock async producer should implement the sarama.SyncProducer interface.")
  10. }
  11. }
  12. func TestSyncProducerReturnsExpectationsToSendMessage(t *testing.T) {
  13. sp := NewSyncProducer(t, nil)
  14. defer sp.Close()
  15. sp.ExpectSendMessageAndSucceed()
  16. sp.ExpectSendMessageAndSucceed()
  17. sp.ExpectSendMessageAndFail(sarama.ErrOutOfBrokers)
  18. var (
  19. offset int64
  20. err error
  21. )
  22. _, offset, err = sp.SendMessage("test", nil, sarama.StringEncoder("test"))
  23. if err != nil {
  24. t.Errorf("The first message should have been produced successfully, but got %s", err)
  25. }
  26. if offset != 1 {
  27. t.Errorf("The first message should have been assigned offset 1, but got %d", offset)
  28. }
  29. _, offset, err = sp.SendMessage("test", nil, sarama.StringEncoder("test"))
  30. if err != nil {
  31. t.Errorf("The second message should have been produced successfully, but got %s", err)
  32. }
  33. if offset != 2 {
  34. t.Errorf("The second message should have been assigned offset 2, but got %d", offset)
  35. }
  36. _, offset, err = sp.SendMessage("test", nil, sarama.StringEncoder("test"))
  37. if err != sarama.ErrOutOfBrokers {
  38. t.Errorf("The third message should not have been produced successfully")
  39. }
  40. sp.Close()
  41. }
  42. func TestSyncProducerWithTooManyExpectations(t *testing.T) {
  43. trm := newTestReporterMock()
  44. sp := NewSyncProducer(trm, nil)
  45. sp.ExpectSendMessageAndSucceed()
  46. sp.ExpectSendMessageAndFail(sarama.ErrOutOfBrokers)
  47. sp.SendMessage("test", nil, sarama.StringEncoder("test"))
  48. sp.Close()
  49. if len(trm.errors) != 1 {
  50. t.Error("Expected to report an error")
  51. }
  52. }
  53. func TestSyncProducerWithTooFewExpectations(t *testing.T) {
  54. trm := newTestReporterMock()
  55. sp := NewSyncProducer(trm, nil)
  56. sp.ExpectSendMessageAndSucceed()
  57. sp.SendMessage("test", nil, sarama.StringEncoder("test"))
  58. sp.SendMessage("test", nil, sarama.StringEncoder("test"))
  59. sp.Close()
  60. if len(trm.errors) != 1 {
  61. t.Error("Expected to report an error")
  62. }
  63. }