Added mermaid test cases for class diagrams
This commit is contained in:
@@ -29,37 +29,37 @@ TEST_CASE("t00057", "[test-case][class]")
|
||||
REQUIRE(model->name() == "t00057_class");
|
||||
|
||||
{
|
||||
auto puml = generate_class_puml(diagram, *model);
|
||||
AliasMatcher _A(puml);
|
||||
auto src = generate_class_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 classes exist
|
||||
REQUIRE_THAT(puml, IsClass(_A("t00057_A")));
|
||||
REQUIRE_THAT(puml, IsClass(_A("t00057_B")));
|
||||
REQUIRE_THAT(puml, IsClass(_A("t00057_C")));
|
||||
REQUIRE_THAT(puml, IsUnion(_A("t00057_D")));
|
||||
REQUIRE_THAT(puml, IsClass(_A("t00057_E")));
|
||||
REQUIRE_THAT(puml, IsClass(_A("t00057_F")));
|
||||
REQUIRE_THAT(puml, IsClass(_A("t00057_G")));
|
||||
REQUIRE_THAT(puml, !IsClass(_A("(anonymous)")));
|
||||
REQUIRE_THAT(puml, IsClass(_A("t00057_R")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_A")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_B")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_C")));
|
||||
REQUIRE_THAT(src, IsUnion(_A("t00057_D")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_E")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_F")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_G")));
|
||||
REQUIRE_THAT(src, !IsClass(_A("(anonymous)")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_R")));
|
||||
|
||||
// Check if all relationships exist
|
||||
REQUIRE_THAT(puml, IsAggregation(_A("t00057_R"), _A("t00057_A"), "+a"));
|
||||
REQUIRE_THAT(puml, IsAggregation(_A("t00057_R"), _A("t00057_B"), "+b"));
|
||||
REQUIRE_THAT(puml, IsAssociation(_A("t00057_R"), _A("t00057_C"), "+c"));
|
||||
REQUIRE_THAT(puml, IsAggregation(_A("t00057_R"), _A("t00057_D"), "+d"));
|
||||
REQUIRE_THAT(puml, IsAssociation(_A("t00057_R"), _A("t00057_E"), "+e"));
|
||||
REQUIRE_THAT(puml, IsAssociation(_A("t00057_R"), _A("t00057_F"), "+f"));
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src, IsAggregation(_A("t00057_R"), _A("t00057_A"), "+a"));
|
||||
REQUIRE_THAT(src, IsAggregation(_A("t00057_R"), _A("t00057_B"), "+b"));
|
||||
REQUIRE_THAT(src, IsAssociation(_A("t00057_R"), _A("t00057_C"), "+c"));
|
||||
REQUIRE_THAT(src, IsAggregation(_A("t00057_R"), _A("t00057_D"), "+d"));
|
||||
REQUIRE_THAT(src, IsAssociation(_A("t00057_R"), _A("t00057_E"), "+e"));
|
||||
REQUIRE_THAT(src, IsAssociation(_A("t00057_R"), _A("t00057_F"), "+f"));
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(
|
||||
_A("t00057_E"), _A("t00057_E::(coordinates)"), "+coordinates"));
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(_A("t00057_E"), _A("t00057_E::(height)"), "+height"));
|
||||
|
||||
save_puml(config.output_directory(), diagram->name + ".puml", puml);
|
||||
save_puml(config.output_directory(), diagram->name + ".puml", src);
|
||||
}
|
||||
|
||||
{
|
||||
@@ -79,8 +79,35 @@ TEST_CASE("t00057", "[test-case][class]")
|
||||
save_json(config.output_directory(), diagram->name + ".json", j);
|
||||
}
|
||||
{
|
||||
auto mmd = generate_class_mermaid(diagram, *model);
|
||||
auto src = generate_class_mermaid(diagram, *model);
|
||||
|
||||
save_mermaid(config.output_directory(), diagram->name + ".mmd", mmd);
|
||||
mermaid::AliasMatcher _A(src);
|
||||
using mermaid::IsUnion;
|
||||
|
||||
// Check if all classes exist
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_A")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_B")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_C")));
|
||||
REQUIRE_THAT(src, IsUnion(_A("t00057_D")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_E")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_F")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_G")));
|
||||
REQUIRE_THAT(src, !IsClass(_A("(anonymous)")));
|
||||
REQUIRE_THAT(src, IsClass(_A("t00057_R")));
|
||||
|
||||
// Check if all relationships exist
|
||||
REQUIRE_THAT(src, IsAggregation(_A("t00057_R"), _A("t00057_A"), "+a"));
|
||||
REQUIRE_THAT(src, IsAggregation(_A("t00057_R"), _A("t00057_B"), "+b"));
|
||||
REQUIRE_THAT(src, IsAssociation(_A("t00057_R"), _A("t00057_C"), "+c"));
|
||||
REQUIRE_THAT(src, IsAggregation(_A("t00057_R"), _A("t00057_D"), "+d"));
|
||||
REQUIRE_THAT(src, IsAssociation(_A("t00057_R"), _A("t00057_E"), "+e"));
|
||||
REQUIRE_THAT(src, IsAssociation(_A("t00057_R"), _A("t00057_F"), "+f"));
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(
|
||||
_A("t00057_E"), _A("t00057_E::(coordinates)"), "+coordinates"));
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(_A("t00057_E"), _A("t00057_E::(height)"), "+height"));
|
||||
|
||||
save_mermaid(config.output_directory(), diagram->name + ".mmd", src);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user