Added mermaid test cases for sequence diagrams
This commit is contained in:
@@ -28,32 +28,32 @@ TEST_CASE("t20020", "[test-case][sequence]")
|
||||
|
||||
REQUIRE(model->name() == "t20020_sequence");
|
||||
{
|
||||
auto puml = generate_sequence_puml(diagram, *model);
|
||||
AliasMatcher _A(puml);
|
||||
auto src = generate_sequence_puml(diagram, *model);
|
||||
AliasMatcher _A(src);
|
||||
|
||||
REQUIRE_THAT(puml, StartsWith("@startuml"));
|
||||
REQUIRE_THAT(puml, EndsWith("@enduml\n"));
|
||||
REQUIRE_THAT(src, StartsWith("@startuml"));
|
||||
REQUIRE_THAT(src, EndsWith("@enduml\n"));
|
||||
|
||||
// Check if all calls exist
|
||||
REQUIRE_THAT(puml, HasCall(_A("tmain()"), _A("A"), "a1()"));
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("A"), "a1()"));
|
||||
REQUIRE_THAT(
|
||||
puml, HasCallInControlCondition(_A("tmain()"), _A("A"), "a2()"));
|
||||
src, HasCallInControlCondition(_A("tmain()"), _A("A"), "a2()"));
|
||||
REQUIRE_THAT(
|
||||
puml, HasCallInControlCondition(_A("tmain()"), _A("A"), "a3()"));
|
||||
src, HasCallInControlCondition(_A("tmain()"), _A("A"), "a3()"));
|
||||
|
||||
REQUIRE_THAT(puml, HasCall(_A("tmain()"), _A("B"), "b1()"));
|
||||
REQUIRE_THAT(puml, HasCall(_A("tmain()"), _A("B"), "b2()"));
|
||||
REQUIRE_THAT(puml, HasCall(_A("tmain()"), _A("B"), "log()"));
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B"), "b1()"));
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B"), "b2()"));
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B"), "log()"));
|
||||
|
||||
REQUIRE_THAT(puml, HasCall(_A("tmain()"), _A("C"), "c1() const"));
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("C"), "c1() const"));
|
||||
REQUIRE_THAT(
|
||||
puml, HasCallInControlCondition(_A("C"), _A("C"), "c2() const"));
|
||||
REQUIRE_THAT(puml, HasCall(_A("C"), _A("C"), "log() const"));
|
||||
src, HasCallInControlCondition(_A("C"), _A("C"), "c2() const"));
|
||||
REQUIRE_THAT(src, HasCall(_A("C"), _A("C"), "log() const"));
|
||||
|
||||
REQUIRE_THAT(
|
||||
puml, HasCallInControlCondition(_A("tmain()"), _A("C"), "c3(int)"));
|
||||
src, HasCallInControlCondition(_A("tmain()"), _A("C"), "c3(int)"));
|
||||
|
||||
save_puml(config.output_directory(), diagram->name + ".puml", puml);
|
||||
save_puml(config.output_directory(), diagram->name + ".puml", src);
|
||||
}
|
||||
|
||||
{
|
||||
@@ -81,8 +81,30 @@ TEST_CASE("t20020", "[test-case][sequence]")
|
||||
}
|
||||
|
||||
{
|
||||
auto mmd = generate_sequence_mermaid(diagram, *model);
|
||||
auto src = generate_sequence_mermaid(diagram, *model);
|
||||
|
||||
save_mermaid(config.output_directory(), diagram->name + ".mmd", mmd);
|
||||
mermaid::SequenceDiagramAliasMatcher _A(src);
|
||||
using mermaid::HasCall;
|
||||
using mermaid::HasCallInControlCondition;
|
||||
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("A"), "a1()"));
|
||||
REQUIRE_THAT(
|
||||
src, HasCallInControlCondition(_A("tmain()"), _A("A"), "a2()"));
|
||||
REQUIRE_THAT(
|
||||
src, HasCallInControlCondition(_A("tmain()"), _A("A"), "a3()"));
|
||||
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B"), "b1()"));
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B"), "b2()"));
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B"), "log()"));
|
||||
|
||||
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("C"), "c1() const"));
|
||||
REQUIRE_THAT(
|
||||
src, HasCallInControlCondition(_A("C"), _A("C"), "c2() const"));
|
||||
REQUIRE_THAT(src, HasCall(_A("C"), _A("C"), "log() const"));
|
||||
|
||||
REQUIRE_THAT(
|
||||
src, HasCallInControlCondition(_A("tmain()"), _A("C"), "c3(int)"));
|
||||
|
||||
save_mermaid(config.output_directory(), diagram->name + ".mmd", src);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user