Parcourir la source

Add test for some functions of the module Edit_command

Leo il y a 9 ans
Parent
commit
be2e887323
2 fichiers modifiés avec 114 ajouts et 1 suppressions
  1. 113 0
      src/test/edit_t.ml
  2. 1 1
      src/test/test.ml

+ 113 - 0
src/test/edit_t.ml

@@ -0,0 +1,113 @@
+(******************************************************************************)
+(* Copyright © Joly Clément, 2015                                             *)
+(*                                                                            *)
+(*  leowzukw@vmail.me                                                         *)
+(*                                                                            *)
+(*  Ce logiciel est un programme informatique servant à exécuter              *)
+(*  automatiquement des programmes à l'ouverture du terminal.                 *)
+(*                                                                            *)
+(*  Ce logiciel est régi par la licence CeCILL soumise au droit français et   *)
+(*  respectant les principes de diffusion des logiciels libres. Vous pouvez   *)
+(*  utiliser, modifier et/ou redistribuer ce programme sous les conditions    *)
+(*  de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA    *)
+(*  sur le site "http://www.cecill.info".                                     *)
+(*                                                                            *)
+(*  En contrepartie de l'accessibilité au code source et des droits de copie, *)
+(*  de modification et de redistribution accordés par cette licence, il n'est *)
+(*  offert aux utilisateurs qu'une garantie limitée.  Pour les mêmes raisons, *)
+(*  seule une responsabilité restreinte pèse sur l'auteur du programme,  le   *)
+(*  titulaire des droits patrimoniaux et les concédants successifs.           *)
+(*                                                                            *)
+(*  A cet égard  l'attention de l'utilisateur est attirée sur les risques     *)
+(*  associés au chargement,  à l'utilisation,  à la modification et/ou au     *)
+(*  développement et à la reproduction du logiciel par l'utilisateur étant    *)
+(*  donné sa spécificité de logiciel libre, qui peut le rendre complexe à     *)
+(*  manipuler et qui le réserve donc à des développeurs et des professionnels *)
+(*  avertis possédant  des  connaissances  informatiques approfondies.  Les   *)
+(*  utilisateurs sont donc invités à charger  et  tester  l'adéquation  du    *)
+(*  logiciel à leurs besoins dans des conditions permettant d'assurer la      *)
+(*  sécurité de leurs systèmes et ou de leurs données et, plus généralement,  *)
+(*  à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.        *)
+(*                                                                            *)
+(*  Le fait que vous puissiez accéder à cet en-tête signifie que vous avez    *)
+(*  pris connaissance de la licence CeCILL, et que vous en avez accepté les   *)
+(*  termes.                                                                   *)
+(******************************************************************************)
+
+open Core.Std;;
+
+(* A module containing tests for src/edit_command.ml *)
+
+(* Function epur ============================= *)
+let epur test solution () =
+  let actual = Edit_command.epur test in
+  OUnit.assert_equal actual solution
+;;
+
+(* Data for above test *)
+let ll_data = [
+  ( [ "cmd1" ; "cmd2"; "" ], [ "cmd1" ; "cmd2" ], "Canonical case" );
+  ( [ "" ; "cmd1" ; "" ; "" ; "cmd2"; "" ], [ "cmd1" ; "cmd2" ], "Harder case" );
+  ( [], [], "Empty list" );
+  ( [ "" ; "" ; "" ], [], "Empty list resulting of empty strings" );
+]
+
+let llt_l =
+  List.map ll_data ~f:(fun (t, s, name) -> ( (epur t s), name))
+  |> List.map ~f:(fun ( f,name ) -> (name, `Quick, f))
+;;
+(* =========================================== *)
+
+
+(* Function new_list ========================= *)
+let n_list ( current_list, position, new_items ) solution () =
+  let actual = Edit_command.new_list current_list position new_items in
+  OUnit.assert_equal actual solution
+;;
+
+(* Data for above test *)
+let nl_data = [
+  ( ( [ "cmd1" ; "cmd2" ; "cmd3" ], 1, ["new_cmd"] ), [ "cmd1" ; "new_cmd" ; "cmd2" ; "cmd3" ], "Canonical case 1" );
+  ( ( [ "cmd1" ; "cmd2" ; "cmd3" ; "cmd4" ; "cmd5" ], 2, [ "cmd"  ; "cmd" ; "cmd" ] ),
+      [ "cmd1" ; "cmd2" ; "cmd"  ; "cmd" ; "cmd" ; "cmd3" ; "cmd4" ; "cmd5" ],
+      "Canonical case 2" );
+  ( ( [ "cmd1" ; "cmd2" ; "cmd3" ], 0, ["new_cmd"] ), [ "new_cmd" ; "cmd1" ;
+  "cmd2" ; "cmd3" ], "Insert on top" );
+  ( ( [ "cmd1" ; "cmd2" ; "cmd3" ; "cmd4" ; "cmd5" ], 4, ["new_cmd"] ), [ "cmd1"
+  ; "cmd2" ; "cmd3" ; "cmd4" ; "new_cmd" ; "cmd5" ], "Insert bottom" );
+  ( ( [], 0, [] ), [], "Empty list" );
+  ( ( [], 0, [ "new" ; "element" ] ), [ "new" ; "element" ], "Insertion of new elements in an empty list" );
+  ( ( [], 5, [ "new" ; "element" ] ), [ "new" ; "element" ], "Out of bound (inserting elements)" );
+  ( ( [], 5, [] ), [], "Out of bound (inserting nothing)" );
+]
+
+let big =
+  (
+    "Big list",
+    `Slow,
+    (fun () ->
+      let l = List.init 1_000_000 ~f:(fun a -> a) in
+      let pos = 5 in
+      let actual = Edit_command.new_list l pos [ -2 ; -1 ] in
+      let conformity li =
+        ((List.nth_exn li pos) = -2) &&
+        ((List.nth_exn li (succ pos)) = -1)
+      in
+      OUnit.assert_bool "My test" (conformity actual)
+    )
+  )
+;;
+
+let lt_l =
+  List.map nl_data ~f:(fun (t, s, name) -> ( (n_list t s), name))
+  |> List.map ~f:(fun ( f,name ) -> (name, `Quick, f))
+;;
+(* =========================================== *)
+
+(* To be used in test.ml *)
+let alco = [( "Edit_command.ml: Epur", llt_l ) ;
+  ( "Edit_command.ml: New list", ( big :: lt_l ) )
+];;
+
+
+

+ 1 - 1
src/test/test.ml

@@ -40,5 +40,5 @@ open Core.Std;;
 
 let () =
     Alcotest.run "Test suite for the project"
-        (List.concat [ Ec_t.alco ; Exec_t.alco ])
+        (List.concat [ Ec_t.alco ; Exec_t.alco ; Edit_t.alco ])
 ;;