Sha256: eee53780b25a0712001ca0d4caa135b66704a396241990040122a5c291e17f14

Contents?: true

Size: 1.56 KB

Versions: 3

Compression:

Stored size: 1.56 KB

Contents

open Core.Std
open OUnit2
open Model
open Codegen
open Special_cases

let ae exp got _ctxt = assert_equal ~printer:Fn.id exp got

let tuples_printer kvs =
  String.concat ~sep:";" @@ List.map ~f:(fun (k,v) -> "(" ^ k ^ "," ^ v ^ ")") kvs

let stringify = function
  | Bool true -> "stringified"
  | _ -> failwith "Bad type for stringify"

let special_cases_tests = [
  "for a non special cased slug convert the parameter to a string" >:: (fun _ctx ->
      assert_equal ~printer:Fn.id "stringified" @@ fixup ~stringify ~slug:"some-slug" ~key:"key" ~value:(Bool true)
    );

  "an optional int parameter is converted to none if it matches the special value" >:: (fun _ctx ->
      assert_equal "None" @@ optional_int ~none:88 (Int 88)
    );

  "an optional int parameter is converted to (Some value) if it does not match the special value" >:: (fun _ctx ->
      assert_equal "(Some 0)" @@ optional_int ~none:88 (Int 0)
    );

  "default_value does not provide a default for a list that has the given key already" >:: (fun _ctx ->
      let ps = [("key", "value")] in
      assert_equal ps @@ default_value ~key:"key" ~value:"value2" ps
    );

  "default_value does provides a default for a list that does not have the given key" >:: (fun _ctx ->
      assert_equal [("key", "value")] @@ default_value ~key:"key" ~value:"value" []
    );

  "optional_string replace value with Some(value)" >:: (fun _ctx ->
      assert_equal ~printer:tuples_printer [("key", "(Some \"value\")"); ("key2", "value2")]
        @@ optional_string ~f:(fun x -> x = "key") [("key", "value"); ("key2", "value2")]
    );
]

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
trackler-2.0.1.1 tracks/ocaml/tools/test-generator/test/special_cases_test.ml
trackler-2.0.1.0 tracks/ocaml/tools/test-generator/test/special_cases_test.ml
trackler-2.0.0.10 tracks/ocaml/tools/test-generator/test/special_cases_test.ml