如何解决如何验证drools规则中的哪个条件失败?
我正在使用 drools 7.44 并且有一个包含 20 多个规则的包。目前我面临的问题是,有时我希望触发的某些规则没有触发。 在 then 中,我可以添加日志语句,但不能在 when 中添加。 有没有办法调试或记录规则的哪些条件失败?
如果客户年龄=21 性别=男性并且使用以下规则。我如何在运行时确定性别是导致规则不触发的标准。
rule "some rule"
when
$c : Customer(age>18,gender == "female" )
then
........
do something here
log.debug("something to log")
end
这是一个简单的例子来说明问题。理想情况下,我们有多个条件。
解决方法
使用 DebugAgendaEventListener
跟踪规则评估。请参阅manual
这将仅涵盖匹配成功的情况。如果没有,则不会评估任何内容。有一个 JIRA 来跟踪这种失败的评估
摘自手册
Drools 引擎还支持以下议程和工作 用于调试日志记录的内存事件侦听器:
DebugAgendaEventListener
DebugRuleRuntimeEventListener
这些事件侦听器实现了相同的受支持的事件侦听器 方法并默认包含调试打印语句。您可以添加一个 要监视和记录的特定支持事件,或监视 所有议程或工作记忆活动。
例如下面的代码使用了DebugRuleRuntimeEventListener 监听和打印所有工作内存事件的事件监听器:
监控和打印所有工作内存事件的示例代码
ksession.addEventListener( new DebugRuleRuntimeEventListener() );
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。