diff --git a/data/osm_test_data/nikolaevka_village.osm b/data/osm_test_data/nikolaevka_village.osm
new file mode 100644
index 0000000000..95f95b6e0e
--- /dev/null
+++ b/data/osm_test_data/nikolaevka_village.osm
@@ -0,0 +1,354 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/data/osm_test_data/novenkoe_village.osm b/data/osm_test_data/novenkoe_village.osm
new file mode 100644
index 0000000000..c7d51ea416
--- /dev/null
+++ b/data/osm_test_data/novenkoe_village.osm
@@ -0,0 +1,386 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/generator/generator_tests/raw_generator_test.cpp b/generator/generator_tests/raw_generator_test.cpp
index dc086bcfc1..de5023bab6 100644
--- a/generator/generator_tests/raw_generator_test.cpp
+++ b/generator/generator_tests/raw_generator_test.cpp
@@ -415,36 +415,53 @@ UNIT_CLASS_TEST(TestRawGenerator, Postcode_Relations)
TEST_EQUAL(count, 2, ());
}
-UNIT_CLASS_TEST(TestRawGenerator, Relation_Wiki)
+// https://github.com/organicmaps/organicmaps/issues/4974
+UNIT_TEST(Relation_Wiki)
{
std::string const mwmName = "Relation";
- BuildFB("./data/osm_test_data/village_relation.osm", mwmName);
+ std::string const arrFiles[] = {
+ "./data/osm_test_data/village_relation.osm",
+ "./data/osm_test_data/novenkoe_village.osm",
+ "./data/osm_test_data/nikolaevka_village.osm",
+ };
- uint32_t const villageType = classif().GetTypeByPath({"place", "village"});
+ std::string const arrWiki[] = {
+ "fr:Charmois-l'Orgueilleux",
+ "ru:Новенькое (Локтевский район)",
+ "ru:Николаевка (Локтевский район)",
+ };
- size_t count = 0;
- ForEachFB(mwmName, [&](feature::FeatureBuilder const & fb)
+ for (size_t i = 0; i < std::size(arrFiles); ++i)
{
- switch (fb.GetGeomType())
- {
- case feature::GeomType::Point:
- {
- TEST(fb.HasType(villageType), ());
- ++count;
- TEST_EQUAL(fb.GetMetadata().Get(feature::Metadata::FMD_WIKIPEDIA),
- "fr:Charmois-l'Orgueilleux", ());
- break;
- }
- case feature::GeomType::Line:
- {
- TEST(fb.GetMetadata().Get(feature::Metadata::FMD_WIKIPEDIA).empty(), ());
- break;
- }
- }
- });
+ TestRawGenerator generator;
- TEST_EQUAL(count, 1, ());
+ uint32_t const villageType = classif().GetTypeByPath({"place", "village"});
+
+ generator.BuildFB(arrFiles[i], mwmName);
+
+ size_t count = 0;
+ generator.ForEachFB(mwmName, [&](feature::FeatureBuilder const & fb)
+ {
+ switch (fb.GetGeomType())
+ {
+ case feature::GeomType::Point:
+ {
+ TEST(fb.HasType(villageType), ());
+ ++count;
+ TEST_EQUAL(fb.GetMetadata().Get(feature::Metadata::FMD_WIKIPEDIA), arrWiki[i], ());
+ break;
+ }
+ case feature::GeomType::Line:
+ {
+ TEST(fb.GetMetadata().Get(feature::Metadata::FMD_WIKIPEDIA).empty(), ());
+ break;
+ }
+ }
+ });
+
+ TEST_EQUAL(count, 1, ());
+ }
}
UNIT_CLASS_TEST(TestRawGenerator, AssociatedStreet_Wiki)
diff --git a/generator/place_processor.cpp b/generator/place_processor.cpp
index 69bae46b84..393bd38285 100644
--- a/generator/place_processor.cpp
+++ b/generator/place_processor.cpp
@@ -93,6 +93,10 @@ bool IsWorsePlace(FeaturePlace const & left, FeaturePlace const & right)
if (type == ftypes::LocalityType::City)
return area > 1e10;
+ /// @todo By VNG: It doesn't work with updated heuristic when collecting boundaries.
+ /// Should connect (by name) Node and Way places to select best boundary (like with Relations).
+ /// @see Relation_Wiki test.
+ /*
// ~14*14 km
if (type == ftypes::LocalityType::Town)
return area > 2e8;
@@ -100,6 +104,7 @@ bool IsWorsePlace(FeaturePlace const & left, FeaturePlace const & right)
// 10*10 km
if (type == ftypes::LocalityType::Village)
return area > 1e8;
+ */
return false;
};