Added mermaid test cases for class diagrams
This commit is contained in:
@@ -29,124 +29,121 @@ TEST_CASE("t00014", "[test-case][class]")
|
||||
REQUIRE(model->name() == "t00014_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, IsClassTemplate("A", "T,P"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "T,std::string"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "T,P"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "T,std::string"));
|
||||
REQUIRE_THAT(
|
||||
puml, IsClassTemplate("A", "T,std::unique_ptr<std::string>"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "double,T"));
|
||||
src, IsClassTemplate("A", "T,std::unique_ptr<std::string>"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "double,T"));
|
||||
// TODO: Figure out how to handle the same templates with different
|
||||
// template
|
||||
// parameter names
|
||||
// REQUIRE_THAT(puml, !IsClassTemplate("A", "long,U"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "long,T"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "long,bool"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "double,bool"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "long,float"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "double,float"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "bool,std::string"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "std::string,std::string"));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("A", "char,std::string"));
|
||||
REQUIRE_THAT(puml, IsClass(_A("B")));
|
||||
REQUIRE_THAT(puml, IsClassTemplate("R", "T"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "long,T"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "long,bool"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "double,bool"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "long,float"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "double,float"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "bool,std::string"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "std::string,std::string"));
|
||||
REQUIRE_THAT(src, IsClassTemplate("A", "char,std::string"));
|
||||
REQUIRE_THAT(src, IsClass(_A("B")));
|
||||
REQUIRE_THAT(src, IsClassTemplate("R", "T"));
|
||||
|
||||
REQUIRE_THAT(puml, IsField<Private>("bapair", "PairPairBA<bool>"));
|
||||
REQUIRE_THAT(puml, IsField<Private>("abool", "APtr<bool>"));
|
||||
REQUIRE_THAT(puml, IsField<Private>("aboolfloat", "AAPtr<bool,float>"));
|
||||
REQUIRE_THAT(puml, IsField<Private>("afloat", "ASharedPtr<float>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("bapair", "PairPairBA<bool>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("abool", "APtr<bool>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("aboolfloat", "AAPtr<bool,float>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("afloat", "ASharedPtr<float>"));
|
||||
REQUIRE_THAT(
|
||||
puml, IsField<Private>("boolstring", "A<bool,std::string>"));
|
||||
REQUIRE_THAT(
|
||||
puml, IsField<Private>("floatstring", "AStringPtr<float>"));
|
||||
REQUIRE_THAT(puml, IsField<Private>("atfloat", "AAPtr<T,float>"));
|
||||
src, IsField<Private>("boolstring", "A<bool,std::string>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("floatstring", "AStringPtr<float>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("atfloat", "AAPtr<T,float>"));
|
||||
|
||||
REQUIRE_THAT(puml, IsField<Private>("intstring", "AIntString"));
|
||||
REQUIRE_THAT(puml, IsField<Private>("stringstring", "AStringString"));
|
||||
REQUIRE_THAT(puml, IsField<Private>("bstringstring", "BStringString"));
|
||||
REQUIRE_THAT(src, IsField<Private>("intstring", "AIntString"));
|
||||
REQUIRE_THAT(src, IsField<Private>("stringstring", "AStringString"));
|
||||
REQUIRE_THAT(src, IsField<Private>("bstringstring", "BStringString"));
|
||||
|
||||
REQUIRE_THAT(puml, IsField<Protected>("bs", "BVector"));
|
||||
REQUIRE_THAT(src, IsField<Protected>("bs", "BVector"));
|
||||
|
||||
REQUIRE_THAT(
|
||||
puml, IsField<Public>("cb", "SimpleCallback<ACharString>"));
|
||||
REQUIRE_THAT(src, IsField<Public>("cb", "SimpleCallback<ACharString>"));
|
||||
#if LLVM_VERSION_MAJOR >= 16
|
||||
REQUIRE_THAT(
|
||||
puml, IsField<Public>("gcb", "GenericCallback<AWCharString>"));
|
||||
src, IsField<Public>("gcb", "GenericCallback<AWCharString>"));
|
||||
#else
|
||||
REQUIRE_THAT(
|
||||
puml, IsField<Public>("gcb", "GenericCallback<R::AWCharString>"));
|
||||
src, IsField<Public>("gcb", "GenericCallback<R::AWCharString>"));
|
||||
#endif
|
||||
REQUIRE_THAT(puml, IsField<Public>("vcb", "VoidCallback"));
|
||||
|
||||
REQUIRE_THAT(puml,
|
||||
!IsClassTemplate("std::std::function", "void(T...,int),int)"));
|
||||
REQUIRE_THAT(src, IsField<Public>("vcb", "VoidCallback"));
|
||||
|
||||
REQUIRE_THAT(
|
||||
puml, IsInstantiation(_A("A<T,P>"), _A("A<T,std::string>")));
|
||||
REQUIRE_THAT(
|
||||
puml, IsInstantiation(_A("A<long,T>"), _A("A<long,float>")));
|
||||
REQUIRE_THAT(
|
||||
puml, IsInstantiation(_A("A<long,T>"), _A("A<long,bool>")));
|
||||
src, !IsClassTemplate("std::std::function", "void(T...,int),int)"));
|
||||
|
||||
REQUIRE_THAT(puml, IsInstantiation(_A("A<T,P>"), _A("A<long,T>")));
|
||||
REQUIRE_THAT(
|
||||
src, IsInstantiation(_A("A<T,P>"), _A("A<T,std::string>")));
|
||||
REQUIRE_THAT(
|
||||
src, IsInstantiation(_A("A<long,T>"), _A("A<long,float>")));
|
||||
REQUIRE_THAT(src, IsInstantiation(_A("A<long,T>"), _A("A<long,bool>")));
|
||||
|
||||
REQUIRE_THAT(src, IsInstantiation(_A("A<T,P>"), _A("A<long,T>")));
|
||||
// REQUIRE_THAT(puml, !IsInstantiation(_A("A<long,T>"),
|
||||
// _A("A<long,U>")));
|
||||
REQUIRE_THAT(
|
||||
puml, IsInstantiation(_A("A<double,T>"), _A("A<double,float>")));
|
||||
src, IsInstantiation(_A("A<double,T>"), _A("A<double,float>")));
|
||||
REQUIRE_THAT(
|
||||
puml, IsInstantiation(_A("A<double,T>"), _A("A<double,bool>")));
|
||||
REQUIRE_THAT(puml, IsInstantiation(_A("A<T,P>"), _A("A<double,T>")));
|
||||
src, IsInstantiation(_A("A<double,T>"), _A("A<double,bool>")));
|
||||
REQUIRE_THAT(src, IsInstantiation(_A("A<T,P>"), _A("A<double,T>")));
|
||||
REQUIRE_THAT(
|
||||
puml, IsInstantiation(_A("A<T,P>"), _A("A<T,std::string>")));
|
||||
REQUIRE_THAT(puml,
|
||||
src, IsInstantiation(_A("A<T,P>"), _A("A<T,std::string>")));
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(_A("A<T,std::string>"), _A("A<bool,std::string>")));
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(_A("A<T,std::string>"), _A("A<char,std::string>")));
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(
|
||||
_A("A<T,std::string>"), _A("A<wchar_t,std::string>")));
|
||||
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(_A("A<T,std::unique_ptr<std::string>>"),
|
||||
_A("A<float,std::unique_ptr<std::string>>")));
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(
|
||||
_A("A<T,P>"), _A("A<T,std::unique_ptr<std::string>>")));
|
||||
|
||||
REQUIRE_THAT(puml, IsAggregation(_A("R<T>"), _A("B"), "+vps"));
|
||||
REQUIRE_THAT(puml, IsAggregation(_A("R<T>"), _A("B"), "-bapair"));
|
||||
REQUIRE_THAT(puml,
|
||||
IsAggregation(_A("R<T>"), _A("A<long,float>"), "-aboolfloat"));
|
||||
REQUIRE_THAT(src, IsAggregation(_A("R<T>"), _A("B"), "+vps"));
|
||||
REQUIRE_THAT(src, IsAggregation(_A("R<T>"), _A("B"), "-bapair"));
|
||||
REQUIRE_THAT(
|
||||
puml, IsAggregation(_A("R<T>"), _A("A<long,bool>"), "-bapair"));
|
||||
REQUIRE_THAT(puml,
|
||||
src, IsAggregation(_A("R<T>"), _A("A<long,float>"), "-aboolfloat"));
|
||||
REQUIRE_THAT(
|
||||
src, IsAggregation(_A("R<T>"), _A("A<long,bool>"), "-bapair"));
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(_A("R<T>"), _A("A<double,bool>"), "-aboolfloat"));
|
||||
REQUIRE_THAT(
|
||||
puml, IsAggregation(_A("R<T>"), _A("A<double,T>"), "-atfloat"));
|
||||
src, IsAggregation(_A("R<T>"), _A("A<double,T>"), "-atfloat"));
|
||||
REQUIRE_THAT(
|
||||
puml, IsAggregation(_A("R<T>"), _A("A<long,float>"), "-atfloat"));
|
||||
src, IsAggregation(_A("R<T>"), _A("A<long,float>"), "-atfloat"));
|
||||
REQUIRE_THAT(
|
||||
puml, IsAssociation(_A("R<T>"), _A("A<double,float>"), "-afloat"));
|
||||
REQUIRE_THAT(puml,
|
||||
src, IsAssociation(_A("R<T>"), _A("A<double,float>"), "-afloat"));
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(
|
||||
_A("R<T>"), _A("A<bool,std::string>"), "-boolstring"));
|
||||
REQUIRE_THAT(puml,
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(_A("R<T>"),
|
||||
_A("A<float,std::unique_ptr<std::string>>"), "-floatstring"));
|
||||
#if !defined(__APPLE__)
|
||||
// TODO(#176)
|
||||
REQUIRE_THAT(puml, IsDependency(_A("R<T>"), _A("A<char,std::string>")));
|
||||
REQUIRE_THAT(src, IsDependency(_A("R<T>"), _A("A<char,std::string>")));
|
||||
REQUIRE_THAT(
|
||||
puml, IsDependency(_A("R<T>"), _A("A<wchar_t,std::string>")));
|
||||
src, IsDependency(_A("R<T>"), _A("A<wchar_t,std::string>")));
|
||||
#endif
|
||||
|
||||
save_puml(config.output_directory(), diagram->name + ".puml", puml);
|
||||
save_puml(config.output_directory(), diagram->name + ".puml", src);
|
||||
}
|
||||
{
|
||||
auto j = generate_class_json(diagram, *model);
|
||||
@@ -171,8 +168,118 @@ TEST_CASE("t00014", "[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::IsField;
|
||||
|
||||
REQUIRE_THAT(src, !Contains("type-parameter-"));
|
||||
|
||||
REQUIRE_THAT(src, IsClass(_A("A<T,P>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<T,std::string>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<T,std::unique_ptr<std::string>>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<double,T>")));
|
||||
// TODO: Figure out how to handle the same templates with different
|
||||
// template
|
||||
// parameter names
|
||||
// REQUIRE_THAT(puml, !IsClass("A", "long,U"));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<long,T>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<long,bool>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<double,bool>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<long,float>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<double,float>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<bool,std::string>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<std::string,std::string>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("A<char,std::string>")));
|
||||
REQUIRE_THAT(src, IsClass(_A("B")));
|
||||
REQUIRE_THAT(src, IsClass(_A("R<T>")));
|
||||
|
||||
REQUIRE_THAT(src, IsField<Private>("bapair", "PairPairBA<bool>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("abool", "APtr<bool>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("aboolfloat", "AAPtr<bool,float>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("afloat", "ASharedPtr<float>"));
|
||||
REQUIRE_THAT(
|
||||
src, IsField<Private>("boolstring", "A<bool,std::string>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("floatstring", "AStringPtr<float>"));
|
||||
REQUIRE_THAT(src, IsField<Private>("atfloat", "AAPtr<T,float>"));
|
||||
|
||||
REQUIRE_THAT(src, IsField<Private>("intstring", "AIntString"));
|
||||
REQUIRE_THAT(src, IsField<Private>("stringstring", "AStringString"));
|
||||
REQUIRE_THAT(src, IsField<Private>("bstringstring", "BStringString"));
|
||||
|
||||
REQUIRE_THAT(src, IsField<Protected>("bs", "BVector"));
|
||||
|
||||
REQUIRE_THAT(src, IsField<Public>("cb", "SimpleCallback<ACharString>"));
|
||||
#if LLVM_VERSION_MAJOR >= 16
|
||||
REQUIRE_THAT(
|
||||
src, IsField<Public>("gcb", "GenericCallback<AWCharString>"));
|
||||
#else
|
||||
REQUIRE_THAT(
|
||||
src, IsField<Public>("gcb", "GenericCallback<R::AWCharString>"));
|
||||
#endif
|
||||
REQUIRE_THAT(src, IsField<Public>("vcb", "VoidCallback"));
|
||||
|
||||
REQUIRE_THAT(
|
||||
src, !IsClassTemplate("std::std::function", "void(T...,int),int)"));
|
||||
|
||||
REQUIRE_THAT(
|
||||
src, IsInstantiation(_A("A<T,P>"), _A("A<T,std::string>")));
|
||||
REQUIRE_THAT(
|
||||
src, IsInstantiation(_A("A<long,T>"), _A("A<long,float>")));
|
||||
REQUIRE_THAT(src, IsInstantiation(_A("A<long,T>"), _A("A<long,bool>")));
|
||||
|
||||
REQUIRE_THAT(src, IsInstantiation(_A("A<T,P>"), _A("A<long,T>")));
|
||||
// REQUIRE_THAT(puml, !IsInstantiation(_A("A<long,T>"),
|
||||
// _A("A<long,U>")));
|
||||
REQUIRE_THAT(
|
||||
src, IsInstantiation(_A("A<double,T>"), _A("A<double,float>")));
|
||||
REQUIRE_THAT(
|
||||
src, IsInstantiation(_A("A<double,T>"), _A("A<double,bool>")));
|
||||
REQUIRE_THAT(src, IsInstantiation(_A("A<T,P>"), _A("A<double,T>")));
|
||||
REQUIRE_THAT(
|
||||
src, IsInstantiation(_A("A<T,P>"), _A("A<T,std::string>")));
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(_A("A<T,std::string>"), _A("A<bool,std::string>")));
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(_A("A<T,std::string>"), _A("A<char,std::string>")));
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(
|
||||
_A("A<T,std::string>"), _A("A<wchar_t,std::string>")));
|
||||
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(_A("A<T,std::unique_ptr<std::string>>"),
|
||||
_A("A<float,std::unique_ptr<std::string>>")));
|
||||
REQUIRE_THAT(src,
|
||||
IsInstantiation(
|
||||
_A("A<T,P>"), _A("A<T,std::unique_ptr<std::string>>")));
|
||||
|
||||
REQUIRE_THAT(src, IsAggregation(_A("R<T>"), _A("B"), "+vps"));
|
||||
REQUIRE_THAT(src, IsAggregation(_A("R<T>"), _A("B"), "-bapair"));
|
||||
REQUIRE_THAT(
|
||||
src, IsAggregation(_A("R<T>"), _A("A<long,float>"), "-aboolfloat"));
|
||||
REQUIRE_THAT(
|
||||
src, IsAggregation(_A("R<T>"), _A("A<long,bool>"), "-bapair"));
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(_A("R<T>"), _A("A<double,bool>"), "-aboolfloat"));
|
||||
REQUIRE_THAT(
|
||||
src, IsAggregation(_A("R<T>"), _A("A<double,T>"), "-atfloat"));
|
||||
REQUIRE_THAT(
|
||||
src, IsAggregation(_A("R<T>"), _A("A<long,float>"), "-atfloat"));
|
||||
REQUIRE_THAT(
|
||||
src, IsAssociation(_A("R<T>"), _A("A<double,float>"), "-afloat"));
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(
|
||||
_A("R<T>"), _A("A<bool,std::string>"), "-boolstring"));
|
||||
REQUIRE_THAT(src,
|
||||
IsAggregation(_A("R<T>"),
|
||||
_A("A<float,std::unique_ptr<std::string>>"), "-floatstring"));
|
||||
#if !defined(__APPLE__)
|
||||
// TODO(#176)
|
||||
REQUIRE_THAT(src, IsDependency(_A("R<T>"), _A("A<char,std::string>")));
|
||||
REQUIRE_THAT(
|
||||
src, IsDependency(_A("R<T>"), _A("A<wchar_t,std::string>")));
|
||||
#endif
|
||||
|
||||
save_mermaid(config.output_directory(), diagram->name + ".mmd", src);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user