mysql_test.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. package sqlx
  2. import (
  3. "testing"
  4. "github.com/go-sql-driver/mysql"
  5. "github.com/stretchr/testify/assert"
  6. "github.com/tal-tech/go-zero/core/breaker"
  7. "github.com/tal-tech/go-zero/core/logx"
  8. "github.com/tal-tech/go-zero/core/stat"
  9. )
  10. func init() {
  11. stat.SetReporter(nil)
  12. }
  13. func TestBreakerOnDuplicateEntry(t *testing.T) {
  14. logx.Disable()
  15. err := tryOnDuplicateEntryError(t, mysqlAcceptable)
  16. assert.Equal(t, duplicateEntryCode, err.(*mysql.MySQLError).Number)
  17. }
  18. func TestBreakerOnNotHandlingDuplicateEntry(t *testing.T) {
  19. logx.Disable()
  20. var found bool
  21. for i := 0; i < 100; i++ {
  22. if tryOnDuplicateEntryError(t, nil) == breaker.ErrServiceUnavailable {
  23. found = true
  24. }
  25. }
  26. assert.True(t, found)
  27. }
  28. func tryOnDuplicateEntryError(t *testing.T, accept func(error) bool) error {
  29. logx.Disable()
  30. conn := commonSqlConn{
  31. brk: breaker.NewBreaker(),
  32. accept: accept,
  33. }
  34. for i := 0; i < 1000; i++ {
  35. assert.NotNil(t, conn.brk.DoWithAcceptable(func() error {
  36. return &mysql.MySQLError{
  37. Number: duplicateEntryCode,
  38. }
  39. }, conn.acceptable))
  40. }
  41. return conn.brk.DoWithAcceptable(func() error {
  42. return &mysql.MySQLError{
  43. Number: duplicateEntryCode,
  44. }
  45. }, conn.acceptable)
  46. }