1 (* hivex OCaml bindings
2 * Copyright (C) 2009-2010 Red Hat Inc.
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.
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.
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.
19 (* Test different types of error handling used by the API. *)
23 let (//) = Filename.concat
24 let srcdir = try Sys.getenv "srcdir" with Not_found -> "."
27 printf "01 non-existent file\n%!";
29 ignore (Hivex.open_file "no_such_file" []);
30 failwith "no exception thrown when opening a non-existent file"
32 | Hivex.Error ("open", ENOENT, _) -> () (* ok *)
33 (* let any other exception escape and stop the test *)
36 printf "02 closed handle\n%!";
37 let h = Hivex.open_file (srcdir // "../images/minimal") [] in
42 | Hivex.Handle_closed "root" -> () (* ok *)
43 (* let any other exception escape and stop the test *)
46 printf "03 write to read-only file\n%!";
47 let h = Hivex.open_file (srcdir // "../images/minimal") [] in
49 ignore (Hivex.node_add_child h (Hivex.root h) "Foo")
51 | Hivex.Error ("node_add_child", EROFS, _) -> () (* ok *)
52 (* let any other exception escape and stop the test *)
56 printf "04 node_get_child node not found\n%!";
57 let h = Hivex.open_file (srcdir // "../images/minimal") [] in
59 ignore (Hivex.node_get_child h (Hivex.root h) "NoSuchNode")
61 | Not_found -> () (* ok *)
62 (* let any other exception escape and stop the test *)
66 (* Gc.compact is a good way to ensure we don't have
67 * heap corruption or double-freeing.