aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src/vcpkg-test/binarycaching.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'toolsrc/src/vcpkg-test/binarycaching.cpp')
-rw-r--r--toolsrc/src/vcpkg-test/binarycaching.cpp138
1 files changed, 138 insertions, 0 deletions
diff --git a/toolsrc/src/vcpkg-test/binarycaching.cpp b/toolsrc/src/vcpkg-test/binarycaching.cpp
new file mode 100644
index 000000000..817b85e03
--- /dev/null
+++ b/toolsrc/src/vcpkg-test/binarycaching.cpp
@@ -0,0 +1,138 @@
+#include <catch2/catch.hpp>
+#include <vcpkg/binarycaching.private.h>
+#include <vcpkg/base/files.h>
+#include <vcpkg/vcpkgcmdarguments.h>
+#include <vcpkg/sourceparagraph.h>
+#include <vcpkg/paragraphs.h>
+#include <vcpkg/dependencies.h>
+#include <string>
+
+using namespace vcpkg;
+
+TEST_CASE ("reformat_version semver-ish", "[reformat_version]")
+{
+ REQUIRE(reformat_version("0.0.0", "abitag") == "0.0.0-abitag");
+ REQUIRE(reformat_version("1.0.1", "abitag") == "1.0.1-abitag");
+ REQUIRE(reformat_version("1.01.000", "abitag") == "1.1.0-abitag");
+ REQUIRE(reformat_version("1.2", "abitag") == "1.2.0-abitag");
+ REQUIRE(reformat_version("v52", "abitag") == "52.0.0-abitag");
+ REQUIRE(reformat_version("v09.01.02", "abitag") == "9.1.2-abitag");
+ REQUIRE(reformat_version("1.1.1q", "abitag") == "1.1.1-abitag");
+ REQUIRE(reformat_version("1", "abitag") == "1.0.0-abitag");
+}
+
+TEST_CASE ("reformat_version date", "[reformat_version]")
+{
+ REQUIRE(reformat_version("2020-06-26", "abitag") == "2020.6.26-abitag");
+ REQUIRE(reformat_version("20-06-26", "abitag") == "0.0.0-abitag");
+ REQUIRE(reformat_version("2020-06-26-release", "abitag") == "2020.6.26-abitag");
+ REQUIRE(reformat_version("2020-06-26000", "abitag") == "2020.6.26-abitag");
+}
+
+TEST_CASE ("reformat_version generic", "[reformat_version]")
+{
+ REQUIRE(reformat_version("apr", "abitag") == "0.0.0-abitag");
+ REQUIRE(reformat_version("", "abitag") == "0.0.0-abitag");
+}
+
+TEST_CASE ("generate_nuspec", "[generate_nuspec]")
+{
+ auto& fsWrapper = Files::get_real_filesystem();
+ VcpkgCmdArguments args = VcpkgCmdArguments::create_from_arg_sequence(nullptr, nullptr);
+ args.packages_root_dir = std::make_unique<std::string>("/");
+ VcpkgPaths paths(fsWrapper, args);
+
+ auto pghs = Paragraphs::parse_paragraphs(R"(
+Source: zlib2
+Version: 1.5
+Build-Depends: zlib
+Description: a spiffy compression library wrapper
+
+Feature: a
+Description: a feature
+
+Feature: b
+Description: enable bzip capabilities
+Build-Depends: bzip
+)",
+ "<testdata>");
+ REQUIRE(pghs.has_value());
+ auto maybe_scf = SourceControlFile::parse_control_file(fs::path(), std::move(*pghs.get()));
+ REQUIRE(maybe_scf.has_value());
+ SourceControlFileLocation scfl{std::move(*maybe_scf.get()), fs::path()};
+
+ Dependencies::InstallPlanAction ipa(PackageSpec{"zlib2", Triplet::X64_WINDOWS},
+ scfl,
+ Dependencies::RequestType::USER_REQUESTED,
+ {{"a", {}}, {"b", {}}});
+
+ ipa.abi_info = Build::AbiInfo{};
+ ipa.abi_info.get()->package_abi = "packageabi";
+ std::string tripletabi("tripletabi");
+ ipa.abi_info.get()->triplet_abi = tripletabi;
+
+ NugetReference ref(ipa);
+
+ REQUIRE(ref.nupkg_filename() == "zlib2_x64-windows.1.5.0-packageabi.nupkg");
+
+ auto nuspec = generate_nuspec(paths, ipa, ref);
+#ifdef _WIN32
+#define PKGPATH "C:\\zlib2_x64-windows\\**"
+#else
+#define PKGPATH "/zlib2_x64-windows/**"
+#endif
+ std::string expected = R"(<package>
+ <metadata>
+ <id>zlib2_x64-windows</id>
+ <version>1.5.0-packageabi</version>
+ <authors>vcpkg</authors>
+ <description>NOT FOR DIRECT USE. Automatically generated cache package.
+
+a spiffy compression library wrapper
+
+Version: 1.5
+Triplet/Compiler hash: tripletabi
+Features: a, b
+Dependencies:
+</description>
+ <packageTypes><packageType name="vcpkg"/></packageTypes>
+ </metadata>
+ <files><file src=")" PKGPATH R"(" target=""/></files>
+ </package>
+)";
+ auto expected_lines = Strings::split(expected, '\n');
+ auto nuspec_lines = Strings::split(nuspec, '\n');
+ for (size_t i = 0; i < expected_lines.size() && i < nuspec_lines.size(); ++i)
+ {
+ INFO("on line: " << i);
+ REQUIRE(nuspec_lines[i] == expected_lines[i]);
+ }
+ REQUIRE(nuspec_lines.size() == expected_lines.size());
+}
+
+TEST_CASE ("XmlSerializer", "[XmlSerializer]")
+{
+ XmlSerializer xml;
+ xml.open_tag("a");
+ xml.open_tag("b");
+ xml.simple_tag("c", "d");
+ xml.close_tag("b");
+ xml.text("escaping: & < > \" '");
+
+ REQUIRE(xml.buf == R"(<a><b><c>d</c></b>escaping: &amp; &lt; &gt; &quot; &apos;)");
+
+ xml = XmlSerializer();
+ xml.emit_declaration();
+ xml.start_complex_open_tag("a").text_attr("b", "<").text_attr("c", " ").finish_self_closing_complex_tag();
+ REQUIRE(xml.buf == R"(<?xml version="1.0" encoding="utf-8"?><a b="&lt;" c=" "/>)");
+
+ xml = XmlSerializer();
+ xml.start_complex_open_tag("a").finish_complex_open_tag();
+ REQUIRE(xml.buf == R"(<a>)");
+
+ xml = XmlSerializer();
+ xml.line_break();
+ xml.open_tag("a").line_break().line_break();
+ xml.close_tag("a").line_break().line_break();
+ REQUIRE(xml.buf == "\n<a>\n \n </a>\n\n");
+} \ No newline at end of file