123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- package sqlx
- import (
- "errors"
- "reflect"
- "testing"
- "github.com/go-sql-driver/mysql"
- "github.com/stretchr/testify/assert"
- "github.com/tal-tech/go-zero/core/breaker"
- "github.com/tal-tech/go-zero/core/logx"
- "github.com/tal-tech/go-zero/core/stat"
- )
- func init() {
- stat.SetReporter(nil)
- }
- func TestBreakerOnDuplicateEntry(t *testing.T) {
- logx.Disable()
- err := tryOnDuplicateEntryError(t, mysqlAcceptable)
- assert.Equal(t, duplicateEntryCode, err.(*mysql.MySQLError).Number)
- }
- func TestBreakerOnNotHandlingDuplicateEntry(t *testing.T) {
- logx.Disable()
- var found bool
- for i := 0; i < 100; i++ {
- if tryOnDuplicateEntryError(t, nil) == breaker.ErrServiceUnavailable {
- found = true
- }
- }
- assert.True(t, found)
- }
- func TestMysqlAcceptable(t *testing.T) {
- conn := NewMysql("nomysql").(*commonSqlConn)
- withMysqlAcceptable()(conn)
- assert.EqualValues(t, reflect.ValueOf(mysqlAcceptable).Pointer(), reflect.ValueOf(conn.accept).Pointer())
- assert.True(t, mysqlAcceptable(nil))
- assert.False(t, mysqlAcceptable(errors.New("any")))
- assert.False(t, mysqlAcceptable(new(mysql.MySQLError)))
- }
- func tryOnDuplicateEntryError(t *testing.T, accept func(error) bool) error {
- logx.Disable()
- conn := commonSqlConn{
- brk: breaker.NewBreaker(),
- accept: accept,
- }
- for i := 0; i < 1000; i++ {
- assert.NotNil(t, conn.brk.DoWithAcceptable(func() error {
- return &mysql.MySQLError{
- Number: duplicateEntryCode,
- }
- }, conn.acceptable))
- }
- return conn.brk.DoWithAcceptable(func() error {
- return &mysql.MySQLError{
- Number: duplicateEntryCode,
- }
- }, conn.acceptable)
- }
|