File: TestStdFiles.ml

package info (click to toggle)
oasis 0.4.4-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 3,432 kB
  • ctags: 2,908
  • sloc: ml: 31,357; makefile: 166; sh: 75; ansic: 48; awk: 26
file content (124 lines) | stat: -rw-r--r-- 5,014 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
(******************************************************************************)
(* OASIS: architecture for building OCaml libraries and applications          *)
(*                                                                            *)
(* Copyright (C) 2011-2013, Sylvain Le Gall                                   *)
(* Copyright (C) 2008-2011, OCamlCore SARL                                    *)
(*                                                                            *)
(* This library is free software; you can redistribute it and/or modify it    *)
(* under the terms of the GNU Lesser General Public License as published by   *)
(* the Free Software Foundation; either version 2.1 of the License, or (at    *)
(* your option) any later version, with the OCaml static compilation          *)
(* exception.                                                                 *)
(*                                                                            *)
(* This library is distributed in the hope that it will be useful, but        *)
(* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY *)
(* or FITNESS FOR A PARTICULAR PURPOSE. See the file COPYING for more         *)
(* details.                                                                   *)
(*                                                                            *)
(* You should have received a copy of the GNU Lesser General Public License   *)
(* along with this library; if not, write to the Free Software Foundation,    *)
(* Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA              *)
(******************************************************************************)

(** Test plugin StdFiles
    @author Sylvain Le Gall
 *)

open OUnit2
open TestCommon
open TestFullUtils
open OASISPlugin
open OASISFileTemplate

module Line =
struct
  type t = string
  let compare = String.compare
  let pp_printer fmt = Format.fprintf fmt "%S"
  let pp_print_sep = Format.pp_print_newline
end

module DiffFileContent =
struct
  include OUnitDiff.ListSimpleMake (Line)

  let of_file fn =
    OASISString.split_newline ~do_trim:false
      (TestCommon.file_content fn)
end


let file_match_expectation test_ctxt ctxt dn fn =
  let digest_filter_out =
    List.filter
      (fun line ->
         not (OASISString.contains ~what:"DO NOT EDIT (digest:" line))
  in
  let tmpl = to_string_list (find fn ctxt.files) in
    logf test_ctxt `Info "File generated %s" fn;
    List.iter (logf test_ctxt `Info "%s") tmpl;
    DiffFileContent.assert_equal
      ~msg:"README.md"
      (digest_filter_out
         (DiffFileContent.of_file (Filename.concat dn (fn ^ ".exp"))))
      (digest_filter_out
         (DiffFileContent.of_list (tmpl @ [""] (* eol at eof *))))


let tests =
  "TestStdFiles" >:::
  [
    "markdown" >::
    (fun test_ctxt ->
       (* Parse string to get OASIS package *)
       let dn = in_testdata_dir test_ctxt ["TestStdFiles"; "oasis"] in
       let pkg =
         OASISParse.from_file ~ctxt:oasis_ctxt
           (Filename.concat dn OASISParse.default_oasis_fn)
       in
       let ctxt, _ =
         with_bracket_chdir test_ctxt dn
           (fun test_ctxt ->
              BaseSetup.of_package ~setup_update:false
                OASISSetupUpdate.NoUpdate pkg)
       in
         file_match_expectation test_ctxt ctxt dn "README.md";
         file_match_expectation test_ctxt ctxt dn "INSTALL.md";
         file_match_expectation test_ctxt ctxt dn "AUTHORS.md");

    "remove-section" >::
    (fun test_ctxt ->
       let t =
         setup_test_directories test_ctxt
           ~is_native:(is_native test_ctxt)
           ~native_dynlink:(native_dynlink test_ctxt)
           (in_testdata_dir test_ctxt ["TestStdFiles"; "remove"])
       in
       let pristine_files = all_files t.src_dir in
       let expected_files =
         SetFile.remove
           (in_src_dir t "AUTHORS.txt")
           (SetFile.add_list
              pristine_files
              (List.rev_map (in_src_dir t) ["README.txt"; "INSTALL.txt.bak"]))
       in
         FileUtil.cp [in_src_dir t "README.txt.fst"]
           (in_src_dir t "README.txt");
         FileUtil.cp [in_src_dir t "INSTALL.txt.fst"]
           (in_src_dir t "INSTALL.txt");
         FileUtil.cp [in_src_dir t "AUTHORS.txt.fst"]
           (in_src_dir t "AUTHORS.txt");
         assert_oasis_cli ~ctxt:test_ctxt ~chdir:t.src_dir
           ["setup-clean"; "-remove"];
         DiffFileContent.assert_equal
           ~msg:"INSTALL.txt.bak = INSTALL.txt.fst"
           (DiffFileContent.of_file (in_src_dir t "INSTALL.txt.bak"))
           (DiffFileContent.of_file (in_src_dir t "INSTALL.txt.fst"));
         DiffFileContent.assert_equal
           ~msg:"README.txt = README.txt.snd"
           (DiffFileContent.of_file (in_src_dir t "README.txt"))
           (DiffFileContent.of_file (in_src_dir t "README.txt.snd"));
         SetFile.assert_equal ~root:t.src_dir
           expected_files
           (all_files t.src_dir));
  ]