/** * tests/t20036/test_case.h * * Copyright (c) 2021-2024 Bartek Kryza * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ TEST_CASE("t20036") { using namespace clanguml::test; auto [config, db, diagram, model] = CHECK_SEQUENCE_MODEL("t20036", "t20036_sequence"); CHECK_SEQUENCE_DIAGRAM(config, diagram, *model, [](const auto &src) { REQUIRE(MessageChainsOrder(src, { // { // {Entrypoint{}, "C", "c1()"}, // {"C", "B", "b1()"}, // {"B", "A", "a2()"}, // }, // { // {Entrypoint{}, "D", "d1()"}, // {"D", "C", "c2()"}, // {"C", "B", "b2()"}, // {"B", "A", "a2()"}, // }, // { // {Entrypoint{}, "D", "d3()"}, // {"D", "A", "a2()"}, // }, // { // {Entrypoint{}, "C", "c4()"}, // {"C", "B", "b2()"}, // {"B", "A", "a2()"}, // }, // { // {Entrypoint{}, "C", "c3()"}, // {"C", "C", "c2()"}, // {"C", "B", "b2()"}, // {"B", "A", "a2()"}, // }, // { // {Entrypoint{}, "D", "d2()"}, // {"D", "C", "c2()"}, // {"C", "B", "b2()"}, // {"B", "A", "a2()"}, // }, // })); }); /* { auto src = generate_sequence_puml(diagram, *model); AliasMatcher _A(src); REQUIRE_THAT(src, StartsWith("@startuml")); REQUIRE_THAT(src, EndsWith("@enduml\n")); REQUIRE_THAT(src, HasCall(_A("C"), _A("C"), "c2()")); REQUIRE_THAT(src, HasCall(_A("C"), _A("B"), "b2()")); REQUIRE_THAT(src, HasCall(_A("B"), _A("A"), "a2()")); REQUIRE_THAT(src, HasCall(_A("C"), _A("B"), "b2()")); REQUIRE_THAT(src, HasCall(_A("B"), _A("A"), "a2()")); REQUIRE_THAT(src, HasCall(_A("D"), _A("A"), "a2()")); REQUIRE_THAT(src, HasCall(_A("C"), _A("B"), "b1()")); REQUIRE_THAT(src, HasCall(_A("B"), _A("A"), "a2()")); save_puml(config.output_directory(), diagram->name + ".puml", src); } { auto j = generate_sequence_json(diagram, *model); using namespace json; REQUIRE(HasMessageChain(j, {{"c3()", "c2()", "void"}, {"c2()", "b2()", "void"}, {"b2()", "a2()", "void"}})); REQUIRE(HasMessageChain( j, {{"c4()", "b2()", "void"}, {"b2()", "a2()", "void"}})); REQUIRE(HasMessageChain(j, {{"d3()", "a2()", "void"}})); REQUIRE(HasMessageChain(j, {{"d1()", "c2()", "void"}, {"c2()", "b2()", "void"}, {"b2()", "a2()", "void"}})); REQUIRE(HasMessageChain( j, {{"c1()", "b1()", "void"}, {"b1()", "a2()", "void"}})); save_json(config.output_directory(), diagram->name + ".json", j); } { auto src = generate_sequence_mermaid(diagram, *model); mermaid::SequenceDiagramAliasMatcher _A(src); using mermaid::HasCall; REQUIRE_THAT(src, HasCall(_A("C"), _A("C"), "c2()")); REQUIRE_THAT(src, HasCall(_A("C"), _A("B"), "b2()")); REQUIRE_THAT(src, HasCall(_A("B"), _A("A"), "a2()")); REQUIRE_THAT(src, HasCall(_A("C"), _A("B"), "b2()")); REQUIRE_THAT(src, HasCall(_A("B"), _A("A"), "a2()")); REQUIRE_THAT(src, HasCall(_A("D"), _A("A"), "a2()")); REQUIRE_THAT(src, HasCall(_A("C"), _A("B"), "b1()")); REQUIRE_THAT(src, HasCall(_A("B"), _A("A"), "a2()")); save_mermaid(config.output_directory(), diagram->name + ".mmd", src); }*/ }