Test: tasks pkg

pull/1059/head
HFO4 2021-11-20 17:14:45 +08:00
parent 9056ef9171
commit 96b84bb5e5
7 changed files with 44 additions and 12 deletions

View File

@ -144,7 +144,7 @@ func TestCompressTask_Do(t *testing.T) {
task.Do() task.Do()
asserts.NoError(mock.ExpectationsWereMet()) asserts.NoError(mock.ExpectationsWereMet())
asserts.NotEmpty(task.GetError().Msg) asserts.NotEmpty(task.GetError().Msg)
asserts.True(util.IsEmpty("test/compress")) asserts.True(util.IsEmpty(util.RelativePath("test/compress")))
} }
} }

View File

@ -82,7 +82,7 @@ func Record(job Job) (*model.Task, error) {
} }
// Resume 从数据库中恢复未完成任务 // Resume 从数据库中恢复未完成任务
func Resume() { func Resume(p Pool) {
tasks := model.GetTasksByStatus(Queued, Processing) tasks := model.GetTasksByStatus(Queued, Processing)
if len(tasks) == 0 { if len(tasks) == 0 {
return return
@ -97,7 +97,7 @@ func Resume() {
} }
if job != nil { if job != nil {
TaskPoll.Submit(job) p.Submit(job)
} }
} }
} }

View File

@ -2,6 +2,7 @@ package task
import ( import (
"errors" "errors"
testMock "github.com/stretchr/testify/mock"
"testing" "testing"
"github.com/DATA-DOG/go-sqlmock" "github.com/DATA-DOG/go-sqlmock"
@ -21,15 +22,46 @@ func TestRecord(t *testing.T) {
asserts.NoError(err) asserts.NoError(err)
} }
type taskPoolMock struct {
testMock.Mock
}
func (t taskPoolMock) Add(num int) {
t.Called(num)
}
func (t taskPoolMock) Submit(job Job) {
t.Called(job)
}
func TestResume(t *testing.T) { func TestResume(t *testing.T) {
asserts := assert.New(t) asserts := assert.New(t)
mockPool := taskPoolMock{}
// 没有任务 // 没有任务
{ {
mock.ExpectQuery("SELECT(.+)").WithArgs(Queued).WillReturnRows(sqlmock.NewRows([]string{"type"})) mock.ExpectQuery("SELECT(.+)").WithArgs(Queued, Processing).WillReturnRows(sqlmock.NewRows([]string{"type"}))
Resume() Resume(mockPool)
asserts.NoError(mock.ExpectationsWereMet()) asserts.NoError(mock.ExpectationsWereMet())
} }
// 有任务, 类型未知
{
mock.ExpectQuery("SELECT(.+)").WithArgs(Queued, Processing).WillReturnRows(sqlmock.NewRows([]string{"type"}).AddRow(233))
Resume(mockPool)
asserts.NoError(mock.ExpectationsWereMet())
}
// 有任务
{
mockPool.On("Submit", testMock.Anything)
mock.ExpectQuery("SELECT(.+)").WithArgs(Queued, Processing).WillReturnRows(sqlmock.NewRows([]string{"type", "props"}).AddRow(CompressTaskType, "{}"))
mock.ExpectQuery("SELECT(.+)users").WillReturnRows(sqlmock.NewRows([]string{"id"}).AddRow(1))
mock.ExpectQuery("SELECT(.+)policies").WillReturnRows(sqlmock.NewRows([]string{"id"}).AddRow(1))
Resume(mockPool)
asserts.NoError(mock.ExpectationsWereMet())
mockPool.AssertExpectations(t)
}
} }
func TestGetJobFromModel(t *testing.T) { func TestGetJobFromModel(t *testing.T) {

View File

@ -63,6 +63,6 @@ func Init() {
util.Log().Info("初始化任务队列WorkerNum = %d", maxWorker) util.Log().Info("初始化任务队列WorkerNum = %d", maxWorker)
if conf.SystemConfig.Mode == "master" { if conf.SystemConfig.Mode == "master" {
Resume() Resume(TaskPoll)
} }
} }

View File

@ -29,10 +29,10 @@ func TestMain(m *testing.M) {
func TestInit(t *testing.T) { func TestInit(t *testing.T) {
asserts := assert.New(t) asserts := assert.New(t)
cache.Set("setting_max_worker_num", "10", 0) cache.Set("setting_max_worker_num", "10", 0)
mock.ExpectQuery("SELECT(.+)").WithArgs(Queued).WillReturnRows(sqlmock.NewRows([]string{"type"}).AddRow(-1)) mock.ExpectQuery("SELECT(.+)").WithArgs(Queued, Processing).WillReturnRows(sqlmock.NewRows([]string{"type"}).AddRow(-1))
Init() Init()
asserts.NoError(mock.ExpectationsWereMet()) asserts.NoError(mock.ExpectationsWereMet())
asserts.Len(TaskPoll.idleWorker, 10) asserts.Len(TaskPoll.(*AsyncPool).idleWorker, 10)
} }
func TestPool_Submit(t *testing.T) { func TestPool_Submit(t *testing.T) {

View File

@ -69,7 +69,7 @@ func (job *TransferTask) SetErrorMsg(msg string, err error) {
} }
if err := cluster.DefaultController.SendNotification(job.MasterID, job.Req.Hash(job.MasterID), notifyMsg); err != nil { if err := cluster.DefaultController.SendNotification(job.MasterID, job.Req.Hash(job.MasterID), notifyMsg); err != nil {
util.Log().Warning("无法发送转存失败通知到从机, ", err) util.Log().Warning("无法发送转存失败通知到从机, %s", err)
} }
} }
@ -132,7 +132,7 @@ func (job *TransferTask) Do() {
} }
if err := cluster.DefaultController.SendNotification(job.MasterID, job.Req.Hash(job.MasterID), msg); err != nil { if err := cluster.DefaultController.SendNotification(job.MasterID, job.Req.Hash(job.MasterID), msg); err != nil {
util.Log().Warning("无法发送转存成功通知到从机, ", err) util.Log().Warning("无法发送转存成功通知到从机, %s", err)
} }
} }

View File

@ -138,7 +138,7 @@ func TestNewTransferTask(t *testing.T) {
mock.ExpectBegin() mock.ExpectBegin()
mock.ExpectExec("INSERT(.+)").WillReturnResult(sqlmock.NewResult(1, 1)) mock.ExpectExec("INSERT(.+)").WillReturnResult(sqlmock.NewResult(1, 1))
mock.ExpectCommit() mock.ExpectCommit()
job, err := NewTransferTask(1, []string{}, "/", "/", false) job, err := NewTransferTask(1, []string{}, "/", "/", false, 0, nil)
asserts.NoError(mock.ExpectationsWereMet()) asserts.NoError(mock.ExpectationsWereMet())
asserts.NotNil(job) asserts.NotNil(job)
asserts.NoError(err) asserts.NoError(err)
@ -150,7 +150,7 @@ func TestNewTransferTask(t *testing.T) {
mock.ExpectBegin() mock.ExpectBegin()
mock.ExpectExec("INSERT(.+)").WillReturnError(errors.New("error")) mock.ExpectExec("INSERT(.+)").WillReturnError(errors.New("error"))
mock.ExpectRollback() mock.ExpectRollback()
job, err := NewTransferTask(1, []string{}, "/", "/", false) job, err := NewTransferTask(1, []string{}, "/", "/", false, 0, nil)
asserts.NoError(mock.ExpectationsWereMet()) asserts.NoError(mock.ExpectationsWereMet())
asserts.Nil(job) asserts.Nil(job)
asserts.Error(err) asserts.Error(err)