Added mermaid test cases for class diagrams
This commit is contained in:
@@ -29,56 +29,55 @@ TEST_CASE("t00064", "[test-case][class]")
|
||||
REQUIRE(model->name() == "t00064_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"));
|
||||
|
||||
REQUIRE_THAT(puml, !Contains("type-parameter-"));
|
||||
REQUIRE_THAT(src, !Contains("type-parameter-"));
|
||||
|
||||
REQUIRE_THAT(puml, IsClass(_A("A")));
|
||||
REQUIRE_THAT(puml, IsClass(_A("B")));
|
||||
REQUIRE_THAT(puml, IsClass(_A("C")));
|
||||
REQUIRE_THAT(puml, IsClass(_A("R")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A")));
|
||||
REQUIRE_THAT(src, IsClass(_A("B")));
|
||||
REQUIRE_THAT(src, IsClass(_A("C")));
|
||||
REQUIRE_THAT(src, IsClass(_A("R")));
|
||||
|
||||
REQUIRE_THAT(puml, IsClassTemplate("type_list", "Ts..."));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("type_list", "Ret(Arg &&),Ts..."));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("type_list", "T const,Ts..."));
|
||||
REQUIRE_THAT(src, IsClassTemplate("type_list", "Ts..."));
|
||||
REQUIRE_THAT(src, IsClassTemplate("type_list", "Ret(Arg &&),Ts..."));
|
||||
REQUIRE_THAT(src, IsClassTemplate("type_list", "T const,Ts..."));
|
||||
|
||||
REQUIRE_THAT(puml, IsClassTemplate("head", "typename"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("head", "type_list<Head,Tail...>"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("head", "typename"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("head", "type_list<Head,Tail...>"));
|
||||
REQUIRE_THAT(
|
||||
puml, IsClassTemplate("type_group_pair", "typename,typename"));
|
||||
REQUIRE_THAT(puml,
|
||||
src, IsClassTemplate("type_group_pair", "typename,typename"));
|
||||
REQUIRE_THAT(src,
|
||||
IsClassTemplate(
|
||||
"type_group_pair", "type_list<First...>,type_list<Second...>"));
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
IsClassTemplate(
|
||||
"type_group_pair", "type_list<float,double>,type_list<A,B,C>"));
|
||||
|
||||
REQUIRE_THAT(puml, IsClassTemplate("optional_ref", "T"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("optional_ref", "T"));
|
||||
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
IsClassTemplate("type_group_pair_it",
|
||||
"It,type_list<First...>,type_list<Second...>"));
|
||||
REQUIRE_THAT(
|
||||
puml, (IsMethod<Public>("get", "ref_t", "unsigned int i")));
|
||||
REQUIRE_THAT(src, (IsMethod<Public>("get", "ref_t", "unsigned int i")));
|
||||
#if LLVM_VERSION_MAJOR < 16
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
(IsMethod<Public>("getp", "value_type const*", "unsigned int i")));
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
(IsMethod<Public, Constexpr>(
|
||||
"find", "unsigned int", "value_type const& v")));
|
||||
#else
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
(IsMethod<Public>("getp", "const value_type *", "unsigned int i")));
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
(IsMethod<Public, Constexpr>(
|
||||
"find", "unsigned int", "const value_type & v")));
|
||||
|
||||
#endif
|
||||
save_puml(config.output_directory(), diagram->name + ".puml", puml);
|
||||
save_puml(config.output_directory(), diagram->name + ".puml", src);
|
||||
}
|
||||
|
||||
{
|
||||
@@ -89,8 +88,53 @@ TEST_CASE("t00064", "[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::IsMethod;
|
||||
|
||||
REQUIRE_THAT(src, !Contains("type-parameter-"));
|
||||
|
||||
REQUIRE_THAT(src, IsClass(_A("A")));
|
||||
REQUIRE_THAT(src, IsClass(_A("B")));
|
||||
REQUIRE_THAT(src, IsClass(_A("C")));
|
||||
REQUIRE_THAT(src, IsClass(_A("R")));
|
||||
|
||||
REQUIRE_THAT(src, IsClass(_A("type_list<Ts...>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("type_list<Ret(Arg &&),Ts...>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("type_list<T const,Ts...>")));
|
||||
|
||||
REQUIRE_THAT(src, IsClass(_A("head<typename>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("head<type_list<Head,Tail...>>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("type_group_pair<typename,typename>")));
|
||||
REQUIRE_THAT(src,
|
||||
IsClass(_A(
|
||||
"type_group_pair<type_list<First...>,type_list<Second...>>")));
|
||||
REQUIRE_THAT(src,
|
||||
IsClass(_A(
|
||||
"type_group_pair<type_list<float,double>,type_list<A,B,C>>")));
|
||||
|
||||
REQUIRE_THAT(src, IsClass(_A("optional_ref<T>")));
|
||||
|
||||
REQUIRE_THAT(src,
|
||||
IsClass(_A("type_group_pair_it<It,type_list<First...>,type_list<"
|
||||
"Second...>>")));
|
||||
REQUIRE_THAT(src, (IsMethod<Public>("get", "ref_t", "unsigned int i")));
|
||||
#if LLVM_VERSION_MAJOR < 16
|
||||
REQUIRE_THAT(src,
|
||||
(IsMethod<Public>("getp", "value_type const*", "unsigned int i")));
|
||||
REQUIRE_THAT(src,
|
||||
(IsMethod<Public, Constexpr>(
|
||||
"find", "unsigned int", "value_type const& v")));
|
||||
#else
|
||||
REQUIRE_THAT(src,
|
||||
(IsMethod<Public>("getp", "const value_type *", "unsigned int i")));
|
||||
REQUIRE_THAT(src,
|
||||
(IsMethod<Public, Constexpr>(
|
||||
"find", "unsigned int", "const value_type & v")));
|
||||
|
||||
#endif
|
||||
|
||||
save_mermaid(config.output_directory(), diagram->name + ".mmd", src);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user