Files
tidb/pkg/planner/task/task_scheduler_test.go

71 lines
1.8 KiB
Go

// Copyright 2024 PingCAP, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package task
import (
"errors"
"strconv"
"testing"
"github.com/stretchr/testify/require"
)
// TestSchedulerContext is defined to test scheduling logic here.
type TestSchedulerContext struct {
ts *taskStack
}
func (t *TestSchedulerContext) getStack() Stack {
return t.ts
}
func (t *TestSchedulerContext) pushTask(task Task) {
t.ts.Push(task)
}
// TestSchedulerContext is defined to mock special error state in specified task.
type TestTaskImpl2 struct {
a int64
}
func (t *TestTaskImpl2) execute() error {
// mock error at special task
if t.a == 2 {
return errors.New("mock error at task id = 2")
}
return nil
}
func (t *TestTaskImpl2) desc() string {
return strconv.Itoa(int(t.a))
}
func TestSimpleTaskScheduler(t *testing.T) {
testSchedulerContext := &TestSchedulerContext{
newTaskStack(),
}
testScheduler := &SimpleTaskScheduler{
SchedulerCtx: testSchedulerContext,
}
testScheduler.SchedulerCtx.pushTask(&TestTaskImpl2{a: 1})
testScheduler.SchedulerCtx.pushTask(&TestTaskImpl2{a: 2})
testScheduler.SchedulerCtx.pushTask(&TestTaskImpl2{a: 3})
var testTaskScheduler Scheduler = testScheduler
testTaskScheduler.ExecuteTasks()
require.NotNil(t, testScheduler.Err)
require.Equal(t, testScheduler.Err.Error(), "mock error at task id = 2")
}