Skip to content

Commit

Permalink
[CN-Test-Gen] Enum hints for --with-static-hack (rems-project#812)
Browse files Browse the repository at this point in the history
  • Loading branch information
ZippeyKeys12 authored Jan 3, 2025
1 parent 6d4b486 commit 6316f8f
Show file tree
Hide file tree
Showing 3 changed files with 65 additions and 3 deletions.
54 changes: 51 additions & 3 deletions backend/cn/lib/testGeneration/testGeneration.ml
Original file line number Diff line number Diff line change
Expand Up @@ -209,6 +209,7 @@ let save_build_script ~output_dir ~filename_base =
save ~perm:0o777 output_dir "run_tests.sh" script_doc


(** Workaround for https://github.com/rems-project/cerberus/issues/784 *)
let needs_static_hack
~(with_warning : bool)
(cabs_tunit : CF.Cabs.translation_unit)
Expand Down Expand Up @@ -241,7 +242,7 @@ let needs_static_hack
(string "Static function"
^^^ squotes (Sym.pp inst.fn)
^^^ string "could not be tested."
^/^ string "You can try again with '--with-static-hack'")))
^/^ string "Try again with '--with-static-hack'")))
();
true
| _ -> false)
Expand Down Expand Up @@ -285,14 +286,59 @@ let needs_static_hack
^^^ squotes (Sym.pp sym)
^^ comma
^^^ string "so could not be tested."
^^^ string "You can try again with '--with-static-hack'.")))
^^^ string "Try again with '--with-static-hack'.")))
static_globs)
();
true)
in
is_static_func () || depends_on_static_glob ()


(** Workaround for https://github.com/rems-project/cerberus/issues/765 *)
let needs_enum_hack
~(with_warning : bool)
(sigma : CF.GenTypes.genTypeCategory A.sigma)
(inst : Executable_spec_extract.instrumentation)
=
match List.assoc Sym.equal inst.fn sigma.declarations with
| loc, _, Decl_function (_, (_, ret_ct), cts, _, _, _) ->
if
List.exists
(fun (_, ct, _) ->
match ct with C.Ctype (_, Basic (Integer (Enum _))) -> true | _ -> false)
cts
then (
if with_warning then
Cerb_colour.with_colour
(fun () ->
Pp.(
warn
loc
(string "Function"
^^^ squotes (Sym.pp inst.fn)
^^^ string "has enum arguments and so could not be tested."
^/^ string "Try again with '--with-static-hack'")))
();
true)
else if match ret_ct with C.Ctype (_, Basic (Integer (Enum _))) -> true | _ -> false
then (
if with_warning then
Cerb_colour.with_colour
(fun () ->
Pp.(
warn
loc
(string "Function"
^^^ squotes (Sym.pp inst.fn)
^^^ string "has an enum return type and so could not be tested."
^/^ string "Try again with '--with-static-hack'")))
();
true)
else
false
| _ -> false


let functions_under_test
~(with_warning : bool)
(cabs_tunit : CF.Cabs.translation_unit)
Expand All @@ -313,7 +359,9 @@ let functions_under_test
Option.is_some inst.internal
&& Sym.Set.mem inst.fn selected_fsyms
&& (Config.with_static_hack ()
|| not (needs_static_hack ~with_warning cabs_tunit sigma inst)))
|| not
(needs_static_hack ~with_warning cabs_tunit sigma inst
|| needs_enum_hack ~with_warning sigma inst)))


let run
Expand Down
7 changes: 7 additions & 0 deletions tests/cn-test-gen/src/enum1.pass.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
enum color {
Red, Green, Blue
};

enum color identity(enum color x) {
return x;
}
7 changes: 7 additions & 0 deletions tests/cn-test-gen/src/enum2.pass.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
enum color {
Red, Green, Blue
};

enum color identity() {
return Red;
}

0 comments on commit 6316f8f

Please sign in to comment.