aboutsummaryrefslogtreecommitdiff
path: root/tests/core/encoding/json
diff options
context:
space:
mode:
Diffstat (limited to 'tests/core/encoding/json')
-rw-r--r--tests/core/encoding/json/test_core_json.odin21
1 files changed, 21 insertions, 0 deletions
diff --git a/tests/core/encoding/json/test_core_json.odin b/tests/core/encoding/json/test_core_json.odin
index 62f474ce0..10e09df3b 100644
--- a/tests/core/encoding/json/test_core_json.odin
+++ b/tests/core/encoding/json/test_core_json.odin
@@ -372,6 +372,27 @@ utf8_string_of_multibyte_characters :: proc(t: ^testing.T) {
}
@test
+struct_with_ignore_tags :: proc(t: ^testing.T) {
+ My_Struct :: struct {
+ a: string `json:"-"`,
+ }
+
+ my_struct := My_Struct{
+ a = "test",
+ }
+
+ my_struct_marshaled, marshal_err := json.marshal(my_struct)
+ defer delete(my_struct_marshaled)
+
+ testing.expectf(t, marshal_err == nil, "Expected `json.marshal` to return nil error, got %v", marshal_err)
+
+ my_struct_json := transmute(string)my_struct_marshaled
+ expected_json := `{}`
+
+ testing.expectf(t, expected_json == my_struct_json, "Expected `json.marshal` to return %s, got %s", expected_json, my_struct_json)
+}
+
+@test
map_with_integer_keys :: proc(t: ^testing.T) {
my_map := make(map[i32]string)
defer delete_map(my_map)