mattermost-community-enterp.../public/model/scheduled_task_test.go
Claude ec1f89217a Merge: Complete Mattermost Server with Community Enterprise
Full Mattermost server source with integrated Community Enterprise features.
Includes vendor directory for offline/air-gapped builds.

Structure:
- enterprise-impl/: Enterprise feature implementations
- enterprise-community/: Init files that register implementations
- enterprise/: Bridge imports (community_imports.go)
- vendor/: All dependencies for offline builds

Build (online):
  go build ./cmd/mattermost

Build (offline/air-gapped):
  go build -mod=vendor ./cmd/mattermost

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-17 23:59:07 +09:00

106 lines
2.5 KiB
Go

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
package model
import (
"sync"
"sync/atomic"
"testing"
"time"
"github.com/stretchr/testify/assert"
)
func TestCreateTask(t *testing.T) {
TaskName := "Test Task"
TaskTime := time.Second * 2
executionCount := new(int32)
testFunc := func() {
atomic.AddInt32(executionCount, 1)
}
task := CreateTask(TaskName, testFunc, TaskTime)
assert.EqualValues(t, 0, atomic.LoadInt32(executionCount))
time.Sleep(TaskTime + time.Second)
assert.EqualValues(t, 1, atomic.LoadInt32(executionCount))
assert.Equal(t, TaskName, task.Name)
assert.Equal(t, TaskTime, task.Interval)
assert.False(t, task.Recurring)
}
func TestCreateRecurringTask(t *testing.T) {
TaskName := "Test Recurring Task"
TaskTime := time.Second * 2
executionCount := new(int32)
testFunc := func() {
atomic.AddInt32(executionCount, 1)
}
task := CreateRecurringTask(TaskName, testFunc, TaskTime)
assert.EqualValues(t, 0, atomic.LoadInt32(executionCount))
time.Sleep(TaskTime + time.Second)
assert.EqualValues(t, 1, atomic.LoadInt32(executionCount))
time.Sleep(TaskTime)
assert.EqualValues(t, 2, atomic.LoadInt32(executionCount))
assert.Equal(t, TaskName, task.Name)
assert.Equal(t, TaskTime, task.Interval)
assert.True(t, task.Recurring)
task.Cancel()
}
func TestCancelTask(t *testing.T) {
TaskName := "Test Task"
TaskTime := time.Second
executionCount := new(int32)
testFunc := func() {
atomic.AddInt32(executionCount, 1)
}
task := CreateTask(TaskName, testFunc, TaskTime)
assert.EqualValues(t, 0, atomic.LoadInt32(executionCount))
task.Cancel()
time.Sleep(TaskTime + time.Second)
assert.EqualValues(t, 0, atomic.LoadInt32(executionCount))
}
func TestCreateRecurringTaskFromNextIntervalTime(t *testing.T) {
taskName := "Test Recurring Task starting from next interval time"
taskTime := time.Second * 3
var executionTime time.Time
var mu sync.Mutex
testFunc := func() {
mu.Lock()
executionTime = time.Now()
mu.Unlock()
}
task := CreateRecurringTaskFromNextIntervalTime(taskName, testFunc, taskTime)
defer task.Cancel()
time.Sleep(taskTime)
mu.Lock()
expectedSeconds := executionTime.Second()
mu.Unlock()
// Ideally we would expect 0, but in busy CI environments it can lag
// by a second. If we see a lag of more than a second, we would need to disable
// the test entirely.
assert.LessOrEqual(t, expectedSeconds%3, 1)
assert.Equal(t, taskName, task.Name)
assert.Equal(t, taskTime, task.Interval)
assert.True(t, task.Recurring)
}