diff options
author | Louis Pilfold <louis@lpil.uk> | 2023-08-03 13:31:34 +0100 |
---|---|---|
committer | Louis Pilfold <louis@lpil.uk> | 2023-08-03 13:33:50 +0100 |
commit | f0bb7f8e13ffb33d36c03aa98589218e2dc9eee9 (patch) | |
tree | 1db53b9b6c4e77c6df0d7c51a67f87261f7305ca /test/gleam_json_js_ffi_test.gleam | |
parent | 48f6516428679c6240ed996e53c14b8c3f492f1a (diff) | |
download | gleam_json-f0bb7f8e13ffb33d36c03aa98589218e2dc9eee9.tar.gz gleam_json-f0bb7f8e13ffb33d36c03aa98589218e2dc9eee9.zip |
Update for Gleam v0.30
Diffstat (limited to 'test/gleam_json_js_ffi_test.gleam')
-rw-r--r-- | test/gleam_json_js_ffi_test.gleam | 123 |
1 files changed, 66 insertions, 57 deletions
diff --git a/test/gleam_json_js_ffi_test.gleam b/test/gleam_json_js_ffi_test.gleam index f746ce2..df1b763 100644 --- a/test/gleam_json_js_ffi_test.gleam +++ b/test/gleam_json_js_ffi_test.gleam @@ -1,67 +1,76 @@ -if javascript { - import gleam/json.{DecodeError, UnexpectedByte, UnexpectedEndOfInput} - import gleeunit/should +@target(javascript) +import gleam/json.{DecodeError, UnexpectedByte, UnexpectedEndOfInput} +@target(javascript) +import gleeunit/should - type StandardError { - StandardError(message: String) - } - - // === End of input tests === // - pub fn chromium_end_of_input_test() { - "Unexpected end of JSON input" - |> StandardError - |> get_json_decode_error("") - |> should.equal(UnexpectedEndOfInput) - } +@target(javascript) +type StandardError { + StandardError(message: String) +} - pub fn spidermonkey_end_of_input_test() { - "JSON.parse: unexpected end of data at line 1 column 1 of the JSON data" - |> StandardError - |> get_json_decode_error("") - |> should.equal(UnexpectedEndOfInput) - } +// === End of input tests === // +@target(javascript) +pub fn chromium_end_of_input_test() { + "Unexpected end of JSON input" + |> StandardError + |> get_json_decode_error("") + |> should.equal(UnexpectedEndOfInput) +} - pub fn javascript_core_end_of_input_test() { - "JSON Parse error: Unexpected EOF" - |> StandardError - |> get_json_decode_error("") - |> should.equal(UnexpectedEndOfInput) - } +@target(javascript) +pub fn spidermonkey_end_of_input_test() { + "JSON.parse: unexpected end of data at line 1 column 1 of the JSON data" + |> StandardError + |> get_json_decode_error("") + |> should.equal(UnexpectedEndOfInput) +} - // === Unexpected byte tests === // - pub fn chromium_unexpected_byte_test() { - "Unexpected token a in JSON at position 5" - |> StandardError - |> get_json_decode_error("{\"b\":a}") - |> should.equal(UnexpectedByte(byte: "0x61", position: 5)) - } +@target(javascript) +pub fn javascript_core_end_of_input_test() { + "JSON Parse error: Unexpected EOF" + |> StandardError + |> get_json_decode_error("") + |> should.equal(UnexpectedEndOfInput) +} - pub fn spidermonkey_unexpected_byte_test() { - "JSON.parse: expected property name or '}' at line 1 column 6 of the JSON data" - |> StandardError - |> get_json_decode_error("{\"b\":a}") - |> should.equal(UnexpectedByte(byte: "0x61", position: 5)) - } +// === Unexpected byte tests === // +@target(javascript) +pub fn chromium_unexpected_byte_test() { + "Unexpected token a in JSON at position 5" + |> StandardError + |> get_json_decode_error("{\"b\":a}") + |> should.equal(UnexpectedByte(byte: "0x61", position: 5)) +} - pub fn javascript_core_unexpected_byte_test() { - "JSON Parse error: Unexpected identifier \"a\"" - |> StandardError - |> get_json_decode_error("{\"b\":a}") - |> should.equal(UnexpectedByte(byte: "0x61", position: 0)) - } +@target(javascript) +pub fn spidermonkey_unexpected_byte_test() { + "JSON.parse: expected property name or '}' at line 1 column 6 of the JSON data" + |> StandardError + |> get_json_decode_error("{\"b\":a}") + |> should.equal(UnexpectedByte(byte: "0x61", position: 5)) +} - pub fn spidermonkey_multiline_unexpected_byte_test() { - "JSON.parse: expected property name or '}' at line 2 column 6 of the JSON data" - |> StandardError - |> get_json_decode_error("{\n\"b\": a\n}") - |> should.equal(UnexpectedByte(byte: "0x61", position: 7)) +@target(javascript) +pub fn javascript_core_unexpected_byte_test() { + "JSON Parse error: Unexpected identifier \"a\"" + |> StandardError + |> get_json_decode_error("{\"b\":a}") + |> should.equal(UnexpectedByte(byte: "0x61", position: 0)) +} - "JSON.parse: expected double-quoted property name at line 3 column 1 of the JSON data" - |> StandardError - |> get_json_decode_error("{\n\"b\": \"x\",\na\n}") - |> should.equal(UnexpectedByte(byte: "0x61", position: 12)) - } +@target(javascript) +pub fn spidermonkey_multiline_unexpected_byte_test() { + "JSON.parse: expected property name or '}' at line 2 column 6 of the JSON data" + |> StandardError + |> get_json_decode_error("{\n\"b\": a\n}") + |> should.equal(UnexpectedByte(byte: "0x61", position: 7)) - external fn get_json_decode_error(StandardError, String) -> DecodeError = - "./gleam_json_ffi.mjs" "getJsonDecodeError" + "JSON.parse: expected double-quoted property name at line 3 column 1 of the JSON data" + |> StandardError + |> get_json_decode_error("{\n\"b\": \"x\",\na\n}") + |> should.equal(UnexpectedByte(byte: "0x61", position: 12)) } + +@target(javascript) +@external(javascript, "./gleam_json_ffi.mjs", "getJsonDecodeError") +fn get_json_decode_error(a: StandardError, b: String) -> DecodeError |