ligo/vendors/ocaml-secp256k1/test/test.ml
2018-04-26 21:24:21 +02:00

142 lines
6.0 KiB
OCaml

open Libsecp256k1
let assert_equal a b = assert (a = b)
module Num = struct
open Internal
open Num
let basic () =
let z = zero () in
assert_equal true (is_zero z)
let runtest =
[ "basic", `Quick, basic ;
]
end
module Scalar = struct
open Internal
open Scalar
let basic () =
let z = zero () in
assert_equal true (is_zero z) ;
(* set_int z 1 ; *)
let z = const ~d0:1L () in
assert_equal false (is_zero z) ;
assert_equal false (is_even z) ;
assert_equal true (is_one z)
let runtest =
[ "basic", `Quick, basic ;
]
end
module External = struct
open External
let buffer_of_hex s =
let { Cstruct.buffer; off = _ ; len = _ } = Hex.to_cstruct (`Hex s) in
buffer
let ctx = Context.create [ Sign ; Verify ]
let cstruct_testable =
Alcotest.testable Cstruct.hexdump_pp Cstruct.equal
let assert_eq_cstruct a b =
let a = Cstruct.of_bigarray a in
let b = Cstruct.of_bigarray b in
assert (Alcotest.equal cstruct_testable a b)
let test_signature_of_string () =
let sign_orig = buffer_of_hex
"3044022079BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F817980220294F14E883B3F525B5367756C2A11EF6CF84B730B36C17CB0C56F0AAB2C98589" in
let signature = Sign.read_der_exn ctx sign_orig in
let sign = Sign.to_bytes ~der:true ctx signature in
assert_eq_cstruct sign_orig sign
let test_valid_signature _ =
let ctx = Context.create [Verify] in
let msg = Sign.msg_of_bytes_exn @@ buffer_of_hex
"CF80CD8AED482D5D1527D7DC72FCEFF84E6326592848447D2DC0B0E87DFC9A90" in
let signature = Sign.read_der_exn ctx
(buffer_of_hex "3044022079BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F817980220294F14E883B3F525B5367756C2A11EF6CF84B730B36C17CB0C56F0AAB2C98589") in
let pk = Key.read_pk_exn ctx
(buffer_of_hex "040A629506E1B65CD9D2E0BA9C75DF9C4FED0DB16DC9625ED14397F0AFC836FAE595DC53F8B0EFE61E703075BD9B143BAC75EC0E19F82A2208CAEB32BE53414C40") in
assert (Sign.verify_exn ctx ~signature ~pk ~msg)
let test_invalid_signature _ =
let ctx = Context.create [Verify] in
let msg = Sign.msg_of_bytes_exn @@ buffer_of_hex
"CF80CD8AED482D5D1527D7DC72FCEFF84E6326592848447D2DC0B0E87DFC9A91" in
let signature = Sign.read_der_exn ctx
(buffer_of_hex "3044022079BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F817980220294F14E883B3F525B5367756C2A11EF6CF84B730B36C17CB0C56F0AAB2C98589") in
let pk = Key.read_pk_exn ctx
(buffer_of_hex "040a629506e1b65cd9d2e0ba9c75df9c4fed0db16dc9625ed14397f0afc836fae595dc53f8b0efe61e703075bd9b143bac75ec0e19f82a2208caeb32be53414c40") in
assert (not (Sign.verify_exn ctx ~signature ~pk ~msg))
let test_public_module _ =
let pubtrue =
buffer_of_hex "04c591a8ff19ac9c4e4e5793673b83123437e975285e7b442f4ee2654dffca5e2d2103ed494718c697ac9aebcfd19612e224db46661011863ed2fc54e71861e2a6" in
let pub = Key.read_pk_exn ctx pubtrue in
let pub_serialized = Key.to_bytes ~compress:false ctx pub in
assert_eq_cstruct pubtrue pub_serialized
let test_pubkey_creation _ =
let seckey = buffer_of_hex "67E56582298859DDAE725F972992A07C6C4FB9F62A8FFF58CE3CA926A1063530" in
let pubtrue = buffer_of_hex "04c591a8ff19ac9c4e4e5793673b83123437e975285e7b442f4ee2654dffca5e2d2103ed494718c697ac9aebcfd19612e224db46661011863ed2fc54e71861e2a6" in
let seckey = Key.read_sk_exn ctx seckey in
let pubkey = Key.neuterize_exn ctx seckey in
let buf_pk_comp = Cstruct.create 33 in
let buf_pk_uncomp = Cstruct.create 65 in
let nb_written = Key.write ~compress:true ctx buf_pk_comp.buffer pubkey in
assert (nb_written = 33) ;
let nb_written = Key.write ~compress:false ctx buf_pk_uncomp.buffer pubkey in
assert (nb_written = 65) ;
let nb_written = Key.write ~compress:true ctx buf_pk_uncomp.buffer ~pos:32 pubkey in
assert (nb_written = 33) ;
let pubkey_serialized = Key.to_bytes ~compress:false ctx pubkey in
assert_eq_cstruct pubtrue pubkey_serialized
let test_sign _ =
let ctx = Context.create [Sign] in
let msg = Sign.msg_of_bytes_exn @@ buffer_of_hex "CF80CD8AED482D5D1527D7DC72FCEFF84E6326592848447D2DC0B0E87DFC9A90" in
let sk = Key.read_sk_exn ctx (buffer_of_hex "67E56582298859DDAE725F972992A07C6C4FB9F62A8FFF58CE3CA926A1063530") in
let validsign = Sign.read_der_exn ctx (buffer_of_hex "30440220182a108e1448dc8f1fb467d06a0f3bb8ea0533584cb954ef8da112f1d60e39a202201c66f36da211c087f3af88b50edf4f9bdaa6cf5fd6817e74dca34db12390c6e9") in
let sign = Sign.sign_exn ctx ~sk ~msg in
assert (Sign.equal sign validsign)
let test_recover _ =
let ctx = Context.create [Sign; Verify] in
let msg = Sign.msg_of_bytes_exn @@ buffer_of_hex "CF80CD8AED482D5D1527D7DC72FCEFF84E6326592848447D2DC0B0E87DFC9A90" in
let seckey = Key.read_sk_exn ctx (buffer_of_hex "67E56582298859DDAE725F972992A07C6C4FB9F62A8FFF58CE3CA926A1063530") in
let pubkey = Key.neuterize_exn ctx seckey in
let recoverable_sign = Sign.sign_recoverable_exn ctx ~sk:seckey msg in
let usual_sign = Sign.to_plain ctx recoverable_sign in
assert (Sign.verify_exn ctx ~pk:pubkey ~signature:usual_sign ~msg);
let compact, recid = Sign.to_bytes_recid ctx recoverable_sign in
let usual_sign' = Sign.read_exn ctx compact in
assert (Sign.equal usual_sign' usual_sign) ;
let parsed = Sign.read_recoverable_exn ctx compact ~recid in
assert (Sign.equal parsed recoverable_sign);
match Sign.recover ctx ~signature:recoverable_sign ~msg with
| Error _ -> assert false
| Ok recovered -> assert (Key.equal recovered pubkey)
let runtest = [
"signature_of_string", `Quick, test_signature_of_string ;
"valid_signature", `Quick, test_valid_signature ;
"invalid_signature", `Quick, test_invalid_signature ;
"public_module", `Quick, test_public_module ;
"pubkey_creation", `Quick, test_pubkey_creation ;
"sign", `Quick, test_sign ;
"recover", `Quick, test_recover ;
]
end
let () =
Alcotest.run "secp256k1" [
"Num", Num.runtest ;
"Scalar", Scalar.runtest ;
"External", External.runtest ;
]