Fixing restriction_test and making them workable with osm ids to second stage feature ids binary mapping file.

This commit is contained in:
Vladimir Byko-Ianko 2016-11-15 08:40:56 +03:00
parent 7ad4551e4c
commit e995ce1d39
2 changed files with 64 additions and 28 deletions

View file

@ -3,6 +3,7 @@
#include "generator/generator_tests_support/test_feature.hpp"
#include "generator/generator_tests_support/test_mwm_builder.hpp"
#include "generator/gen_mwm_info.hpp"
#include "generator/restriction_collector.hpp"
#include "generator/restriction_generator.hpp"
@ -12,6 +13,7 @@
#include "indexer/mwm_set.hpp"
#include "coding/file_name_utils.hpp"
#include "coding/file_writer.hpp"
#include "platform/platform_tests_support/scoped_dir.hpp"
#include "platform/platform_tests_support/scoped_file.hpp"
@ -21,7 +23,9 @@
#include "base/logging.hpp"
#include "base/scope_guard.hpp"
#include "base/string_utils.hpp"
#include "std/utility.hpp"
#include "std/string.hpp"
using namespace feature;
@ -37,17 +41,47 @@ string const kTestDir = "restriction_generation_test";
// Temporary mwm name for testing.
string const kTestMwm = "test";
string const kRestrictionFileName = "restrictions_in_osm_ids.csv";
string const featureId2OsmIdsName = "feature_id_to_osm_ids.csv";
string const kOsmIdsToFeatureIdsName = "osm_ids_to_feature_ids" OSM2FEATURE_FILE_EXTENSION;
void BuildEmptyMwm(LocalCountryFile & country)
{
generator::tests_support::TestMwmBuilder builder(country, feature::DataHeader::country);
}
/// \brief Generates a binary file with by a string with mapping from osm ids to feature ids.
/// \param mappingContent a string with lines with mapping from osm id to feature id (one to one).
/// For example
/// 10, 1,
/// 20, 2
/// 30, 3,
/// 40, 4
/// \parma outputFilePath full path to an output file where the mapping is saved.
void GenerateOsmIdsToFeatureIdsMapping(string const & mappingContent, string const & outputFilePath)
{
strings::SimpleTokenizer lineIter(mappingContent, "\n\r" /* string delimiter */);
gen::Accumulator<pair<uint64_t, uint32_t>> osmIdsToFeatureIds;
for (; lineIter; ++lineIter)
{
strings::SimpleTokenizer idIter(*lineIter, ", \t" /* id delimiter */);
uint64_t osmId = 0;
TEST(strings::to_uint64(*idIter, osmId), ("Cannot covert to uint64_t:", *idIter));
TEST(idIter, ("Wrong feature ids to osm ids mapping."));
++idIter;
uint32_t featureId = 0;
TEST(strings::to_uint(*idIter, featureId), ("Cannot covert to uint:", *idIter));
osmIdsToFeatureIds.Add(make_pair(osmId, featureId));
}
FileWriter osm2ftWriter(outputFilePath);
osmIdsToFeatureIds.Flush(osm2ftWriter);
}
/// \brief Generates a restriction section, adds it to an empty mwm,
/// loads the restriction section and test loaded restrictions.
/// \param restrictionContent comma separated text with restrictions in osm id terms.
/// \param mappingContent comma separated text with with mapping from feature ids to osm ids.
/// \param mappingContent comma separated text with with mapping from osm ids to feature ids.
void TestRestrictionBuilding(string const & restrictionContent, string const & mappingContent)
{
Platform & platform = GetPlatform();
@ -60,16 +94,18 @@ void TestRestrictionBuilding(string const & restrictionContent, string const & m
ScopedFile const scopedMwm(mwmRelativePath);
BuildEmptyMwm(country);
// Creating files with restrictions.
// Creating a file with restrictions.
string const restrictionRelativePath = my::JoinFoldersToPath(kTestDir, kRestrictionFileName);
ScopedFile const restrictionScopedFile(restrictionRelativePath, restrictionContent);
string const mappingRelativePath = my::JoinFoldersToPath(kTestDir, featureId2OsmIdsName);
ScopedFile const mappingScopedFile(mappingRelativePath, mappingContent);
// Creating osm ids to feature ids mapping.
string const mappingRelativePath = my::JoinFoldersToPath(kTestDir, kOsmIdsToFeatureIdsName);
ScopedFile const mappingScopedFile(mappingRelativePath);
string const mappingFullPath = my::JoinFoldersToPath(writableDir, mappingRelativePath);
GenerateOsmIdsToFeatureIdsMapping(mappingContent, mappingFullPath);
// Adding restriction section to mwm.
string const restrictionFullPath = my::JoinFoldersToPath(writableDir, restrictionRelativePath);
string const mappingFullPath = my::JoinFoldersToPath(writableDir, mappingRelativePath);
string const mwmFullPath = my::JoinFoldersToPath(writableDir, mwmRelativePath);
BuildRoadRestrictions(mwmFullPath, restrictionFullPath, mappingFullPath);
@ -89,22 +125,22 @@ void TestRestrictionBuilding(string const & restrictionContent, string const & m
UNIT_TEST(RestrictionGenerationTest_NoRestriction)
{
string const restrictionContent = "";
string const featureIdToOsmIdsContent = "";
TestRestrictionBuilding(restrictionContent, featureIdToOsmIdsContent);
string const osmIdsToFeatureIdsContent = "";
TestRestrictionBuilding(restrictionContent, osmIdsToFeatureIdsContent);
}
UNIT_TEST(RestrictionGenerationTest_ZeroId)
{
string const restrictionContent = R"(Only, 0, 0,)";
string const featureIdToOsmIdsContent = R"(0, 0,)";
TestRestrictionBuilding(restrictionContent, featureIdToOsmIdsContent);
string const osmIdsToFeatureIdsContent = R"(0, 0,)";
TestRestrictionBuilding(restrictionContent, osmIdsToFeatureIdsContent);
}
UNIT_TEST(RestrictionGenerationTest_OneRestriction)
{
string const restrictionContent = R"(No, 10, 10,)";
string const featureIdToOsmIdsContent = R"(1, 10,)";
TestRestrictionBuilding(restrictionContent, featureIdToOsmIdsContent);
string const osmIdsToFeatureIdsContent = R"(10, 1,)";
TestRestrictionBuilding(restrictionContent, osmIdsToFeatureIdsContent);
}
UNIT_TEST(RestrictionGenerationTest_ThreeRestrictions)
@ -112,11 +148,11 @@ UNIT_TEST(RestrictionGenerationTest_ThreeRestrictions)
string const restrictionContent = R"(No, 10, 10,
Only, 10, 20
Only, 30, 40)";
string const featureIdToOsmIdsContent = R"(1, 10,
2, 20
3, 30,
4, 40)";
TestRestrictionBuilding(restrictionContent, featureIdToOsmIdsContent);
string const osmIdsToFeatureIdsContent = R"(10, 1,
20, 2
30, 3,
40, 4)";
TestRestrictionBuilding(restrictionContent, osmIdsToFeatureIdsContent);
}
UNIT_TEST(RestrictionGenerationTest_SevenRestrictions)
@ -128,11 +164,11 @@ UNIT_TEST(RestrictionGenerationTest_SevenRestrictions)
No, 30, 30,
No, 40, 40,
Only, 30, 40,)";
string const featureIdToOsmIdsContent = R"(1, 10,
2, 20,
3, 30,
4, 40)";
TestRestrictionBuilding(restrictionContent, featureIdToOsmIdsContent);
string const osmIdsToFeatureIdsContent = R"(10, 1,
20, 2,
30, 3,
40, 4)";
TestRestrictionBuilding(restrictionContent, osmIdsToFeatureIdsContent);
}
UNIT_TEST(RestrictionGenerationTest_ThereAndMoreLinkRestrictions)
@ -141,10 +177,10 @@ UNIT_TEST(RestrictionGenerationTest_ThereAndMoreLinkRestrictions)
No, 20, 20,
Only, 10, 20, 30, 40
Only, 20, 30, 40)";
string const featureIdToOsmIdsContent = R"(1, 10,
2, 20,
3, 30,
4, 40)";
TestRestrictionBuilding(restrictionContent, featureIdToOsmIdsContent);
string const osmIdsToFeatureIdsContent = R"(10, 1,
20, 2,
30, 3,
40, 4)";
TestRestrictionBuilding(restrictionContent, osmIdsToFeatureIdsContent);
}
} // namespace

View file

@ -84,7 +84,7 @@ bool RestrictionCollector::ParseOsmIdToFeatureIdMapping(string const & osmIdsToF
}
catch (FileReader::Exception const & e)
{
LOG(LERROR, ("Exception while reading file:", osmIdsToFeatureIdPath, ". Msg:", e.Msg()));
LOG(LWARNING, ("Exception while reading file:", osmIdsToFeatureIdPath, ". Msg:", e.Msg()));
return false;
}