mirror of https://github.com/cloudreve/Cloudreve
Test: tasks pkg
parent
9056ef9171
commit
96b84bb5e5
|
@ -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")))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue