Comments (2)
@blib thank you for providing this test case and good catch 👍
May Ia ask, in the test you wrote bpmnEngine.PublishEventForInstance(pi1.GetInstanceKey(), "globalMsgRef", nil)
twice,
and the assertions as well. It seems redundant and could be shortenened, like below.
Do I oversee something?
PS: I will provide a fix soon.
func Test_IntermediateCatchEvent_multiple_instances_received_message_completes_the_instance(t *testing.T) {
// setup
bpmnEngine := New()
// given
process, _ := bpmnEngine.LoadFromFile("../../test-cases/message-intermediate-catch-event.bpmn")
pi1, _ := bpmnEngine.CreateAndRunInstance(process.ProcessKey, map[string]interface{}{"key": "pi1"})
pi2, _ := bpmnEngine.CreateAndRunInstance(process.ProcessKey, map[string]interface{}{"key": "pi2"})
// when
bpmnEngine.PublishEventForInstance(pi1.GetInstanceKey(), "globalMsgRef", nil)
bpmnEngine.RunOrContinueInstance(pi1.GetInstanceKey())
bpmnEngine.RunOrContinueInstance(pi2.GetInstanceKey())
// then
then.AssertThat(t, pi1.GetState(), is.EqualTo(Completed))
then.AssertThat(t, pi2.GetState(), is.EqualTo(Active))
// when
bpmnEngine.PublishEventForInstance(pi2.GetInstanceKey(), "globalMsgRef", nil)
bpmnEngine.RunOrContinueInstance(pi1.GetInstanceKey())
bpmnEngine.RunOrContinueInstance(pi2.GetInstanceKey())
// then
then.AssertThat(t, pi1.GetState(), is.EqualTo(Completed))
then.AssertThat(t, pi2.GetState(), is.EqualTo(Completed))
}
from lib-bpmn-engine.
fixed.
thank you for your contribution 🚀
from lib-bpmn-engine.
Related Issues (20)
- QUESTION: Process not in COMPLETED state? HOT 4
- Ensure that parallel flows are executed independently HOT 7
- QUESTION: How to execute a process in async way HOT 3
- Add support for link events HOT 3
- improve documentation: synchr. vs. asynch. jobs
- bpmn is driven through for temporal HOT 4
- Refactor using go-style Getters and Setters
- implement support for start timer event HOT 1
- evaluate expression using jsonlogic HOT 3
- Even more flexible task handlers HOT 9
- Can lib-bpmn-engine specify participants via assignment handler? HOT 1
- replace `MessageSubscription.originaActivity` with some smarter solution
- add feature - Inclusive Gateway element HOT 1
- Inclusive gateway question. HOT 2
- How to implement user task? HOT 3
- improve error handling handleIntermediateTimerCatchEvent() HOT 1
- improve test coverage
- Rework engine-name to be optional HOT 5
- fix data house keeping / cleanup HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from lib-bpmn-engine.