tests: start building tests in separate directory

This approach seems nice, and as a bonus it makes it easier to run the
tests through the module interface rather than by importing the
sources directly, which I think is a good dog food approach.
This commit is contained in:
2023-08-21 23:31:46 -07:00
parent ef185bc975
commit 40d898a55e
4 changed files with 64 additions and 64 deletions

View File

@@ -113,63 +113,3 @@ pub const Message = opaque {
// NATS_EXTERN const char* stanMsg_GetData(const stanMsg *msg);
// NATS_EXTERN int stanMsg_GetDataLength(const stanMsg *msg);
// NATS_EXTERN void stanMsg_Destroy(stanMsg *msg);
test "message: create message" {
const subject = "hello";
const reply = "reply";
const data = "world";
const nats = @import("./nats.zig");
// have to initialize the library so the reference counter can correctly destroy
// objects, otherwise we segfault on trying to free the memory.
try nats.init(-1);
defer nats.deinit();
const message = try Message.create(subject, reply, data);
defer message.destroy();
const message2 = try Message.create(subject, null, data);
defer message2.destroy();
const message3 = try Message.create(subject, data, null);
defer message3.destroy();
const message4 = try Message.create(subject, null, null);
defer message4.destroy();
}
test "message: get subject" {
const nats = @import("./nats.zig");
try nats.init(-1);
defer nats.deinit();
const subject = "hello";
const message = try Message.create(subject, null, null);
defer message.destroy();
const received = message.getSubject();
try std.testing.expectEqualStrings(subject, received);
}
test "message: get reply" {
const nats = @import("./nats.zig");
try nats.init(-1);
defer nats.deinit();
const subject = "hello";
const reply = "reply";
const message = try Message.create(subject, reply, null);
defer message.destroy();
const received = message.getReply() orelse return error.TestUnexpectedResult;
try std.testing.expectEqualStrings(reply, received);
const message2 = try Message.create(subject, null, null);
defer message2.destroy();
const received2 = message2.getReply();
try std.testing.expect(received2 == null);
}

View File

@@ -158,7 +158,3 @@ pub const MessageList = opaque {
nats_c.natsMsgList_Destroy(@ptrCast(self));
}
};
test {
std.testing.refAllDecls(@This());
}