diff options
Diffstat (limited to 'render-test/manifest_parser.cpp')
-rw-r--r-- | render-test/manifest_parser.cpp | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/render-test/manifest_parser.cpp b/render-test/manifest_parser.cpp index 6aec4b3593..e0e4946215 100644 --- a/render-test/manifest_parser.cpp +++ b/render-test/manifest_parser.cpp @@ -22,7 +22,13 @@ std::string prependFileScheme(const std::string& url) { } } // namespace -Manifest::Manifest() = default; +Manifest::Manifest() { + const char* envToken = getenv("MAPBOX_ACCESS_TOKEN"); + if (envToken != nullptr) { + accessToken = envToken; + } +} + Manifest::~Manifest() = default; const std::vector<TestPaths>& Manifest::getTestPaths() const { @@ -48,6 +54,10 @@ const std::string& Manifest::getCachePath() const { return cachePath; } +const std::string& Manifest::getAccessToken() const { + return accessToken; +} + const std::set<std::string>& Manifest::getProbes() const { return probes; } @@ -321,6 +331,19 @@ mbgl::optional<Manifest> ManifestParser::parseManifest(const std::string& manife return mbgl::nullopt; } } + if (document.HasMember("access_token")) { + const auto& accessTokenValue = document["access_token"]; + if (!accessTokenValue.IsString()) { + mbgl::Log::Warning(mbgl::Event::General, + "Invalid access_token is provided inside the manifest file: %s", + filePath.c_str()); + return mbgl::nullopt; + } + manifest.accessToken = accessTokenValue.GetString(); + if (manifest.accessToken.empty()) { + return mbgl::nullopt; + } + } mbgl::filesystem::path baseTestPath; if (document.HasMember("base_test_path")) { const auto& testPathValue = document["base_test_path"]; |