diff options
Diffstat (limited to 'render-test/parser.cpp')
-rw-r--r-- | render-test/parser.cpp | 55 |
1 files changed, 50 insertions, 5 deletions
diff --git a/render-test/parser.cpp b/render-test/parser.cpp index 4598ba3786..6e6ebb0ba4 100644 --- a/render-test/parser.cpp +++ b/render-test/parser.cpp @@ -13,8 +13,9 @@ #include <boost/archive/iterators/transform_width.hpp> #include <boost/archive/iterators/ostream_iterator.hpp> -#include "parser.hpp" +#include "filesystem.hpp" #include "metadata.hpp" +#include "parser.hpp" #include "runner.hpp" #include <sstream> @@ -162,6 +163,22 @@ mbgl::optional<std::string> localizeMapboxTilesetURL(const std::string& url) { return getIntegrationPath(url, "tilesets/", regex); } +TestPaths makeTestPaths(mbgl::filesystem::path stylePath) { + std::vector<mbgl::filesystem::path> expectations{ stylePath }; + expectations.front().remove_filename(); + + const static std::regex regex{ TestRunner::getBasePath() }; + for (const std::string& path : TestRunner::getPlatformExpectationsPaths()) { + expectations.emplace_back(std::regex_replace(expectations.front().string(), regex, path)); + assert(!expectations.back().empty()); + } + + return { + std::move(stylePath), + std::move(expectations) + }; +} + } // namespace JSONReply readJson(const mbgl::filesystem::path& jsonPath) { @@ -239,6 +256,8 @@ ArgumentsTuple parseArguments(int argc, char** argv) { { "seed" }); args::ValueFlag<std::string> testPathValue(argumentParser, "rootPath", "Test root rootPath", { 'p', "rootPath" }); + args::ValueFlag<std::regex> testFilterValue(argumentParser, "filter", "Test filter regex", + { 'f', "filter" }); args::PositionalList<std::string> testNameValues(argumentParser, "URL", "Test name(s)"); try { @@ -260,10 +279,16 @@ ArgumentsTuple parseArguments(int argc, char** argv) { mbgl::Log::Info(mbgl::Event::General, stream.str()); mbgl::Log::Error(mbgl::Event::General, e.what()); exit(2); + } catch (const std::regex_error& e) { + mbgl::Log::Error(mbgl::Event::General, "Invalid filter regular expression: %s", e.what()); + exit(3); } - const std::string testDefaultPath = - std::string(TEST_RUNNER_ROOT_PATH).append("/mapbox-gl-js/test/integration/render-tests"); + const auto rootPath = testPathValue ? args::get(testPathValue) : TestRunner::getBasePath(); + if (!mbgl::filesystem::exists(mbgl::filesystem::path(rootPath))) { + mbgl::Log::Error(mbgl::Event::General, "Provided rootPath '%s' does not exist.", rootPath.c_str()); + exit(4); + } std::vector<std::string> ids; for (const auto& id : args::get(testNameValues)) { @@ -274,11 +299,31 @@ ArgumentsTuple parseArguments(int argc, char** argv) { ids.emplace_back(TestRunner::getBasePath()); } + // Recursively traverse through the test paths and collect test directories containing "style.json". + std::vector<TestPaths> testPaths; + testPaths.reserve(ids.size()); + for (const auto& id : ids) { + auto path = mbgl::filesystem::path(id); + if (!mbgl::filesystem::exists(path)) { + mbgl::Log::Error(mbgl::Event::General, "Provided test folder '%s' does not exist.", id.c_str()); + continue; + } + for (auto& testPath : mbgl::filesystem::recursive_directory_iterator(path)) { + // Skip paths that fail regexp match. + if (testFilterValue && !std::regex_match(testPath.path().string(), args::get(testFilterValue))) { + continue; + } + if (testPath.path().filename() == "style.json") { + testPaths.emplace_back(makeTestPaths(testPath)); + } + } + } + return ArgumentsTuple { recycleMapFlag ? args::get(recycleMapFlag) : false, shuffleFlag ? args::get(shuffleFlag) : false, seedValue ? args::get(seedValue) : 1u, - testPathValue ? args::get(testPathValue) : testDefaultPath, - std::move(ids) + testPathValue ? args::get(testPathValue) : TestRunner::getBasePath(), + std::move(testPaths) }; } |