6cb9f9e5915dc2bd3ff8386ad43cc280eee2d13c
[whenjobs.git] / tests / parsing / test_load.ml
1 (* whenjobs
2  * Copyright (C) 2012 Red Hat Inc.
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License along
15  * with this program; if not, write to the Free Software Foundation, Inc.,
16  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
17  *)
18
19 open Printf
20
21 (* This program is passed a single argument, which is the .cmo file to
22  * dynamically load.
23  *)
24 let file =
25   if Array.length Sys.argv != 2 then (
26     eprintf "test_load test.cmo\n";
27     exit 1
28   );
29   Sys.argv.(1)
30
31 let () =
32   Whenfile.init ();
33
34   (try
35      Dynlink.loadfile file
36    with
37      Dynlink.Error err ->
38        eprintf "test_load: %s: %s\n" file (Dynlink.error_message err);
39        exit 1
40   );
41
42   let jobs = Whenfile.get_jobs () in
43   printf "test_load: %s: %d jobs parsed from file\n" file (List.length jobs)