Commit 06763c4c8c
Changed files (3)
lib
std
lib/std/http/Client.zig
@@ -1046,72 +1046,3 @@ test {
std.testing.refAllDecls(@This());
}
-
-test "client requests server" {
- const builtin = @import("builtin");
-
- // This test requires spawning threads.
- if (builtin.single_threaded) {
- return error.SkipZigTest;
- }
-
- const native_endian = comptime builtin.cpu.arch.endian();
- if (builtin.zig_backend == .stage2_llvm and native_endian == .Big) {
- // https://github.com/ziglang/zig/issues/13782
- return error.SkipZigTest;
- }
-
- if (builtin.os.tag == .wasi) return error.SkipZigTest;
-
- const allocator = std.testing.allocator;
-
- const max_header_size = 8192;
- var server = std.http.Server.init(allocator, .{ .reuse_address = true });
- defer server.deinit();
-
- const address = try std.net.Address.parseIp("127.0.0.1", 0);
- try server.listen(address);
- const server_port = server.socket.listen_address.in.getPort();
-
- const thread = try std.Thread.spawn(.{}, (struct {
- fn apply(s: *std.http.Server) !void {
- const res = try s.accept(.{ .dynamic = max_header_size });
- defer res.reset();
- try res.wait();
-
- const server_body: []const u8 = "message from server!\n";
- res.transfer_encoding = .{ .content_length = server_body.len };
- try res.headers.append("content-type", "text/plain");
- try res.headers.append("connection", "close");
- try res.do();
-
- var buf: [128]u8 = undefined;
- const n = try res.readAll(&buf);
- try testing.expect(std.mem.eql(u8, buf[0..n], "Hello, World!\n"));
- _ = try res.writer().writeAll(server_body);
- try res.finish();
- }
- }).apply, .{&server});
-
- var uri_buf: [22]u8 = undefined;
- const uri = std.Uri.parse(try std.fmt.bufPrint(&uri_buf, "http://127.0.0.1:{d}", .{server_port})) catch unreachable;
- var client = std.http.Client{ .allocator = allocator };
- defer client.deinit();
- var client_headers = std.http.Headers{ .allocator = allocator };
- defer client_headers.deinit();
- var client_req = try client.request(.POST, uri, client_headers, .{});
- defer client_req.deinit();
-
- client_req.transfer_encoding = .{ .content_length = 14 }; // this will be checked to ensure you sent exactly 14 bytes
- try client_req.start(); // this sends the request
- try client_req.writeAll("Hello, ");
- try client_req.writeAll("World!\n");
- try client_req.finish();
- try client_req.do(); // this waits for a response
-
- const body = try client_req.reader().readAllAlloc(allocator, 8192 * 1024);
- defer allocator.free(body);
- try testing.expect(std.mem.eql(u8, body, "message from server!\n"));
-
- thread.join();
-}
lib/std/http/test.zig
@@ -0,0 +1,71 @@
+const std = @import("std");
+const expect = std.testing.expect;
+
+test "client requests server" {
+ const builtin = @import("builtin");
+
+ // This test requires spawning threads.
+ if (builtin.single_threaded) {
+ return error.SkipZigTest;
+ }
+
+ const native_endian = comptime builtin.cpu.arch.endian();
+ if (builtin.zig_backend == .stage2_llvm and native_endian == .Big) {
+ // https://github.com/ziglang/zig/issues/13782
+ return error.SkipZigTest;
+ }
+
+ if (builtin.os.tag == .wasi) return error.SkipZigTest;
+
+ const allocator = std.testing.allocator;
+
+ const max_header_size = 8192;
+ var server = std.http.Server.init(allocator, .{ .reuse_address = true });
+ defer server.deinit();
+
+ const address = try std.net.Address.parseIp("127.0.0.1", 0);
+ try server.listen(address);
+ const server_port = server.socket.listen_address.in.getPort();
+
+ const server_thread = try std.Thread.spawn(.{}, (struct {
+ fn apply(s: *std.http.Server) !void {
+ const res = try s.accept(.{ .dynamic = max_header_size });
+ defer res.reset();
+ try res.wait();
+
+ const server_body: []const u8 = "message from server!\n";
+ res.transfer_encoding = .{ .content_length = server_body.len };
+ try res.headers.append("content-type", "text/plain");
+ try res.headers.append("connection", "close");
+ try res.do();
+
+ var buf: [128]u8 = undefined;
+ const n = try res.readAll(&buf);
+ try expect(std.mem.eql(u8, buf[0..n], "Hello, World!\n"));
+ _ = try res.writer().writeAll(server_body);
+ try res.finish();
+ }
+ }).apply, .{&server});
+
+ var uri_buf: [22]u8 = undefined;
+ const uri = try std.Uri.parse(try std.fmt.bufPrint(&uri_buf, "http://127.0.0.1:{d}", .{server_port}));
+ var client = std.http.Client{ .allocator = allocator };
+ defer client.deinit();
+ var client_headers = std.http.Headers{ .allocator = allocator };
+ defer client_headers.deinit();
+ var client_req = try client.request(.POST, uri, client_headers, .{});
+ defer client_req.deinit();
+
+ client_req.transfer_encoding = .{ .content_length = 14 }; // this will be checked to ensure you sent exactly 14 bytes
+ try client_req.start(); // this sends the request
+ try client_req.writeAll("Hello, ");
+ try client_req.writeAll("World!\n");
+ try client_req.finish();
+ try client_req.do(); // this waits for a response
+
+ const body = try client_req.reader().readAllAlloc(allocator, 8192 * 1024);
+ defer allocator.free(body);
+ try expect(std.mem.eql(u8, body, "message from server!\n"));
+
+ server_thread.join();
+}
lib/std/http.zig
@@ -275,4 +275,5 @@ test {
_ = Client;
_ = Method;
_ = Status;
+ _ = @import("http/test.zig");
}