server: Better newstyle .open failure handling
[nbdkit/ericb.git] / tests / test-ocaml.c
blob505e32b239f0f7edd409f4b2b48c32f7a098962d
1 /* nbdkit
2 * Copyright (C) 2014 Red Hat Inc.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
11 * * Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
15 * * Neither the name of Red Hat nor the names of its contributors may be
16 * used to endorse or promote products derived from this software without
17 * specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY RED HAT AND CONTRIBUTORS ''AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
21 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
22 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL RED HAT OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
26 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
27 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
28 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
29 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
33 #include <config.h>
35 #include <stdio.h>
36 #include <stdlib.h>
37 #include <stdint.h>
38 #include <inttypes.h>
39 #include <string.h>
40 #include <unistd.h>
42 #include <guestfs.h>
44 #include "test.h"
46 int
47 main (int argc, char *argv[])
49 guestfs_h *g;
50 int r;
51 int64_t size;
52 char *data;
54 if (test_start_nbdkit ("./test-ocaml-plugin.so", "a=1", "b=2", "c=3",
55 NULL) == -1)
56 exit (EXIT_FAILURE);
58 g = guestfs_create ();
59 if (g == NULL) {
60 perror ("guestfs_create");
61 exit (EXIT_FAILURE);
64 r = guestfs_add_drive_opts (g, "",
65 GUESTFS_ADD_DRIVE_OPTS_FORMAT, "raw",
66 GUESTFS_ADD_DRIVE_OPTS_PROTOCOL, "nbd",
67 GUESTFS_ADD_DRIVE_OPTS_SERVER, server,
68 -1);
69 if (r == -1)
70 exit (EXIT_FAILURE);
72 if (guestfs_launch (g) == -1)
73 exit (EXIT_FAILURE);
75 /* Check the size is exactly 1M. */
76 size = guestfs_blockdev_getsize64 (g, "/dev/sda");
77 if (size != 1024 * 1024) {
78 fprintf (stderr, "%s FAILED: unexpected size "
79 "(actual: %" PRIi64 ", expected: %d)\n",
80 program_name, size, 1024*1024);
81 exit (EXIT_FAILURE);
84 if (guestfs_part_disk (g, "/dev/sda", "mbr") == -1)
85 exit (EXIT_FAILURE);
86 if (guestfs_mkfs (g, "ext2", "/dev/sda1") == -1)
87 exit (EXIT_FAILURE);
89 if (guestfs_mount_options (g, "discard", "/dev/sda1", "/") == -1)
90 exit (EXIT_FAILURE);
92 #define filename "/hello.txt"
93 #define content "hello, people of the world"
95 if (guestfs_write (g, filename, content, strlen (content)) == -1)
96 exit (EXIT_FAILURE);
98 data = guestfs_cat (g, filename);
99 if (!data)
100 exit (EXIT_FAILURE);
102 if (strcmp (data, content) != 0) {
103 fprintf (stderr,
104 "%s FAILED: unexpected content of %s file "
105 "(actual: %s, expected: %s)\n",
106 program_name, filename, data, content);
107 exit (EXIT_FAILURE);
109 free (data);
111 /* Run sync to test flush path. */
112 if (guestfs_sync (g) == -1)
113 exit (EXIT_FAILURE);
115 /* Run fstrim to test trim path. However only recent versions of
116 * libguestfs have this, and it probably only works in recent
117 * versions of qemu.
119 #ifdef GUESTFS_HAVE_FSTRIM
120 if (guestfs_fstrim (g, "/", -1) == -1)
121 exit (EXIT_FAILURE);
122 #endif
124 /* Run fallocate(1) on the device to test zero path. */
125 if (guestfs_umount (g, "/") == -1)
126 exit (EXIT_FAILURE);
127 const char *cmd[] = { "fallocate", "-nzl", "64k", "/dev/sda", NULL };
128 data = guestfs_debug (g, "sh", (char **) cmd);
129 free (data);
131 if (guestfs_shutdown (g) == -1)
132 exit (EXIT_FAILURE);
134 guestfs_close (g);
135 exit (EXIT_SUCCESS);