Files
tcpserver-flow/tests/flow/node_flow/BlockTest.php
T
zimoyin 9ddec3dfb9 refactor(flow): 优化流程配置及相关测试
- 在测试代码中统一使用 setPreviousAction 与 setDuration 方法,规范方法调用
- VirtualContextBuilder 允许 setDuration 接收 null,增强灵活性
- VirtualityFlowProcessor 计算步骤持续时间时改进判断逻辑,避免错误持续时间值
- 增加日志记录上一步骤开始时间,方便调试流程状态
- 自定义流程配置文件大幅重构,新增多种晨洗模式配置
- 新增机洗单步骤流程、无晨洗流程、每日首次晨洗、存储超时晨洗等多种流程样例
- 自定义流程支持 override_steps 为 true/false 的不同合并策略说明与示例
- 详细补充配置节点说明,增强配置文档准确性和用户理解
- 自定义语音模板扩展,支持多种语音播报及错误提示文本
- 更新时间验证配置,统一各流程中各步骤时间要求
- 补充“配置自定义节点流程指南”文档,详细说明配置原则、合并策略与使用建议
2026-03-13 18:59:36 +08:00

182 lines
5.9 KiB
PHP

<?php
namespace tests\flow\cases;
use app\config\Config;
use app\flow\config\ProcessConfig;
use app\flow\ProcessEngine;
use app\utils\Logger;
use tests\flow\TestCase;
use tests\flow\VirtualityFlowProcessor;
/**
* 流程阻断逻辑测试
*
* 覆盖场景:
* 7. 流程阻断逻辑正确性
*/
class BlockTest extends TestCase
{
private VirtualityFlowProcessor $processor;
private bool $originalBlockMode;
protected function setUp(): void
{
parent::setUp();
$this->processor = VirtualityFlowProcessor::createStandard();
// 保存原始 blockMode 值
$this->originalBlockMode = Config::getInstance()->blockMode;
}
protected function tearDown(): void
{
parent::tearDown();
$this->processor->reset();
// 恢复原始 blockMode 值
Config::getInstance()->setBlockMode($this->originalBlockMode);
}
// ==================== 7. 流程阻断逻辑正确性 ====================
/**
* 测试流程链正确执行
*/
public function testProcessChainExecution(): void
{
$engine = ProcessEngine::createStandard();
// 验证流程链已构建
$nodes = $engine->getNodes();
$this->assertNotEmpty($nodes, '流程链应包含节点');
}
/**
* 测试禁用节点后的流程
*/
public function testDisabledNodeSkipped(): void
{
$config = ProcessConfig::createStandard();
$config->skipStep('晨洗');
$processor = VirtualityFlowProcessor::create($config);
$result = $processor->swipe('操作员1', '胃镜1', '清洗');
// 晨洗被跳过,应该直接进入清洗
$this->assertSuccess($result);
$this->assertStep($result, '清洗');
}
/**
* 测试时间验证策略阻断 - 阻断模式开启
*
* 当 blockMode=true 时,清洗时长不达标应该返回错误
*/
public function testTimeValidationBlockWithBlockModeOn(): void
{
// 开启阻断模式
Config::getInstance()->setBlockMode(true);
// 创建一个时间不足的场景(只有5秒)
// 关键:设置 previousAction 和 processType 使得时间验证策略生效
$context = $this->processor->createContextBuilder()
->endoscope('胃镜1')
->reader('漂洗')
->operator('操作员1')
->currentStep('清洗')
->setPreviousAction('清洗') // 上一步也是清洗,表示重复刷同一步骤
->processType('手工洗') // 必须设置流程类型,否则 hasStep 返回 false
->setDuration(5) // 只有5秒,时间不足
->batchNo(date('Ymd') . '010001')
->build();
$engine = ProcessEngine::createStandard();
$result = $engine->execute($context);
// 阻断模式下,时间不足应该导致流程失败
$this->assertFalse($result->isSuccess(), '阻断模式下,时长不足应失败');
}
/**
* 测试时间验证策略 - 阻断模式关闭
*
* 当 blockMode=false 时,清洗时长不达标仍可继续,但应有提醒
*/
public function testTimeValidationWithBlockModeOff(): void
{
// 关闭阻断模式
Config::getInstance()->setBlockMode(false);
// 创建一个时间不足的场景
$context = $this->processor->createContextBuilder()
->endoscope('胃镜1')
->reader('漂洗')
->operator('操作员1')
->currentStep('清洗')
->setPreviousAction('清洗') // 设置 previousAction 使时间验证生效
->processType('手工洗') // 必须设置流程类型
->setDuration(5) // 只有5秒,时间不足
->batchNo(date('Ymd') . '010001')
->build();
$engine = ProcessEngine::createStandard();
$result = $engine->execute($context);
// 非阻断模式下,时间不足应该可以继续流程
$this->assertTrue($result->isSuccess(), '非阻断模式下,时长不足应可继续');
}
/**
* 测试重复刷卡阻断
*/
public function testDuplicateSwipeBlock(): void
{
$operator = '操作员1';
$endoscope = '胃镜1';
// 完成清洗
$result1 = $this->processor->swipe($operator, $endoscope, '清洗');
$this->assertSuccess($result1);
// 继续漂洗
$result2 = $this->processor->swipe($operator, $endoscope, '漂洗');
// 重复刷漂洗卡
$result3 = $this->processor->swipe($operator, $endoscope, '漂洗');
// 获取语音,验证重复刷卡提示
$voice3 = $result3->getFullVoice();
$this->assertNotEmpty($voice3, '应有语音输出');
$this->assertStringContainsString('重复刷卡', $voice3, '语音应包含重复刷卡提示');
}
/**
* 测试时长达标时的正常流程
*/
public function testTimeValidationPass(): void
{
// 开启阻断模式
Config::getInstance()->setBlockMode(true);
// 创建时长达标的场景(120秒,超过最低要求)
$context = $this->processor->createContextBuilder()
->endoscope('胃镜1')
->reader('漂洗')
->operator('操作员1')
->currentStep('清洗')
->setPreviousAction('清洗') // 设置 previousAction 使时间验证生效
->processType('手工洗') // 必须设置流程类型
->setDuration(120) // 120秒,时间充足
->batchNo(date('Ymd') . '010001')
->build();
$engine = ProcessEngine::createStandard();
$result = $engine->execute($context);
// 时长达标应该成功
$this->assertTrue($result->isSuccess(), '时长达标应成功');
}
}