Commit b2e23c1a authored by Harris Hancock's avatar Harris Hancock

Port serialize-async-test.c++ to Windows

parent cff9ba05
...@@ -24,9 +24,7 @@ ...@@ -24,9 +24,7 @@
#include <kj/debug.h> #include <kj/debug.h>
#include <kj/thread.h> #include <kj/thread.h>
#include <stdlib.h> #include <stdlib.h>
#include <unistd.h> #include <kj/miniposix.h>
#include <fcntl.h>
#include <sys/types.h>
#include "test-util.h" #include "test-util.h"
#include <kj/compat/gtest.h> #include <kj/compat/gtest.h>
...@@ -47,13 +45,19 @@ namespace capnp { ...@@ -47,13 +45,19 @@ namespace capnp {
namespace _ { // private namespace _ { // private
namespace { namespace {
#if _WIN32
inline void delay() { Sleep(5); }
#else
inline void delay() { usleep(5000); }
#endif
class FragmentingOutputStream: public kj::OutputStream { class FragmentingOutputStream: public kj::OutputStream {
public: public:
FragmentingOutputStream(kj::OutputStream& inner): inner(inner) {} FragmentingOutputStream(kj::OutputStream& inner): inner(inner) {}
void write(const void* buffer, size_t size) override { void write(const void* buffer, size_t size) override {
while (size > 0) { while (size > 0) {
usleep(5000); delay();
size_t n = rand() % size + 1; size_t n = rand() % size + 1;
inner.write(buffer, n); inner.write(buffer, n);
buffer = reinterpret_cast<const byte*>(buffer) + n; buffer = reinterpret_cast<const byte*>(buffer) + n;
...@@ -164,7 +168,7 @@ public: ...@@ -164,7 +168,7 @@ public:
void write(const void* buffer, size_t size) override { void write(const void* buffer, size_t size) override {
const char* ptr = reinterpret_cast<const char*>(buffer); const char* ptr = reinterpret_cast<const char*>(buffer);
while (size > 0) { while (size > 0) {
ssize_t n; kj::miniposix::ssize_t n;
KJ_SOCKCALL(n = send(fd, ptr, size, 0)); KJ_SOCKCALL(n = send(fd, ptr, size, 0));
size -= n; size -= n;
ptr += n; ptr += n;
...@@ -183,7 +187,7 @@ public: ...@@ -183,7 +187,7 @@ public:
char* ptr = reinterpret_cast<char*>(buffer); char* ptr = reinterpret_cast<char*>(buffer);
size_t total = 0; size_t total = 0;
while (total < minBytes) { while (total < minBytes) {
ssize_t n; kj::miniposix::ssize_t n;
KJ_SOCKCALL(n = recv(fd, ptr, maxBytes, 0)); KJ_SOCKCALL(n = recv(fd, ptr, maxBytes, 0));
total += n; total += n;
maxBytes -= n; maxBytes -= n;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment