Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

update dune lang to 3.0 #7

Merged
merged 2 commits into from
Dec 23, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .ocamlformat
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
profile=janestreet
version=0.27.0
5 changes: 4 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,7 @@ test:
clean:
dune clean

.PHONY: examples doc test build
fmt:
dune build @fmt --auto-promote

.PHONY: examples doc test build fmt
3 changes: 1 addition & 2 deletions alcotest/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,4 @@
(public_name junit_alcotest)
(wrapped false)
(synopsis "JUnit XML reports generation for alcotest tests")
(libraries junit alcotest)
(flags :standard -safe-string -short-paths))
(libraries junit alcotest))
34 changes: 14 additions & 20 deletions alcotest/junit_alcotest.ml
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,7 @@ let wrap_test ?classname handle_result (name, s, test) =
let test () =
try
test ();
Junit.Testcase.pass
~name
~classname
~time:0.
|> handle_result
Junit.Testcase.pass ~name ~classname ~time:0. |> handle_result
with
| Failure exn_msg as exn ->
Junit.Testcase.failure
Expand All @@ -35,11 +31,7 @@ let wrap_test ?classname handle_result (name, s, test) =
|> handle_result;
raise exn
| Alcotest_engine__Core.Skip ->
Junit.Testcase.skipped
~name
~classname
~time:0.
|> handle_result
Junit.Testcase.skipped ~name ~classname ~time:0. |> handle_result
| exn ->
let exn_msg = Printexc.to_string exn in
Junit.Testcase.error
Expand All @@ -52,25 +44,27 @@ let wrap_test ?classname handle_result (name, s, test) =
|> handle_result;
raise exn
in
(name, s, test)
name, s, test
;;

let run ?argv name tl =
A.run ~and_exit:false ?argv name tl
let run ?argv name tl = A.run ~and_exit:false ?argv name tl

let run_and_report ?(and_exit=true) ?package ?timestamp ?argv name tests =
let run_and_report ?(and_exit = true) ?package ?timestamp ?argv name tests =
let testcases = ref [] in
let testsuite = Junit.Testsuite.make ?package ?timestamp ~name () in
let tests =
List.map (fun (title, test_set) ->
let classname = Printf.sprintf "%s.%s" name title in
(title, List.map (wrap_test ~classname (push testcases)) test_set)
) tests
List.map
(fun (title, test_set) ->
let classname = Printf.sprintf "%s.%s" name title in
title, List.map (wrap_test ~classname (push testcases)) test_set)
tests
in
let exit =
try
run ?argv name tests;
fun () -> if and_exit then exit 0 else ()
with A.Test_error ->
fun () -> if and_exit then exit 1 else raise A.Test_error
with
| A.Test_error -> fun () -> if and_exit then exit 1 else raise A.Test_error
in
Junit.Testsuite.add_testcases !testcases testsuite, exit
;;
62 changes: 29 additions & 33 deletions alcotest/junit_alcotest.mli
Original file line number Diff line number Diff line change
@@ -1,50 +1,39 @@
(** Interface to product JUnit reports for Alcotest

It tries to provide a layer as thin as possible on top of Alcotest
to allow to port existing test without writing a lot a boilerplate.
*)

val wrap_test :
?classname:string ->
(Junit.Testcase.t -> unit) ->
unit Alcotest.test_case ->
unit Alcotest.test_case
to allow to port existing test without writing a lot a boilerplate. *)

(** [wrap_test handle_result test_cases] wraps test cases to create
Junit testcases and pass them to [handle_result].

Can be used with {!run} to create customized Junit testsuites if
the output of {!run_and_report} is not as expected.

@param classname will populate the 'classname' attribute
for the test case. For best hierarchic rendering in Jenkins, it
should contain a period. For example, "foo.bar.baz" will be rendered
a package "foo.bar" that contains a class "baz", which contains the
current test case and others. Defaults to the name of the test case.
*)
@param classname
will populate the 'classname' attribute
for the test case. For best hierarchic rendering in Jenkins, it
should contain a period. For example, "foo.bar.baz" will be rendered
a package "foo.bar" that contains a class "baz", which contains the
current test case and others. Defaults to the name of the test case. *)
val wrap_test
: ?classname:string
-> (Junit.Testcase.t -> unit)
-> unit Alcotest.test_case
-> unit Alcotest.test_case

val run: ?argv:string array -> string -> unit Alcotest.test list -> unit
(** [run ?argv n t] is a wrapper around {!Alcotest.run}, only setting
[and_exit] to false. It is mandatory to be able to process results
after the end of the run.

Low level function. It is easier to use {!run_and_report}.
*)
Low level function. It is easier to use {!run_and_report}. *)
val run : ?argv:string array -> string -> unit Alcotest.test list -> unit

type exit = unit -> unit
(** [exit ()] exists with appropriate code if {!run_and_report}'s
(** [exit ()] exits with appropriate code if {!run_and_report}'s
[and_exit] was [true] or raise {!Alcotest.Test_error} in case of
error.
*)

val run_and_report:
?and_exit:bool ->
?package:string ->
?timestamp:Ptime.t ->
?argv:string array ->
string ->
(string * unit Alcotest.test_case list) list ->
(Junit.Testsuite.t * exit)
(** [run name tests] is a wrapper around {!run} and {!wrap_test}. It
error. *)
type exit = unit -> unit

(** [run_and_report name tests] is a wrapper around {!run} and {!wrap_test}. It
runs the tests and creates a Junit testsuite from the results.

As {!Alcotest.run} is always called with [and_exit = false] to be
Expand All @@ -58,5 +47,12 @@ val run_and_report:
raises [Test_error] on error.

[?argv] is forwarded to {!run}. [?package] and [?timestamp] are
forwarded to {!Junit.Testsuite.make}.
*)
forwarded to {!Junit.Testsuite.make}. *)
val run_and_report
: ?and_exit:bool
-> ?package:string
-> ?timestamp:Ptime.t
-> ?argv:string array
-> string
-> (string * unit Alcotest.test_case list) list
-> Junit.Testsuite.t * exit
92 changes: 49 additions & 43 deletions alcotest/test/alcotest_report.ml
Original file line number Diff line number Diff line change
Expand Up @@ -6,68 +6,74 @@ module To_test = struct
let plus int_list = List.fold_left (fun a b -> a + b) 0 int_list
end

let capit () =
A.(check char) "Check A" 'A' (To_test.capit 'a')

let plus () =
A.(check int) "Sum equals to 7" 7 (To_test.plus [1;1;2;3])

let wrong_result () =
A.(check string) "string_of_int equals to '7'" "7" (string_of_int 8)
let capit () = A.(check char) "Check A" 'A' (To_test.capit 'a')
let plus () = A.(check int) "Sum equals to 7" 7 (To_test.plus [ 1; 1; 2; 3 ])
let wrong_result () = A.(check string) "string_of_int equals to '7'" "7" (string_of_int 8)

let raise_unexpected_exn () =
A.(check int) "int_of_string equals to 7" 7 (invalid_arg "7")
;;

let test_set = [
A.test_case "Test with unexpected exception" `Quick raise_unexpected_exn;
A.test_case "Capitalize" `Quick capit;
A.test_case "Add entries" `Slow plus;
A.test_case "Test with wrong result" `Quick wrong_result;
]
let test_set =
[ A.test_case "Test with unexpected exception" `Quick raise_unexpected_exn
; A.test_case "Capitalize" `Quick capit
; A.test_case "Add entries" `Slow plus
; A.test_case "Test with wrong result" `Quick wrong_result
]
;;

let success_test_set = [
A.test_case "Capitalize" `Quick capit;
A.test_case "Add entries" `Slow plus;
]
let success_test_set =
[ A.test_case "Capitalize" `Quick capit; A.test_case "Add entries" `Slow plus ]
;;

let skipped_test_set = [
A.test_case "Skipped quick" `Quick (fun () -> A.skip ());
A.test_case "Skipped slow" `Slow (fun () -> A.skip ());
]
let skipped_test_set =
[ A.test_case "Skipped quick" `Quick (fun () -> A.skip ())
; A.test_case "Skipped slow" `Slow (fun () -> A.skip ())
]
;;

let timestamp =
match Ptime.of_date_time ((2013, 5, 24), ((10, 23, 58), 0)) with
| Some t -> t
| None -> assert false
;;

let alcotest path =
let package = "junit_alcotest" in
let (testsuite0, _) = JA.run_and_report ~package ~timestamp "Skip test suite" [
"Skipped tests", skipped_test_set;
]
let testsuite0, _ =
JA.run_and_report
~package
~timestamp
"Skip test suite"
[ "Skipped tests", skipped_test_set ]
in
let (testsuite1, _) = JA.run_and_report ~package ~timestamp "My first test" [
"Basic tests", test_set;
]
let testsuite1, _ =
JA.run_and_report ~package ~timestamp "My first test" [ "Basic tests", test_set ]
in
let (testsuite2, _) = JA.run_and_report ~package ~timestamp "My second test" [
"Basic tests", test_set;
]
let testsuite2, _ =
JA.run_and_report ~package ~timestamp "My second test" [ "Basic tests", test_set ]
in
let (testsuite3, exit) = JA.run_and_report ~and_exit:false ~package ~timestamp "Success test suite" [
"Good tests", success_test_set;
]
let testsuite3, exit =
JA.run_and_report
~and_exit:false
~package
~timestamp
"Success test suite"
[ "Good tests", success_test_set ]
in
let report = Junit.make [testsuite0; testsuite1; testsuite2; testsuite3] in
begin match path with
| None ->
let xml_report = Junit.to_xml report in
Format.printf "%a\n" (Tyxml.Xml.pp ()) xml_report
| Some path ->
Junit.to_file report path
end;
let report = Junit.make [ testsuite0; testsuite1; testsuite2; testsuite3 ] in
(match path with
| None ->
let xml_report = Junit.to_xml report in
Format.printf "%a\n" (Tyxml.Xml.pp ()) xml_report
| Some path -> Junit.to_file report path);
exit ()
;;

let () =
let path = try Some (Sys.getenv "REPORT_PATH") with _ -> None in
let path =
try Some (Sys.getenv "REPORT_PATH") with
| _ -> None
in
alcotest path
;;
11 changes: 6 additions & 5 deletions alcotest/test/dune
Original file line number Diff line number Diff line change
@@ -1,17 +1,18 @@
(executable
(name alcotest_report)
(modules alcotest_report)
(libraries junit junit_alcotest)
(flags :standard -safe-string -short-paths))
(libraries junit junit_alcotest))

(rule
(targets alcotest_report.xml)
(action
(setenv REPORT_PATH %{targets}
(setenv
REPORT_PATH
%{targets}
(run %{dep:alcotest_report.exe}))))

(alias
(name runtest)
(rule
(alias runtest)
(package junit_alcotest)
(action
(diff %{dep:alcotest_report.expected} %{dep:alcotest_report.xml}))
Expand Down
2 changes: 1 addition & 1 deletion dune-project
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
(lang dune 1.0)
(lang dune 3.0)
(name junit)
3 changes: 2 additions & 1 deletion junit.opam
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,11 @@ dev-repo: "git+https://github.com/Khady/ocaml-junit.git"
doc: "https://khady.github.io/ocaml-junit/"
tags: ["junit" "jenkins"]
depends: [
"dune" {>= "1.0"}
"dune" {>= "3.0"}
"ptime"
"tyxml" {>= "4.0.0"}
"odoc" {with-doc & >= "1.1.1"}
"ocamlformat" {= "0.27.0" & with-dev-setup}
]
build: [
["dune" "subst"] {dev}
Expand Down
3 changes: 1 addition & 2 deletions junit/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,4 @@
(public_name junit)
(wrapped false)
(synopsis "JUnit XML reports generation library")
(libraries tyxml ptime ptime.clock.os)
(flags :standard -safe-string -short-paths))
(libraries tyxml ptime ptime.clock.os))
Loading
Loading