Refactoring sequence diagrams test cases (#266)

This commit is contained in:
Bartek Kryza
2024-05-16 21:58:45 +02:00
parent 5d69f5063a
commit 7c1e0420c6
49 changed files with 2807 additions and 1576 deletions

View File

@@ -16,62 +16,77 @@
* limitations under the License.
*/
TEST_CASE("t20016", "[test-case][sequence]")
TEST_CASE("t20016")
{
auto [config, db] = load_config("t20016");
using namespace clanguml::test;
auto diagram = config.diagrams["t20016_sequence"];
auto [config, db, diagram, model] =
CHECK_SEQUENCE_MODEL("t20016", "t20016_sequence");
REQUIRE(diagram->name == "t20016_sequence");
CHECK_SEQUENCE_DIAGRAM(config, diagram, *model, [](const auto &src) {
REQUIRE(MessageOrder(src,
{
//
{"tmain()", "B<long>", "b1(long)"}, //
{"B<long>", "A", "a1(int)"}, //
{"tmain()", "B<long>", "b2(long)"}, //
{"B<long>", "A", "a2(const long &)"} //
}));
});
/*
{
auto src = generate_sequence_puml(diagram, *model);
AliasMatcher _A(src);
auto model = generate_sequence_diagram(*db, diagram);
REQUIRE_THAT(src, StartsWith("@startuml"));
REQUIRE_THAT(src, EndsWith("@enduml\n"));
REQUIRE(model->name() == "t20016_sequence");
{
auto src = generate_sequence_puml(diagram, *model);
AliasMatcher _A(src);
// Check if all calls exist
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B<long>"),
"b1(long)")); REQUIRE_THAT(src, HasCall(_A("B<long>"), _A("A"),
"a1(int)"));
REQUIRE_THAT(src, StartsWith("@startuml"));
REQUIRE_THAT(src, EndsWith("@enduml\n"));
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B<long>"),
"b2(long)")); REQUIRE_THAT(src, HasCall(_A("B<long>"), _A("A"),
"a2(const long &)"));
// Check if all calls exist
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B<long>"), "b1(long)"));
REQUIRE_THAT(src, HasCall(_A("B<long>"), _A("A"), "a1(int)"));
save_puml(config.output_directory(), diagram->name + ".puml",
src);
}
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B<long>"), "b2(long)"));
REQUIRE_THAT(src, HasCall(_A("B<long>"), _A("A"), "a2(const long &)"));
{
auto j = generate_sequence_json(diagram, *model);
save_puml(config.output_directory(), diagram->name + ".puml", src);
}
using namespace json;
{
auto j = generate_sequence_json(diagram, *model);
std::vector<int> messages = {
FindMessage(j, "tmain()", "B<long>", "b1(long)"),
FindMessage(j, "B<long>", "A", "a1(int)"),
FindMessage(j, "tmain()", "B<long>", "b2(long)"),
FindMessage(j, "B<long>", "A", "a2(const long &)")};
using namespace json;
REQUIRE(std::is_sorted(messages.begin(), messages.end()));
std::vector<int> messages = {
FindMessage(j, "tmain()", "B<long>", "b1(long)"),
FindMessage(j, "B<long>", "A", "a1(int)"),
FindMessage(j, "tmain()", "B<long>", "b2(long)"),
FindMessage(j, "B<long>", "A", "a2(const long &)")};
save_json(config.output_directory(), diagram->name + ".json",
j);
}
REQUIRE(std::is_sorted(messages.begin(), messages.end()));
{
auto src = generate_sequence_mermaid(diagram, *model);
save_json(config.output_directory(), diagram->name + ".json", j);
}
mermaid::SequenceDiagramAliasMatcher _A(src);
using mermaid::HasCall;
{
auto src = generate_sequence_mermaid(diagram, *model);
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B<long>"),
"b1(long)")); REQUIRE_THAT(src, HasCall(_A("B<long>"), _A("A"),
"a1(int)"));
mermaid::SequenceDiagramAliasMatcher _A(src);
using mermaid::HasCall;
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B<long>"),
"b2(long)")); REQUIRE_THAT(src, HasCall(_A("B<long>"), _A("A"),
"a2(const long &)"));
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B<long>"), "b1(long)"));
REQUIRE_THAT(src, HasCall(_A("B<long>"), _A("A"), "a1(int)"));
REQUIRE_THAT(src, HasCall(_A("tmain()"), _A("B<long>"), "b2(long)"));
REQUIRE_THAT(src, HasCall(_A("B<long>"), _A("A"), "a2(const long &)"));
save_mermaid(config.output_directory(), diagram->name + ".mmd", src);
}
save_mermaid(config.output_directory(), diagram->name + ".mmd",
src);
}
*/
}