aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src
diff options
context:
space:
mode:
authorBilly O'Neal <bion@microsoft.com>2020-06-26 12:37:53 -0700
committerGitHub <noreply@github.com>2020-06-26 12:37:53 -0700
commit81ae2ed94bf51fdd453b383135a809dea3d45cce (patch)
tree959ac75af38a41fa1a795a1e233d4a70dee80af2 /toolsrc/src
parent309f6fc9bcb48a68b692b2f4707b5fea7eaf1c60 (diff)
downloadvcpkg-81ae2ed94bf51fdd453b383135a809dea3d45cce.tar.gz
vcpkg-81ae2ed94bf51fdd453b383135a809dea3d45cce.zip
[vcpkg] Add write-only binary caching for CI. (#12130)
Changes to the binary caching spec made as comments over at https://github.com/microsoft/vcpkg/pull/11204#pullrequestreview-438518901
Diffstat (limited to 'toolsrc/src')
-rw-r--r--toolsrc/src/vcpkg-test/binaryconfigparser.cpp28
-rw-r--r--toolsrc/src/vcpkg/binarycaching.cpp99
2 files changed, 88 insertions, 39 deletions
diff --git a/toolsrc/src/vcpkg-test/binaryconfigparser.cpp b/toolsrc/src/vcpkg-test/binaryconfigparser.cpp
index 53e19a8f6..11ed32900 100644
--- a/toolsrc/src/vcpkg-test/binaryconfigparser.cpp
+++ b/toolsrc/src/vcpkg-test/binaryconfigparser.cpp
@@ -44,11 +44,19 @@ TEST_CASE ("BinaryConfigParser files provider", "[binaryconfigparser]")
REQUIRE(!parsed.has_value());
}
{
- auto parsed = create_binary_provider_from_configs_pure("files," ABSOLUTE_PATH ",upload", {});
+ auto parsed = create_binary_provider_from_configs_pure("files," ABSOLUTE_PATH ",read", {});
REQUIRE(parsed.has_value());
}
{
- auto parsed = create_binary_provider_from_configs_pure("files," ABSOLUTE_PATH ",upload,extra", {});
+ auto parsed = create_binary_provider_from_configs_pure("files," ABSOLUTE_PATH ",write", {});
+ REQUIRE(parsed.has_value());
+ }
+ {
+ auto parsed = create_binary_provider_from_configs_pure("files," ABSOLUTE_PATH ",readwrite", {});
+ REQUIRE(parsed.has_value());
+ }
+ {
+ auto parsed = create_binary_provider_from_configs_pure("files," ABSOLUTE_PATH ",readwrite,extra", {});
REQUIRE(!parsed.has_value());
}
{
@@ -140,11 +148,19 @@ TEST_CASE ("BinaryConfigParser default provider", "[binaryconfigparser]")
REQUIRE(!parsed.has_value());
}
{
- auto parsed = create_binary_provider_from_configs_pure("default,upload", {});
+ auto parsed = create_binary_provider_from_configs_pure("default,read", {});
+ REQUIRE(parsed.has_value());
+ }
+ {
+ auto parsed = create_binary_provider_from_configs_pure("default,readwrite", {});
+ REQUIRE(parsed.has_value());
+ }
+ {
+ auto parsed = create_binary_provider_from_configs_pure("default,write", {});
REQUIRE(parsed.has_value());
}
{
- auto parsed = create_binary_provider_from_configs_pure("default,upload,extra", {});
+ auto parsed = create_binary_provider_from_configs_pure("default,read,extra", {});
REQUIRE(!parsed.has_value());
}
}
@@ -180,11 +196,11 @@ TEST_CASE ("BinaryConfigParser multiple providers", "[binaryconfigparser]")
REQUIRE(parsed.has_value());
}
{
- auto parsed = create_binary_provider_from_configs_pure("clear;default,upload", {});
+ auto parsed = create_binary_provider_from_configs_pure("clear;default,readwrite", {});
REQUIRE(parsed.has_value());
}
{
- auto parsed = create_binary_provider_from_configs_pure("clear;default,upload;clear;clear", {});
+ auto parsed = create_binary_provider_from_configs_pure("clear;default,readwrite;clear;clear", {});
REQUIRE(parsed.has_value());
}
{
diff --git a/toolsrc/src/vcpkg/binarycaching.cpp b/toolsrc/src/vcpkg/binarycaching.cpp
index 86c9899e3..13dd920c6 100644
--- a/toolsrc/src/vcpkg/binarycaching.cpp
+++ b/toolsrc/src/vcpkg/binarycaching.cpp
@@ -512,7 +512,7 @@ namespace
}
}
void push_failure(const VcpkgPaths&, const std::string&, const PackageSpec&) override {}
- RestoreResult precheck(const VcpkgPaths&, const Dependencies::InstallPlanAction&, bool) override
+ RestoreResult precheck(const VcpkgPaths&, const Dependencies::InstallPlanAction&) override
{
return RestoreResult::missing;
}
@@ -572,12 +572,11 @@ namespace
}
}
RestoreResult precheck(const VcpkgPaths& paths,
- const Dependencies::InstallPlanAction& action,
- bool purge_tombstones) override
+ const Dependencies::InstallPlanAction& action) override
{
for (auto&& provider : m_providers)
{
- auto result = provider->precheck(paths, action, purge_tombstones);
+ auto result = provider->precheck(paths, action);
switch (result)
{
case RestoreResult::build_failed:
@@ -600,8 +599,8 @@ namespace
{
return RestoreResult::missing;
}
- void push_success(const VcpkgPaths&, const Dependencies::InstallPlanAction&) override {}
- void push_failure(const VcpkgPaths&, const std::string&, const PackageSpec&) override {}
+ void push_success(const VcpkgPaths&, const Dependencies::InstallPlanAction&) override { }
+ void push_failure(const VcpkgPaths&, const std::string&, const PackageSpec&) override { }
RestoreResult precheck(const VcpkgPaths&, const Dependencies::InstallPlanAction&) override
{
return RestoreResult::missing;
@@ -815,33 +814,48 @@ ExpectedS<std::unique_ptr<IBinaryProvider>> vcpkg::create_binary_provider_from_c
else if (segments[0].second == "files")
{
if (segments.size() < 2)
+ {
return add_error("expected arguments: binary config 'files' requires at least a path argument",
segments[0].first);
+ }
auto p = fs::u8path(segments[1].second);
if (!p.is_absolute())
+ {
return add_error("expected arguments: path arguments for binary config strings must be absolute",
segments[1].first);
+ }
- if (segments.size() > 3)
+ std::string mode;
+ switch (segments.size())
{
- return add_error("unexpected arguments: binary config 'files' does not take more than 2 arguments",
- segments[3].first);
+ case 2: mode = "read"; break;
+ case 3: mode = segments[2].second; break;
+ default:
+ return add_error("unexpected arguments: binary config 'files' requires 1 or 2 arguments",
+ segments[3].first);
}
- else if (segments.size() == 3)
+
+ if (mode == "read")
{
- if (segments[2].second != "upload")
- {
- return add_error("unexpected arguments: binary config 'files' can only accept 'upload' as "
- "a second argument",
- segments[2].first);
- }
- else
- {
- state->archives_to_write.push_back(p);
- }
+ state->archives_to_read.push_back(std::move(p));
+ }
+ else if (mode == "write")
+ {
+ state->archives_to_write.push_back(std::move(p));
+ }
+ else if (mode == "readwrite")
+ {
+ state->archives_to_read.push_back(p);
+ state->archives_to_write.push_back(std::move(p));
+ }
+ else
+ {
+ Checks::check_exit(VCPKG_LINE_INFO, segments.size() > 2);
+ return add_error("unexpected arguments: binary config 'files' can only accept"
+ " 'read', readwrite', or 'write' as a second argument",
+ segments[2].first);
}
- state->archives_to_read.push_back(std::move(p));
}
else if (segments[0].second == "interactive")
{
@@ -916,8 +930,10 @@ ExpectedS<std::unique_ptr<IBinaryProvider>> vcpkg::create_binary_provider_from_c
else if (segments[0].second == "default")
{
if (segments.size() > 2)
+ {
return add_error("unexpected arguments: binary config 'default' does not take more than 1 argument",
segments[0].first);
+ }
auto&& maybe_home = System::get_platform_cache_home();
if (!maybe_home.has_value()) return add_error(maybe_home.error(), segments[0].first);
@@ -925,21 +941,38 @@ ExpectedS<std::unique_ptr<IBinaryProvider>> vcpkg::create_binary_provider_from_c
auto p = *maybe_home.get();
p /= fs::u8path("vcpkg/archives");
if (!p.is_absolute())
+ {
return add_error("default path was not absolute: " + p.u8string(), segments[0].first);
- if (segments.size() == 2)
+ }
+
+ std::string mode;
+ switch (segments.size())
{
- if (segments[1].second != "upload")
- {
- return add_error(
- "unexpected arguments: binary config 'default' can only accept 'upload' as an argument",
- segments[1].first);
- }
- else
- {
- state->archives_to_write.push_back(p);
- }
+ case 1: mode = "read"; break;
+ case 2: mode = segments[1].second; break;
+ default: Checks::unreachable(VCPKG_LINE_INFO);
+ }
+
+ if (mode == "read")
+ {
+ state->archives_to_read.push_back(std::move(p));
+ }
+ else if (mode == "write")
+ {
+ state->archives_to_write.push_back(std::move(p));
+ }
+ else if (mode == "readwrite")
+ {
+ state->archives_to_read.push_back(p);
+ state->archives_to_write.push_back(std::move(p));
+ }
+ else
+ {
+ Checks::check_exit(VCPKG_LINE_INFO, segments.size() > 1);
+ return add_error("unexpected arguments: binary config 'default' can only accept"
+ " 'read', readwrite', or 'write' as a first argument",
+ segments[1].first);
}
- state->archives_to_read.push_back(std::move(p));
}
else
{