regedit: Fix syntax for deleting registry keys (RHBZ#737944).
[hivex.git] / ocaml / t / hivex_100_errors.ml
1 (* hivex OCaml bindings
2  * Copyright (C) 2009-2010 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
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17  *)
18
19 (* Test different types of error handling used by the API. *)
20
21 open Unix
22 open Printf
23 let (//) = Filename.concat
24 let srcdir = try Sys.getenv "srcdir" with Not_found -> "."
25
26 let () =
27   printf "01 non-existent file\n%!";
28   (try
29      ignore (Hivex.open_file "no_such_file" []);
30      failwith "no exception thrown when opening a non-existent file"
31    with
32    | Hivex.Error ("open", ENOENT, _) -> () (* ok *)
33    (* let any other exception escape and stop the test *)
34   );
35
36   printf "02 closed handle\n%!";
37   let h = Hivex.open_file (srcdir // "../images/minimal") [] in
38   Hivex.close h;
39   (try
40      ignore (Hivex.root h)
41    with
42    | Hivex.Handle_closed "root" -> () (* ok *)
43    (* let any other exception escape and stop the test *)
44   );
45
46   printf "03 write to read-only file\n%!";
47   let h = Hivex.open_file (srcdir // "../images/minimal") [] in
48   (try
49      ignore (Hivex.node_add_child h (Hivex.root h) "Foo")
50    with
51    | Hivex.Error ("node_add_child", EROFS, _) -> () (* ok *)
52    (* let any other exception escape and stop the test *)
53   );
54   Hivex.close h;
55
56   printf "04 node_get_child node not found\n%!";
57   let h = Hivex.open_file (srcdir // "../images/minimal") [] in
58   (try
59      ignore (Hivex.node_get_child h (Hivex.root h) "NoSuchNode")
60    with
61    | Not_found -> () (* ok *)
62    (* let any other exception escape and stop the test *)
63   );
64   Hivex.close h;
65
66   (* Gc.compact is a good way to ensure we don't have
67    * heap corruption or double-freeing.
68    *)
69   Gc.compact ()