|
9 | 9 | "time"
|
10 | 10 |
|
11 | 11 | "github.com/DATA-DOG/go-sqlmock"
|
| 12 | + "github.com/go-sql-driver/mysql" |
12 | 13 | "github.com/pingcap/errors"
|
| 14 | + "github.com/pingcap/failpoint" |
13 | 15 | "github.com/pingcap/tidb/br/pkg/version"
|
14 | 16 | tcontext "github.com/pingcap/tidb/dumpling/context"
|
15 | 17 | "github.com/pingcap/tidb/parser"
|
@@ -224,3 +226,64 @@ func TestUnregisterMetrics(t *testing.T) {
|
224 | 226 | // should not panic
|
225 | 227 | require.Error(t, err)
|
226 | 228 | }
|
| 229 | + |
| 230 | +func TestSetSessionParams(t *testing.T) { |
| 231 | + // case 1: fail to set tidb_snapshot, should return error with hint |
| 232 | + db, mock, err := sqlmock.New() |
| 233 | + require.NoError(t, err) |
| 234 | + defer func() { |
| 235 | + require.NoError(t, db.Close()) |
| 236 | + }() |
| 237 | + |
| 238 | + mock.ExpectQuery("SELECT @@tidb_config"). |
| 239 | + WillReturnError(errors.New("mock error")) |
| 240 | + mock.ExpectQuery("SELECT COUNT\\(1\\) as c FROM MYSQL.TiDB WHERE VARIABLE_NAME='tikv_gc_safe_point'"). |
| 241 | + WillReturnError(errors.New("mock error")) |
| 242 | + tikvErr := &mysql.MySQLError{ |
| 243 | + Number: 1105, |
| 244 | + Message: "can not get 'tikv_gc_safe_point'", |
| 245 | + } |
| 246 | + mock.ExpectExec("SET SESSION tidb_snapshot"). |
| 247 | + WillReturnError(tikvErr) |
| 248 | + |
| 249 | + require.NoError(t, failpoint.Enable("github.com/pingcap/tidb/dumpling/export/SkipResetDB", "return(true)")) |
| 250 | + defer failpoint.Disable("github.com/pingcap/tidb/dumpling/export/SkipResetDB=return(true)") |
| 251 | + |
| 252 | + tctx, cancel := tcontext.Background().WithLogger(appLogger).WithCancel() |
| 253 | + defer cancel() |
| 254 | + |
| 255 | + conf := DefaultConfig() |
| 256 | + conf.ServerInfo = version.ServerInfo{ |
| 257 | + ServerType: version.ServerTypeTiDB, |
| 258 | + HasTiKV: false, |
| 259 | + } |
| 260 | + conf.Snapshot = "439153276059648000" |
| 261 | + conf.Consistency = ConsistencyTypeSnapshot |
| 262 | + d := &Dumper{ |
| 263 | + tctx: tctx, |
| 264 | + conf: conf, |
| 265 | + cancelCtx: cancel, |
| 266 | + dbHandle: db, |
| 267 | + } |
| 268 | + err = setSessionParam(d) |
| 269 | + require.ErrorContains(t, err, "consistency=none") |
| 270 | + |
| 271 | + // case 2: fail to set other |
| 272 | + conf.ServerInfo = version.ServerInfo{ |
| 273 | + ServerType: version.ServerTypeMySQL, |
| 274 | + HasTiKV: false, |
| 275 | + } |
| 276 | + conf.Snapshot = "" |
| 277 | + conf.Consistency = ConsistencyTypeFlush |
| 278 | + conf.SessionParams = map[string]interface{}{ |
| 279 | + "mock": "UTC", |
| 280 | + } |
| 281 | + d.dbHandle = db |
| 282 | + mock.ExpectExec("SET SESSION mock"). |
| 283 | + WillReturnError(errors.New("Unknown system variable mock")) |
| 284 | + mock.ExpectClose() |
| 285 | + mock.ExpectClose() |
| 286 | + |
| 287 | + err = setSessionParam(d) |
| 288 | + require.NoError(t, err) |
| 289 | +} |
0 commit comments