Added test case for paths include filter (Fixes #113)
This commit is contained in:
@@ -64,7 +64,8 @@ bool diagram::should_include(const element &e) const
|
|||||||
if (filter_.get() == nullptr)
|
if (filter_.get() == nullptr)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
return filter_->should_include(e);
|
return filter_->should_include(e) &&
|
||||||
|
filter_->should_include(dynamic_cast<const source_location &>(e));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool diagram::should_include(const std::string &name) const
|
bool diagram::should_include(const std::string &name) const
|
||||||
|
|||||||
@@ -121,6 +121,12 @@ tvl::value_t filter_visitor::match(
|
|||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tvl::value_t filter_visitor::match(
|
||||||
|
const diagram & /*d*/, const common::model::source_location & /*f*/) const
|
||||||
|
{
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
bool filter_visitor::is_inclusive() const
|
bool filter_visitor::is_inclusive() const
|
||||||
{
|
{
|
||||||
return type_ == filter_t::kInclusive;
|
return type_ == filter_t::kInclusive;
|
||||||
@@ -413,7 +419,7 @@ paths_filter::paths_filter(filter_t type, const std::filesystem::path &root,
|
|||||||
}
|
}
|
||||||
catch (std::filesystem::filesystem_error &e) {
|
catch (std::filesystem::filesystem_error &e) {
|
||||||
LOG_WARN("Cannot add non-existent path {} to paths filter",
|
LOG_WARN("Cannot add non-existent path {} to paths filter",
|
||||||
path.string());
|
absolute_path.string());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -447,6 +453,31 @@ tvl::value_t paths_filter::match(
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tvl::value_t paths_filter::match(
|
||||||
|
const diagram & /*d*/, const common::model::source_location &p) const
|
||||||
|
{
|
||||||
|
if (paths_.empty()) {
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
|
auto sl_path = std::filesystem::path{p.file()};
|
||||||
|
|
||||||
|
// Matching source paths doesn't make sens if they are not absolute or empty
|
||||||
|
if (p.file().empty() || sl_path.is_relative()) {
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
|
for (const auto &path : paths_) {
|
||||||
|
if (sl_path.root_name().string() == path.root_name().string() &&
|
||||||
|
util::starts_with(sl_path.relative_path(), path.relative_path())) {
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
diagram_filter::diagram_filter(
|
diagram_filter::diagram_filter(
|
||||||
const common::model::diagram &d, const config::diagram &c)
|
const common::model::diagram &d, const config::diagram &c)
|
||||||
: diagram_{d}
|
: diagram_{d}
|
||||||
|
|||||||
@@ -75,6 +75,9 @@ public:
|
|||||||
virtual tvl::value_t match(
|
virtual tvl::value_t match(
|
||||||
const diagram &d, const common::model::source_file &f) const;
|
const diagram &d, const common::model::source_file &f) const;
|
||||||
|
|
||||||
|
virtual tvl::value_t match(
|
||||||
|
const diagram &d, const common::model::source_location &f) const;
|
||||||
|
|
||||||
bool is_inclusive() const;
|
bool is_inclusive() const;
|
||||||
bool is_exclusive() const;
|
bool is_exclusive() const;
|
||||||
|
|
||||||
@@ -332,6 +335,9 @@ struct paths_filter : public filter_visitor {
|
|||||||
tvl::value_t match(
|
tvl::value_t match(
|
||||||
const diagram &d, const common::model::source_file &r) const override;
|
const diagram &d, const common::model::source_file &r) const override;
|
||||||
|
|
||||||
|
tvl::value_t match(const diagram &d,
|
||||||
|
const common::model::source_location &sl) const override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::vector<std::filesystem::path> paths_;
|
std::vector<std::filesystem::path> paths_;
|
||||||
std::filesystem::path root_;
|
std::filesystem::path root_;
|
||||||
|
|||||||
@@ -400,6 +400,7 @@ template <> struct convert<class_diagram> {
|
|||||||
get_option(node, rhs.generate_packages);
|
get_option(node, rhs.generate_packages);
|
||||||
get_option(node, rhs.relationship_hints);
|
get_option(node, rhs.relationship_hints);
|
||||||
get_option(node, rhs.type_aliases);
|
get_option(node, rhs.type_aliases);
|
||||||
|
get_option(node, rhs.relative_to);
|
||||||
get_option(node, rhs.comment_parser);
|
get_option(node, rhs.comment_parser);
|
||||||
|
|
||||||
rhs.initialize_relationship_hints();
|
rhs.initialize_relationship_hints();
|
||||||
|
|||||||
15
tests/t00061/.clang-uml
Normal file
15
tests/t00061/.clang-uml
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
compilation_database_dir: ..
|
||||||
|
output_directory: puml
|
||||||
|
diagrams:
|
||||||
|
t00061_class:
|
||||||
|
type: class
|
||||||
|
relative_to: ../../tests/t00061
|
||||||
|
glob:
|
||||||
|
- t00061.cc
|
||||||
|
include:
|
||||||
|
namespaces:
|
||||||
|
- clanguml::t00061
|
||||||
|
paths:
|
||||||
|
- include/t00061_a.h
|
||||||
|
using_namespace:
|
||||||
|
- clanguml::t00061
|
||||||
5
tests/t00061/include/t00061_a.h
Normal file
5
tests/t00061/include/t00061_a.h
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
namespace clanguml {
|
||||||
|
namespace t00061 {
|
||||||
|
struct A { };
|
||||||
|
}
|
||||||
|
}
|
||||||
5
tests/t00061/include/t00061_b.h
Normal file
5
tests/t00061/include/t00061_b.h
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
namespace clanguml {
|
||||||
|
namespace t00061 {
|
||||||
|
struct B { };
|
||||||
|
}
|
||||||
|
}
|
||||||
11
tests/t00061/t00061.cc
Normal file
11
tests/t00061/t00061.cc
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
#include "include/t00061_a.h"
|
||||||
|
#include "include/t00061_b.h"
|
||||||
|
|
||||||
|
namespace clanguml {
|
||||||
|
namespace t00061 {
|
||||||
|
struct C {
|
||||||
|
A *a;
|
||||||
|
B *b;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
58
tests/t00061/test_case.h
Normal file
58
tests/t00061/test_case.h
Normal file
@@ -0,0 +1,58 @@
|
|||||||
|
/**
|
||||||
|
* tests/t00061/test_case.h
|
||||||
|
*
|
||||||
|
* Copyright (c) 2021-2023 Bartek Kryza <bkryza@gmail.com>
|
||||||
|
*
|
||||||
|
* 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("t00061", "[test-case][class]")
|
||||||
|
{
|
||||||
|
auto [config, db] = load_config("t00061");
|
||||||
|
|
||||||
|
auto diagram = config.diagrams["t00061_class"];
|
||||||
|
|
||||||
|
REQUIRE(diagram->name == "t00061_class");
|
||||||
|
|
||||||
|
auto model = generate_class_diagram(*db, diagram);
|
||||||
|
|
||||||
|
REQUIRE(model->name() == "t00061_class");
|
||||||
|
|
||||||
|
{
|
||||||
|
auto puml = generate_class_puml(diagram, *model);
|
||||||
|
AliasMatcher _A(puml);
|
||||||
|
|
||||||
|
REQUIRE_THAT(puml, StartsWith("@startuml"));
|
||||||
|
REQUIRE_THAT(puml, EndsWith("@enduml\n"));
|
||||||
|
|
||||||
|
// Check if all classes exist
|
||||||
|
REQUIRE_THAT(puml, IsClass(_A("A")));
|
||||||
|
REQUIRE_THAT(puml, !IsClass(_A("B")));
|
||||||
|
REQUIRE_THAT(puml, !IsClass(_A("C")));
|
||||||
|
|
||||||
|
save_puml(
|
||||||
|
config.output_directory() + "/" + diagram->name + ".puml", puml);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
auto j = generate_class_json(diagram, *model);
|
||||||
|
|
||||||
|
using namespace json;
|
||||||
|
|
||||||
|
REQUIRE(IsClass(j, "A"));
|
||||||
|
REQUIRE(!IsClass(j, "B"));
|
||||||
|
REQUIRE(!IsClass(j, "C"));
|
||||||
|
|
||||||
|
save_json(config.output_directory() + "/" + diagram->name + ".json", j);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -300,6 +300,7 @@ using namespace clanguml::test::matchers;
|
|||||||
#include "t00059/test_case.h"
|
#include "t00059/test_case.h"
|
||||||
#endif
|
#endif
|
||||||
#include "t00060/test_case.h"
|
#include "t00060/test_case.h"
|
||||||
|
#include "t00061/test_case.h"
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Sequence diagram tests
|
/// Sequence diagram tests
|
||||||
|
|||||||
@@ -28,13 +28,25 @@ TEST_CASE("{{ name }}", "[test-case][{{ type }}]")
|
|||||||
|
|
||||||
REQUIRE(model->name() == "{{ name }}_{{ type }}");
|
REQUIRE(model->name() == "{{ name }}_{{ type }}");
|
||||||
|
|
||||||
auto puml = generate_{{ type }}_puml(diagram, *model);
|
{
|
||||||
AliasMatcher _A(puml);
|
auto puml = generate_{{ type }}_puml(diagram, *model);
|
||||||
|
AliasMatcher _A(puml);
|
||||||
|
|
||||||
REQUIRE_THAT(puml, StartsWith("@startuml"));
|
REQUIRE_THAT(puml, StartsWith("@startuml"));
|
||||||
REQUIRE_THAT(puml, EndsWith("@enduml\n"));
|
REQUIRE_THAT(puml, EndsWith("@enduml\n"));
|
||||||
|
|
||||||
{{ examples }}
|
{{ examples }}
|
||||||
|
|
||||||
|
save_puml(
|
||||||
|
config.output_directory() + "/" + diagram->name + ".puml", puml);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
auto j = generate_class_json(diagram, *model);
|
||||||
|
|
||||||
|
using namespace json;
|
||||||
|
|
||||||
|
save_json(config.output_directory() + "/" + diagram->name + ".json", j);
|
||||||
|
}
|
||||||
|
|
||||||
save_puml(config.output_directory() + "/" + diagram->name + ".puml", puml);
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user