serialiser
This commit is contained in:
parent
113f49f6a4
commit
e1f1084a39
14 changed files with 698 additions and 51 deletions
|
|
@ -2,7 +2,7 @@ const std = @import("std");
|
|||
|
||||
const msgpack = @import("msgpack");
|
||||
|
||||
const deserialise = msgpack.deserialise.deserialise;
|
||||
const deserialise = msgpack.deserialise;
|
||||
|
||||
fn test_binary(bytes: []const u8, expected: []const u8) !void {
|
||||
const alloc = std.testing.allocator;
|
||||
|
|
@ -10,22 +10,22 @@ fn test_binary(bytes: []const u8, expected: []const u8) !void {
|
|||
const obj = try deserialise(alloc, bytes);
|
||||
defer obj.deinit(alloc);
|
||||
|
||||
try std.testing.expectEqualStrings(expected, obj.raw.binary);
|
||||
try std.testing.expectEqualStrings(expected, obj.binary);
|
||||
}
|
||||
|
||||
test "binary 1" {
|
||||
test "fixbin" {
|
||||
const bytes = [_]u8{ 0xc4, 0x03, 'A', 'B', 'C' };
|
||||
|
||||
try test_binary(&bytes, "ABC");
|
||||
}
|
||||
|
||||
test "binary 2" {
|
||||
test "empty bin" {
|
||||
const bytes = [_]u8{ 0xc4, 0x00 };
|
||||
|
||||
try test_binary(&bytes, "");
|
||||
}
|
||||
|
||||
test "binary 3" {
|
||||
test "bin8" {
|
||||
var bytes: [2 + 255]u8 = undefined;
|
||||
|
||||
bytes[0] = 0xc4;
|
||||
|
|
@ -38,7 +38,7 @@ test "binary 3" {
|
|||
try test_binary(&bytes, "A" ** 255);
|
||||
}
|
||||
|
||||
test "binary 4" {
|
||||
test "bin16 1" {
|
||||
var bytes: [3 + 256]u8 = undefined;
|
||||
|
||||
bytes[0] = 0xc5;
|
||||
|
|
@ -52,7 +52,7 @@ test "binary 4" {
|
|||
try test_binary(&bytes, "A" ** 256);
|
||||
}
|
||||
|
||||
test "binary 5" {
|
||||
test "bin16 2" {
|
||||
var bytes: [3 + 65535]u8 = undefined;
|
||||
|
||||
bytes[0] = 0xc5;
|
||||
|
|
@ -66,7 +66,7 @@ test "binary 5" {
|
|||
try test_binary(&bytes, "A" ** 65535);
|
||||
}
|
||||
|
||||
test "binary 6" {
|
||||
test "bin32" {
|
||||
var bytes: [5 + 65536]u8 = undefined;
|
||||
|
||||
bytes[0] = 0xc6;
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@ const std = @import("std");
|
|||
|
||||
pub const msgpack = @import("msgpack");
|
||||
|
||||
const deserialise = msgpack.deserialise.deserialise;
|
||||
const deserialise = msgpack.deserialise;
|
||||
|
||||
fn test_int(bytes: []const u8, expected: i64) !void {
|
||||
const alloc = std.testing.allocator;
|
||||
|
|
|
|||
|
|
@ -1,13 +1,13 @@
|
|||
const std = @import("std");
|
||||
|
||||
pub const msgpack = @import("msgpack");
|
||||
|
||||
pub const binary = @import("binary.zig");
|
||||
pub const string = @import("string.zig");
|
||||
pub const int = @import("int.zig");
|
||||
pub const uint = @import("uint.zig");
|
||||
|
||||
pub const msgpack = @import("msgpack");
|
||||
|
||||
const deserialise = msgpack.deserialise.deserialise;
|
||||
const deserialise = msgpack.deserialise;
|
||||
|
||||
test {
|
||||
@import("std").testing.refAllDecls(@This());
|
||||
|
|
@ -39,3 +39,64 @@ test "bool" {
|
|||
try std.testing.expectEqualDeep(msgpack.Object{ .bool = true }, obj);
|
||||
}
|
||||
}
|
||||
|
||||
test "f32" {
|
||||
const alloc = std.testing.allocator;
|
||||
|
||||
{
|
||||
const obj = try deserialise(alloc, &[_]u8{ 0xca, 0x7f, 0x7f, 0xff, 0xff });
|
||||
defer obj.deinit(alloc);
|
||||
|
||||
// try std.testing.expectEqualDeep(msgpack.Object{ .float = 3.4028234e38 }, obj);
|
||||
try std.testing.expectEqual(3.4028234e38, obj.float32);
|
||||
}
|
||||
}
|
||||
|
||||
test "f64" {
|
||||
const alloc = std.testing.allocator;
|
||||
|
||||
{
|
||||
const obj = try deserialise(alloc, &[_]u8{ 0xcb, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 });
|
||||
defer obj.deinit(alloc);
|
||||
|
||||
try std.testing.expectEqualDeep(msgpack.Object{ .float64 = 0.0 }, obj);
|
||||
}
|
||||
|
||||
{
|
||||
const obj = try deserialise(alloc, &[_]u8{ 0xcb, 0x40, 0x45, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 });
|
||||
defer obj.deinit(alloc);
|
||||
|
||||
try std.testing.expectEqualDeep(msgpack.Object{ .float64 = 42.0 }, obj);
|
||||
}
|
||||
}
|
||||
|
||||
test "array" {
|
||||
const alloc = std.testing.allocator;
|
||||
|
||||
{
|
||||
const obj = try deserialise(alloc, &[_]u8{ 0x92, 0xa2, 0x6c, 0x65, 0xa4, 0x73, 0x68, 0x69, 0x74 });
|
||||
defer obj.deinit(alloc);
|
||||
|
||||
try std.testing.expectEqual(2, obj.array.len);
|
||||
|
||||
try std.testing.expectEqualStrings("le", obj.array[0].string);
|
||||
try std.testing.expectEqualStrings("shit", obj.array[1].string);
|
||||
}
|
||||
}
|
||||
|
||||
test "map" {
|
||||
const alloc = std.testing.allocator;
|
||||
|
||||
{
|
||||
const obj = try deserialise(alloc, &[_]u8{ 0x82, 0x00, 0xa2, 0x6c, 0x65, 0x01, 0xa4, 0x73, 0x68, 0x69, 0x74 });
|
||||
defer obj.deinit(alloc);
|
||||
|
||||
try std.testing.expectEqual(2, obj.map.len);
|
||||
|
||||
try std.testing.expectEqual(0, obj.map[0].key.uinteger);
|
||||
try std.testing.expectEqualStrings("le", obj.map[0].value.string);
|
||||
|
||||
try std.testing.expectEqual(1, obj.map[1].key.uinteger);
|
||||
try std.testing.expectEqualStrings("shit", obj.map[1].value.string);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@ const std = @import("std");
|
|||
|
||||
const msgpack = @import("msgpack");
|
||||
|
||||
const deserialise = msgpack.deserialise.deserialise;
|
||||
const deserialise = msgpack.deserialise;
|
||||
|
||||
fn test_string(bytes: []const u8, expected: []const u8) !void {
|
||||
const alloc = std.testing.allocator;
|
||||
|
|
@ -10,26 +10,26 @@ fn test_string(bytes: []const u8, expected: []const u8) !void {
|
|||
const obj = try deserialise(alloc, bytes);
|
||||
defer obj.deinit(alloc);
|
||||
|
||||
try std.testing.expectEqualStrings(expected, obj.raw.string);
|
||||
try std.testing.expectEqualStrings(expected, obj.string);
|
||||
}
|
||||
|
||||
test "string 1" {
|
||||
test "fixstr 1" {
|
||||
const bytes = [_]u8{ 0b101_00000 | 0x03, 'A', 'B', 'C' };
|
||||
|
||||
try test_string(&bytes, "ABC");
|
||||
}
|
||||
|
||||
test "string 2" {
|
||||
test "str8 1" {
|
||||
const bytes = [_]u8{ 0xd9, 0x03, 'A', 'B', 'C' };
|
||||
|
||||
try test_string(&bytes, "ABC");
|
||||
}
|
||||
test "string 3" {
|
||||
test "empty string" {
|
||||
const bytes = [_]u8{ 0xd9, 0x00 };
|
||||
|
||||
try test_string(&bytes, "");
|
||||
}
|
||||
test "string 4" {
|
||||
test "str8 2" {
|
||||
var bytes: [2 + 255]u8 = undefined;
|
||||
|
||||
bytes[0] = 0xd9;
|
||||
|
|
@ -41,7 +41,7 @@ test "string 4" {
|
|||
|
||||
try test_string(&bytes, "A" ** 255);
|
||||
}
|
||||
test "string 5" {
|
||||
test "str16 1" {
|
||||
var bytes: [3 + 256]u8 = undefined;
|
||||
|
||||
bytes[0] = 0xda;
|
||||
|
|
@ -54,7 +54,7 @@ test "string 5" {
|
|||
|
||||
try test_string(&bytes, "A" ** 256);
|
||||
}
|
||||
test "string 6" {
|
||||
test "str16 2" {
|
||||
var bytes: [3 + 65535]u8 = undefined;
|
||||
|
||||
bytes[0] = 0xda;
|
||||
|
|
@ -67,7 +67,7 @@ test "string 6" {
|
|||
|
||||
try test_string(&bytes, "A" ** 65535);
|
||||
}
|
||||
test "string 7" {
|
||||
test "str32 1" {
|
||||
var bytes: [5 + 65536]u8 = undefined;
|
||||
|
||||
bytes[0] = 0xdb;
|
||||
|
|
@ -82,3 +82,6 @@ test "string 7" {
|
|||
|
||||
try test_string(&bytes, "A" ** 65536);
|
||||
}
|
||||
test "fixstr 2" {
|
||||
try test_string(&[_]u8{ 0xaa, 0x6c, 0x65, 0x20, 0x6d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65 }, "le message");
|
||||
}
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@ const std = @import("std");
|
|||
|
||||
pub const msgpack = @import("msgpack");
|
||||
|
||||
const deserialise = msgpack.deserialise.deserialise;
|
||||
const deserialise = msgpack.deserialise;
|
||||
|
||||
fn test_uint(bytes: []const u8, expected: u64) !void {
|
||||
const alloc = std.testing.allocator;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue