aboutsummaryrefslogtreecommitdiff
path: root/tests/unit/libstore/filetransfer.cc
diff options
context:
space:
mode:
authoreldritch horrors <pennae@lix.systems>2024-05-09 21:22:48 +0200
committereldritch horrors <pennae@lix.systems>2024-06-19 10:50:12 +0000
commitc55dcc6c13b864dc613a0a6ba51e0b897868f4b4 (patch)
tree2c588cf6dd0662b9b8875e9dd7802b564e9306c5 /tests/unit/libstore/filetransfer.cc
parent11f4a5bc7eca8a4cca2ae9f3d83b69cd497933f8 (diff)
filetransfer: return a Source from download()
without this we will not be able to get rid of makeDecompressionSink, which in turn will be necessary to get rid of sourceToSink (since the libarchive archive wrapper *must* be a Source due to api limitations) Change-Id: Iccd3d333ba2cbcab49cb5a1d3125624de16bce27
Diffstat (limited to 'tests/unit/libstore/filetransfer.cc')
-rw-r--r--tests/unit/libstore/filetransfer.cc18
1 files changed, 12 insertions, 6 deletions
diff --git a/tests/unit/libstore/filetransfer.cc b/tests/unit/libstore/filetransfer.cc
index b60963a46..6e8cf3bbe 100644
--- a/tests/unit/libstore/filetransfer.cc
+++ b/tests/unit/libstore/filetransfer.cc
@@ -7,6 +7,7 @@
#include <gtest/gtest.h>
#include <netinet/in.h>
#include <stdexcept>
+#include <string>
#include <string_view>
#include <sys/poll.h>
#include <sys/socket.h>
@@ -136,7 +137,7 @@ TEST(FileTransfer, exceptionAbortsDownload)
LambdaSink broken([](auto block) { throw Done(); });
- ASSERT_THROW(ft->download(FileTransferRequest("file:///dev/zero"), broken), Done);
+ ASSERT_THROW(ft->download(FileTransferRequest("file:///dev/zero"))->drainInto(broken), Done);
// makeFileTransfer returns a ref<>, which cannot be cleared. since we also
// can't default-construct it we'll have to overwrite it instead, but we'll
@@ -159,16 +160,21 @@ TEST(FileTransfer, NOT_ON_DARWIN(reportsSetupErrors))
FileTransferError);
}
-TEST(FileTransfer, NOT_ON_DARWIN(reportsTransferError))
+TEST(FileTransfer, NOT_ON_DARWIN(defersFailures))
{
- auto [port, srv] = serveHTTP("200 ok", "content-length: 100\r\n", [] {
+ auto [port, srv] = serveHTTP("200 ok", "content-length: 100000000\r\n", [] {
std::this_thread::sleep_for(10ms);
- return "";
+ // just a bunch of data to fill the curl wrapper buffer, otherwise the
+ // initial wait for header data will also wait for the the response to
+ // complete (the source is only woken when curl returns data, and curl
+ // might only do so once its internal buffer has already been filled.)
+ return std::string(1024 * 1024, ' ');
});
auto ft = makeFileTransfer();
FileTransferRequest req(fmt("http://[::1]:%d/index", port));
req.baseRetryTimeMs = 0;
- ASSERT_THROW(ft->transfer(req), FileTransferError);
+ auto src = ft->download(std::move(req));
+ ASSERT_THROW(src->drain(), FileTransferError);
}
TEST(FileTransfer, NOT_ON_DARWIN(handlesContentEncoding))
@@ -180,7 +186,7 @@ TEST(FileTransfer, NOT_ON_DARWIN(handlesContentEncoding))
auto ft = makeFileTransfer();
StringSink sink;
- ft->download(FileTransferRequest(fmt("http://[::1]:%d/index", port)), sink);
+ ft->download(FileTransferRequest(fmt("http://[::1]:%d/index", port)))->drainInto(sink);
EXPECT_EQ(sink.s, original);
}