59 lines
1.2 KiB
Go
59 lines
1.2 KiB
Go
package testcase
|
|
|
|
import (
|
|
"context"
|
|
"plp-test/internal/config"
|
|
"plp-test/internal/model"
|
|
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
// ConcurrentWriteTest 并发写入测试
|
|
type ConcurrentWriteTest struct {
|
|
*BaseTestCase
|
|
}
|
|
|
|
// NewConcurrentWriteTest 创建并发写入测试
|
|
func NewConcurrentWriteTest(cfg *config.Config, logger *logrus.Logger) *ConcurrentWriteTest {
|
|
baseTest := NewBaseTestCase(
|
|
"concurrent",
|
|
"测试在Open-CAS环境中进行高并发写入时的数据完整性",
|
|
cfg,
|
|
logger,
|
|
)
|
|
|
|
return &ConcurrentWriteTest{
|
|
BaseTestCase: baseTest,
|
|
}
|
|
}
|
|
|
|
// Setup 设置测试环境
|
|
func (t *ConcurrentWriteTest) Setup(ctx context.Context, recovery bool) error {
|
|
if err := t.BaseTestCase.Setup(ctx); err != nil {
|
|
return err
|
|
}
|
|
|
|
// 实现并发写入测试的设置逻辑
|
|
return nil
|
|
}
|
|
|
|
// Run 运行测试
|
|
func (t *ConcurrentWriteTest) Run(ctx context.Context) (*model.TestResult, error) {
|
|
// 实现并发写入测试逻辑
|
|
return &model.TestResult{
|
|
ID: t.testID,
|
|
TestName: t.name,
|
|
Success: true,
|
|
}, nil
|
|
}
|
|
|
|
// Cleanup 清理测试环境
|
|
func (t *ConcurrentWriteTest) Cleanup(ctx context.Context) error {
|
|
if err := t.BaseTestCase.Cleanup(ctx); err != nil {
|
|
return err
|
|
}
|
|
|
|
// 实现并发写入测试的清理逻辑
|
|
return nil
|
|
}
|