Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 00/16] Small bits of non-Linux porting
Hi, from time to time, there have been requests (or attempts, like the mingw port posted on the list some months ago) to make libguestfs work on OSes different than Linux. Of course this would imply using a fixed appliance, since it is currently heavily dependent on Linux. The attached series provides some easy changes in this direction, resolving some of the easy issues found in porting to FreeBSD; while they don't solve all the build and runtime issues, at least they get libguestfs a bit closer to it, while causing no actual changes on Linux. Other issues (with partial solutions, or not dealt yet) w.r.t porting to non-Linux so far found are the following: a) lack of UNIX_PATH_MAX (which seems Linux-specific anyway) b) usage of meta /dev/fd/N files; while on (k)FreeBSD there's a fdescfs filesystem providing it, IMHO a better solution would be adding API using FDs, like download_fd, upload_fd, tar_in_fd, and tar_out_fd c) program_invocation_short_name is specific to GNU libc d) iconv outside of GNU libc, in an own libintl e) different cli tools, and different output for them Also, as mentioned in the mingw porting patch, https://www.redhat.com/archives/libguestfs/2014-February/msg00160.html a way to disable entirely the usage of supermin (thus leaving only the fixed appliance as appliance style) is needed too. Thanks, -- Pino Pino Toscano (16): build: use the ptsname_r gnulib module Include string.h where needed Include sys/wait.h where needed build: look for and use sys/endian.h fuse: test-fuse: enclose acl vars within HAVE_ACL p2v: remove unused variable normalize iconv handling builder: rename "program_name" into "progname" tests: isolate iso_system_id baseline string Include stdint.h where needed build: use $(SED) instead of sed when possible tests/c-api: add a way to skip test when host and appliance differ actions: mark as IfNotCrossAppliance tests of command and command_lines customize, mllib: use the libvirt CFLAGS tests: switch from get_current_dir_name to getcwd(0, NULL) configure: map also amd64 as host_cpu to x86_64 qemu bootstrap | 2 ++ builder/index-parse.y | 4 +-- builder/index-parser-c.c | 2 +- builder/index-struct.h | 2 +- configure.ac | 4 ++- customize/Makefile.am | 1 + daemon/ext2.c | 1 + daemon/hotplug.c | 1 + daemon/initrd.c | 1 + daemon/journal.c | 5 +++ daemon/ldm.c | 1 + daemon/lvm-filter.c | 1 + daemon/mktemp.c | 1 + daemon/utsname.c | 1 + diff/diff.c | 1 + fish/Makefile.am | 2 +- fish/file-edit.c | 1 + fuse/test-fuse.c | 2 ++ generator/actions.ml | 50 +++++++++++++++--------------- generator/c.ml | 1 + generator/tests_c_api.ml | 20 +++++++++++- generator/types.ml | 5 +++ m4/.gitignore | 3 ++ mllib/Makefile.am | 1 + p2v/Makefile.am | 2 +- p2v/ssh.c | 2 -- po-docs/Makefile.am | 2 +- run.in | 2 +- sparsify/statvfs-c.c | 1 + src/Makefile.am | 3 +- src/create.c | 1 + src/dbdump.c | 1 + src/file.c | 1 + src/filearch.c | 1 + src/fuse.c | 1 + src/info.c | 1 + src/inspect-apps.c | 3 ++ src/inspect-fs-windows.c | 5 ++- src/inspect-icon.c | 1 + src/journal.c | 3 ++ src/launch-direct.c | 1 + src/launch-libvirt.c | 1 + src/launch-unix.c | 1 + src/libvirt-auth.c | 1 + src/libvirt-domain.c | 1 + tests/c-api/test-pwd.c | 2 +- tests/c-api/tests-main.c | 39 +++++++++++++++++++++++ tests/c-api/tests.h | 1 + tests/events/test-libvirt-auth-callbacks.c | 4 +-- tests/guests/Makefile.am | 2 +- 50 files changed, 153 insertions(+), 43 deletions(-) -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 01/16] build: use the ptsname_r gnulib module
virt-p2v uses ptsname_r, which is not portable but implemented by gnulib. --- bootstrap | 1 + m4/.gitignore | 3 +++ 2 files changed, 4 insertions(+) diff --git a/bootstrap b/bootstrap index b4afcdb..b7a45ff 100755 --- a/bootstrap +++ b/bootstrap @@ -77,6 +77,7 @@ openat perror pipe2 pread +ptsname_r read-file readlink select diff --git a/m4/.gitignore b/m4/.gitignore index ed73ab3..605cd26 100644 --- a/m4/.gitignore +++ b/m4/.gitignore @@ -271,3 +271,6 @@ /xstrtol.m4 /xvasprintf.m4 /yield.m4 +/isatty.m4 +/ptsname_r.m4 +/ttyname_r.m4 -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 02/16] Include string.h where needed
Required for using strlen, memcpy, etc. Apparently implicitly pulled so far. --- daemon/hotplug.c | 1 + daemon/ldm.c | 1 + daemon/mktemp.c | 1 + daemon/utsname.c | 1 + generator/c.ml | 1 + src/create.c | 1 + src/file.c | 1 + src/fuse.c | 1 + src/info.c | 1 + src/launch-direct.c | 1 + src/launch-libvirt.c | 1 + src/launch-unix.c | 1 + src/libvirt-auth.c | 1 + src/libvirt-domain.c | 1 + 14 files changed, 14 insertions(+) diff --git a/daemon/hotplug.c b/daemon/hotplug.c index 7ff4ced..2f159c6 100644 --- a/daemon/hotplug.c +++ b/daemon/hotplug.c @@ -23,6 +23,7 @@ #include <unistd.h> #include <errno.h> #include <time.h> +#include <string.h> #include "guestfs_protocol.h" #include "daemon.h" diff --git a/daemon/ldm.c b/daemon/ldm.c index aad7f78..3563313 100644 --- a/daemon/ldm.c +++ b/daemon/ldm.c @@ -24,6 +24,7 @@ #include <sys/types.h> #include <sys/stat.h> #include <glob.h> +#include <string.h> #if HAVE_YAJL #include <yajl/yajl_tree.h> diff --git a/daemon/mktemp.c b/daemon/mktemp.c index cacb48d..39231ad 100644 --- a/daemon/mktemp.c +++ b/daemon/mktemp.c @@ -21,6 +21,7 @@ #include <stdio.h> #include <stdlib.h> +#include <string.h> #include "guestfs_protocol.h" #include "daemon.h" diff --git a/daemon/utsname.c b/daemon/utsname.c index dc49226..17a82c3 100644 --- a/daemon/utsname.c +++ b/daemon/utsname.c @@ -21,6 +21,7 @@ #include <stdio.h> #include <stdlib.h> #include <sys/utsname.h> +#include <string.h> #include "guestfs_protocol.h" #include "daemon.h" diff --git a/generator/c.ml b/generator/c.ml index 1fa05ab..9e17d32 100644 --- a/generator/c.ml +++ b/generator/c.ml @@ -1221,6 +1221,7 @@ and generate_client_actions hash () #include <inttypes.h> #include <sys/types.h> #include <sys/stat.h> +#include <string.h> #include \"guestfs.h\" #include \"guestfs-internal.h\" diff --git a/src/create.c b/src/create.c index 0cfe6be..621ace5 100644 --- a/src/create.c +++ b/src/create.c @@ -29,6 +29,7 @@ #include <sys/wait.h> #include <sys/ioctl.h> #include <errno.h> +#include <string.h> #ifdef HAVE_LINUX_FS_H #include <linux/fs.h> diff --git a/src/file.c b/src/file.c index 91f7947..6a58bfe 100644 --- a/src/file.c +++ b/src/file.c @@ -26,6 +26,7 @@ #include <unistd.h> #include <sys/types.h> #include <sys/stat.h> +#include <string.h> #include "full-read.h" #include "full-write.h" diff --git a/src/fuse.c b/src/fuse.c index 08a8784..258a863 100644 --- a/src/fuse.c +++ b/src/fuse.c @@ -24,6 +24,7 @@ #include <errno.h> #include <sys/types.h> #include <sys/wait.h> +#include <string.h> #if HAVE_FUSE /* See <attr/xattr.h> */ diff --git a/src/info.c b/src/info.c index 175c503..1bc079a 100644 --- a/src/info.c +++ b/src/info.c @@ -29,6 +29,7 @@ #include <sys/stat.h> #include <sys/wait.h> #include <assert.h> +#include <string.h> #if HAVE_YAJL #include <yajl/yajl_tree.h> diff --git a/src/launch-direct.c b/src/launch-direct.c index 5301176..021df94 100644 --- a/src/launch-direct.c +++ b/src/launch-direct.c @@ -34,6 +34,7 @@ #include <sys/un.h> #include <grp.h> #include <assert.h> +#include <string.h> #include <pcre.h> diff --git a/src/launch-libvirt.c b/src/launch-libvirt.c index f8f818a..7206b33 100644 --- a/src/launch-libvirt.c +++ b/src/launch-libvirt.c @@ -30,6 +30,7 @@ #include <sys/stat.h> #include <sys/wait.h> #include <assert.h> +#include <string.h> #ifdef HAVE_LIBVIRT #include <libvirt/libvirt.h> diff --git a/src/launch-unix.c b/src/launch-unix.c index 489a046..c5e4438 100644 --- a/src/launch-unix.c +++ b/src/launch-unix.c @@ -24,6 +24,7 @@ #include <fcntl.h> #include <sys/socket.h> #include <sys/un.h> +#include <string.h> #include "guestfs.h" #include "guestfs-internal.h" diff --git a/src/libvirt-auth.c b/src/libvirt-auth.c index f8ed1b1..1eeac75 100644 --- a/src/libvirt-auth.c +++ b/src/libvirt-auth.c @@ -21,6 +21,7 @@ #include <stdio.h> #include <stdlib.h> #include <stdbool.h> +#include <string.h> #ifdef HAVE_LIBVIRT #include <libvirt/libvirt.h> diff --git a/src/libvirt-domain.c b/src/libvirt-domain.c index 7e0a0d9..59bb4bc 100644 --- a/src/libvirt-domain.c +++ b/src/libvirt-domain.c @@ -22,6 +22,7 @@ #include <stdlib.h> #include <stdbool.h> #include <assert.h> +#include <string.h> #ifdef HAVE_LIBVIRT #include <libvirt/libvirt.h> -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 03/16] Include sys/wait.h where needed
Required for using WIFEXITED, WEXITSTATUS, etc. Apparently implicitly pulled so far. --- daemon/ext2.c | 1 + daemon/initrd.c | 1 + daemon/lvm-filter.c | 1 + diff/diff.c | 1 + fish/file-edit.c | 1 + src/dbdump.c | 1 + src/filearch.c | 1 + src/inspect-icon.c | 1 + 8 files changed, 8 insertions(+) diff --git a/daemon/ext2.c b/daemon/ext2.c index 2b3674c..31fef25 100644 --- a/daemon/ext2.c +++ b/daemon/ext2.c @@ -23,6 +23,7 @@ #include <inttypes.h> #include <string.h> #include <unistd.h> +#include <sys/wait.h> #include "guestfs_protocol.h" #include "daemon.h" diff --git a/daemon/initrd.c b/daemon/initrd.c index ea34000..ac14826 100644 --- a/daemon/initrd.c +++ b/daemon/initrd.c @@ -25,6 +25,7 @@ #include <unistd.h> #include <fcntl.h> #include <sys/stat.h> +#include <sys/wait.h> #include "guestfs_protocol.h" #include "daemon.h" diff --git a/daemon/lvm-filter.c b/daemon/lvm-filter.c index d82fde0..72fe6ac 100644 --- a/daemon/lvm-filter.c +++ b/daemon/lvm-filter.c @@ -24,6 +24,7 @@ #include <string.h> #include <unistd.h> #include <sys/stat.h> +#include <sys/wait.h> #include <augeas.h> diff --git a/diff/diff.c b/diff/diff.c index ad371b0..b113f29 100644 --- a/diff/diff.c +++ b/diff/diff.c @@ -30,6 +30,7 @@ #include <assert.h> #include <time.h> #include <libintl.h> +#include <sys/wait.h> #include "c-ctype.h" #include "human.h" diff --git a/fish/file-edit.c b/fish/file-edit.c index dd2272b..3efd46d 100644 --- a/fish/file-edit.c +++ b/fish/file-edit.c @@ -32,6 +32,7 @@ #include <sys/stat.h> #include <assert.h> #include <utime.h> +#include <sys/wait.h> #include "guestfs-internal-frontend.h" diff --git a/src/dbdump.c b/src/dbdump.c index 684b2cf..f44f2d4 100644 --- a/src/dbdump.c +++ b/src/dbdump.c @@ -27,6 +27,7 @@ #include <string.h> #include <sys/stat.h> #include <errno.h> +#include <sys/wait.h> #ifdef HAVE_ENDIAN_H #include <endian.h> diff --git a/src/filearch.c b/src/filearch.c index c0380d9..f7673a2 100644 --- a/src/filearch.c +++ b/src/filearch.c @@ -25,6 +25,7 @@ #include <unistd.h> #include <string.h> #include <sys/stat.h> +#include <sys/wait.h> #include <pcre.h> diff --git a/src/inspect-icon.c b/src/inspect-icon.c index 0ffca72..9871fde 100644 --- a/src/inspect-icon.c +++ b/src/inspect-icon.c @@ -27,6 +27,7 @@ #include <string.h> #include <sys/stat.h> #include <errno.h> +#include <sys/wait.h> #include "guestfs.h" #include "guestfs-internal.h" -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 04/16] build: look for and use sys/endian.h
Some OSes have sys/endian.h instead of glibc's endian.h. --- configure.ac | 1 + daemon/journal.c | 5 +++++ src/inspect-apps.c | 3 +++ src/inspect-fs-windows.c | 3 +++ src/journal.c | 3 +++ 5 files changed, 15 insertions(+) diff --git a/configure.ac b/configure.ac index 6c33444..8cd29d7 100644 --- a/configure.ac +++ b/configure.ac @@ -288,6 +288,7 @@ AC_CHECK_HEADERS([\ attr/xattr.h \ byteswap.h \ endian.h \ + sys/endian.h \ errno.h \ linux/fs.h \ linux/raid/md_u.h \ diff --git a/daemon/journal.c b/daemon/journal.c index 3fd2135..a2a1c73 100644 --- a/daemon/journal.c +++ b/daemon/journal.c @@ -22,7 +22,12 @@ #include <stdlib.h> #include <inttypes.h> #include <string.h> +#ifdef HAVE_ENDIAN_H #include <endian.h> +#endif +#ifdef HAVE_SYS_ENDIAN_H +#include <sys/endian.h> +#endif #include "guestfs_protocol.h" #include "daemon.h" diff --git a/src/inspect-apps.c b/src/inspect-apps.c index a77e9ce..b62b432 100644 --- a/src/inspect-apps.c +++ b/src/inspect-apps.c @@ -31,6 +31,9 @@ #ifdef HAVE_ENDIAN_H #include <endian.h> #endif +#ifdef HAVE_SYS_ENDIAN_H +#include <sys/endian.h> +#endif /* be32toh is usually a macro definend in <endian.h>, but it might be * a function in some system so check both, and if neither is defined diff --git a/src/inspect-fs-windows.c b/src/inspect-fs-windows.c index 20e4d7f..6d430d1 100644 --- a/src/inspect-fs-windows.c +++ b/src/inspect-fs-windows.c @@ -32,6 +32,9 @@ #ifdef HAVE_ENDIAN_H #include <endian.h> #endif +#ifdef HAVE_SYS_ENDIAN_H +#include <sys/endian.h> +#endif #include <pcre.h> diff --git a/src/journal.c b/src/journal.c index 61ab352..1070067 100644 --- a/src/journal.c +++ b/src/journal.c @@ -31,6 +31,9 @@ #ifdef HAVE_ENDIAN_H #include <endian.h> #endif +#ifdef HAVE_SYS_ENDIAN_H +#include <sys/endian.h> +#endif #include "full-read.h" -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 05/16] fuse: test-fuse: enclose acl vars within HAVE_ACL
Enclose the acl-related variables within a #ifdef HAVE_ACL block, so when building without acl support and -Werror it can build. --- fuse/test-fuse.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/fuse/test-fuse.c b/fuse/test-fuse.c index b675a4c..a341994 100644 --- a/fuse/test-fuse.c +++ b/fuse/test-fuse.c @@ -251,8 +251,10 @@ test_fuse (void) int fd; struct timeval tv[2]; struct timespec ts[2]; +#ifdef HAVE_ACL acl_t acl; char *acl_text; +#endif STAGE ("checking initial files exist"); -- 1.9.3
--- p2v/ssh.c | 2 -- 1 file changed, 2 deletions(-) diff --git a/p2v/ssh.c b/p2v/ssh.c index f3bfcf9..1c0f8b7 100644 --- a/p2v/ssh.c +++ b/p2v/ssh.c @@ -420,8 +420,6 @@ test_connection (struct config *config) } for (;;) { - CLEANUP_FREE char *feature = NULL; - switch (mexp_expect (h, (mexp_regexp[]) { { 100, .re = feature_libguestfs_rewrite_re }, -- 1.9.3
Since the signature of iconv() changes between implementations (the constness of the second parameter, in particular), make use of the iconv module of gnulib to handle these potential differences, including an external (out of libc) iconv implementation. --- bootstrap | 1 + src/Makefile.am | 1 + src/inspect-fs-windows.c | 2 +- 3 files changed, 3 insertions(+), 1 deletion(-) diff --git a/bootstrap b/bootstrap index b7a45ff..402ac4e 100755 --- a/bootstrap +++ b/bootstrap @@ -64,6 +64,7 @@ gnumakefile hash hash-pjw human +iconv ignore-value lock maintainer-makefile diff --git a/src/Makefile.am b/src/Makefile.am index 3d06203..e717251 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -161,6 +161,7 @@ libguestfs_la_LIBADD = \ $(LIB_CLOCK_GETTIME) \ $(LIBINTL) \ $(LTLIBTHREAD) \ + $(LTLIBICONV) \ $(SERVENT_LIB) # Force libtool to name the library 'libguestfs.so.0.$(MAX_PROC_NR).0'. diff --git a/src/inspect-fs-windows.c b/src/inspect-fs-windows.c index 6d430d1..619706c 100644 --- a/src/inspect-fs-windows.c +++ b/src/inspect-fs-windows.c @@ -669,7 +669,7 @@ utf16_to_utf8 (/* const */ char *input, size_t len) char *inp = input; char *outp = out; - size_t r = iconv (ic, &inp, &inlen, &outp, &outlen); + size_t r = iconv (ic, (ICONV_CONST char **) &inp, &inlen, &outp, &outlen); if (r == (size_t) -1) { if (errno == E2BIG) { int err = errno; -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 08/16] builder: rename "program_name" into "progname"
"program_name" is already used as shorthand define for program_invocation_short_name. --- builder/index-parse.y | 4 ++-- builder/index-parser-c.c | 2 +- builder/index-struct.h | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/builder/index-parse.y b/builder/index-parse.y index 06e6a83..36f9f07 100644 --- a/builder/index-parse.y +++ b/builder/index-parse.y @@ -153,8 +153,8 @@ yyerror (YYLTYPE * yylloc, yyscan_t scanner, struct parse_context *context, cons int has_suffix = context->error_suffix != NULL && context->error_suffix[0] != 0; fprintf (stderr, "%s%s%s%ssyntax error at line %d: %s%s%s\n", - context->program_name ? context->program_name : "", - context->program_name ? ": " : "", + context->progname ? context->progname : "", + context->progname ? ": " : "", context->input_file ? context->input_file : "", context->input_file ? ": " : "", yylloc->first_line, msg, diff --git a/builder/index-parser-c.c b/builder/index-parser-c.c index 099bdf8..845abd7 100644 --- a/builder/index-parser-c.c +++ b/builder/index-parser-c.c @@ -56,7 +56,7 @@ virt_builder_parse_index (value progv, value error_suffixv, value filenamev) FILE *in; parse_context_init (&context); - context.program_name = String_val (progv); + context.progname = String_val (progv); context.input_file = String_val (filenamev); context.error_suffix = String_val (error_suffixv); diff --git a/builder/index-struct.h b/builder/index-struct.h index 150535d..ada35e3 100644 --- a/builder/index-struct.h +++ b/builder/index-struct.h @@ -44,7 +44,7 @@ struct parse_context { */ int seen_comments; const char *input_file; - const char *program_name; + const char *progname; const char *error_suffix; }; -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 09/16] tests: isolate iso_system_id baseline string
Move the reference iso_system_id for the isoinfo_device test to an own define for Linux, with an error for unknown OSes. --- generator/actions.ml | 2 +- generator/tests_c_api.ml | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/generator/actions.ml b/generator/actions.ml index 4cfba0d..955f638 100644 --- a/generator/actions.ml +++ b/generator/actions.ml @@ -9883,7 +9883,7 @@ this will create the largest possible LV." }; tests = [ InitNone, Always, TestResult ( [["isoinfo_device"; "/dev/sdd"]], - "STREQ (ret->iso_system_id, \"LINUX\") && "^ + "STREQ (ret->iso_system_id, GUESTFS_ISO_SYSTEM_ID) && "^ "STREQ (ret->iso_volume_id, \"CDROM\") && "^ "STREQ (ret->iso_volume_set_id, \"\") && "^ "ret->iso_volume_set_size == 1 && "^ diff --git a/generator/tests_c_api.ml b/generator/tests_c_api.ml index 88aa07e..43a99e3 100644 --- a/generator/tests_c_api.ml +++ b/generator/tests_c_api.ml @@ -47,6 +47,12 @@ let rec generate_c_api_tests () #include \"tests.h\" +#ifdef __linux__ +#define GUESTFS_ISO_SYSTEM_ID \"LINUX\" +#else +#error Missing GUESTFS_ISO_SYSTEM_ID for the current OS +#endif + "; (* Generate a list of commands which are not tested anywhere. *) -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 10/16] Include stdint.h where needed
Required for using int64_t, etc. Apparently implicitly pulled so far. --- sparsify/statvfs-c.c | 1 + 1 file changed, 1 insertion(+) diff --git a/sparsify/statvfs-c.c b/sparsify/statvfs-c.c index 2ad8db3..76bff0b 100644 --- a/sparsify/statvfs-c.c +++ b/sparsify/statvfs-c.c @@ -21,6 +21,7 @@ #include <stdio.h> #include <stdlib.h> #include <sys/statvfs.h> +#include <stdint.h> #include <caml/alloc.h> #include <caml/fail.h> -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 11/16] build: use $(SED) instead of sed when possible
Make use of the sed executable set at configure time. --- fish/Makefile.am | 2 +- p2v/Makefile.am | 2 +- po-docs/Makefile.am | 2 +- run.in | 2 +- src/Makefile.am | 2 +- tests/guests/Makefile.am | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/fish/Makefile.am b/fish/Makefile.am index d28a94b..e633422 100644 --- a/fish/Makefile.am +++ b/fish/Makefile.am @@ -163,7 +163,7 @@ endif rc_protocol.c: rc_protocol.x rm -f $@-t $@-t2 $(RPCGEN) $(RPCGEN_DEFS) -c -o $@-t $< - sed 's,\.\./\(\.\./\)*fish,.,' < $@-t > $@-t2 + $(SED) 's,\.\./\(\.\./\)*fish,.,' < $@-t > $@-t2 rm $@-t mv $@-t2 $@ diff --git a/p2v/Makefile.am b/p2v/Makefile.am index cafad0b..3e22b4c 100644 --- a/p2v/Makefile.am +++ b/p2v/Makefile.am @@ -89,7 +89,7 @@ virtp2vdata_DATA = \ # Deal with stupid autotools libexecdir-not-expandable crap. launch-virt-p2v: launch-virt-p2v.in rm -f $@ $@-t - sed 's,@''libexecdir@,$(libexecdir),g' < $< > $@-t + $(SED) 's,@''libexecdir@,$(libexecdir),g' < $< > $@-t chmod 0555 $@-t mv $@-t $@ diff --git a/po-docs/Makefile.am b/po-docs/Makefile.am index 17823ab..8803891 100644 --- a/po-docs/Makefile.am +++ b/po-docs/Makefile.am @@ -57,7 +57,7 @@ libguestfs-docs.pot: po4a.conf --copyright-holder "Red Hat Inc." \ po4a.conf for f in `cd $(srcdir); find $(linguas) -name '*.pod'`; do \ - sed '0,/^=encoding/d' < $$f > $$f.new; \ + $(SED) '0,/^=encoding/d' < $$f > $$f.new; \ mv $$f.new $$f; \ done diff --git a/run.in b/run.in index 1cf7c20..760885f 100755 --- a/run.in +++ b/run.in @@ -267,7 +267,7 @@ else echo "$b/run: command failed with exit code $fail" fi if [ -n "$RUN_OUTPUT_FILE" ]; then - testname=`echo "$1" | sed -e 's,^./,,g'` + testname=`echo "$1" | @SED@ -e 's,^./,,g'` echo "<test rescode=\"$fail\" name=\"$testname\" time=\"$(($end_t - $start_t))\">" >> $RUN_OUTPUT_FILE echo "<![CDATA[" >> $RUN_OUTPUT_FILE # skip the results of test-virt-rescue.pl, as they contain diff --git a/src/Makefile.am b/src/Makefile.am index e717251..be8d3a3 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -211,7 +211,7 @@ endif guestfs_protocol.c: guestfs_protocol.x rm -f $@-t $@-t2 $(RPCGEN) $(RPCGEN_DEFS) -c -o $@-t $< - sed 's,\.\./\(\.\./\)*src,.,' < $@-t > $@-t2 + $(SED) 's,\.\./\(\.\./\)*src,.,' < $@-t > $@-t2 rm $@-t mv $@-t2 $@ diff --git a/tests/guests/Makefile.am b/tests/guests/Makefile.am index 62f5d14..e58d563 100644 --- a/tests/guests/Makefile.am +++ b/tests/guests/Makefile.am @@ -67,7 +67,7 @@ blank-%.img: rm -f $@ $@-t $(top_builddir)/run \ ../../fish/guestfish \ - -N $@-t="$$(echo $@ | sed -e 's/blank-//' -e 's/.img//')" exit + -N $@-t="$$(echo $@ | $(SED) -e 's/blank-//' -e 's/.img//')" exit mv $@-t $@ # Make a (dummy) Fedora image. -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 12/16] tests/c-api: add a way to skip test when host and appliance differ
Add a IfNotCrossAppliance prereq for tests, so a test using it can only be run when the appliance is a copy of the running host system; this can help marking tests which run stuff (usually built in the host) inside the appliance. --- generator/tests_c_api.ml | 14 +++++++++++++- generator/types.ml | 5 +++++ tests/c-api/tests-main.c | 39 +++++++++++++++++++++++++++++++++++++++ tests/c-api/tests.h | 1 + 4 files changed, 58 insertions(+), 1 deletion(-) diff --git a/generator/tests_c_api.ml b/generator/tests_c_api.ml index 43a99e3..17a6af9 100644 --- a/generator/tests_c_api.ml +++ b/generator/tests_c_api.ml @@ -67,7 +67,7 @@ let rec generate_c_api_tests () fun { tests = tests } -> let seqs = filter_map ( function - | (_, (Always|IfAvailable _), test, cleanup) -> + | (_, (Always|IfAvailable _|IfNotCrossAppliance), test, cleanup) -> Some (seq_of_test test @ cleanup) | (_, Disabled, _, _) -> None ) tests in @@ -151,6 +151,15 @@ static int pr "\n" in + let utsname_test () + pr " if (using_cross_appliance ()) {\n"; + pr " skipped (\"%s\", \"cannot run when appliance and host are different\");\n" + test_name; + pr " return 0;\n"; + pr " }\n"; + pr "\n" + in + (match optional with | Some group -> group_test group | None -> () @@ -165,6 +174,9 @@ static int generate_one_test_body name i test_name init cleanup | Always -> generate_one_test_body name i test_name init cleanup + | IfNotCrossAppliance -> + utsname_test (); + generate_one_test_body name i test_name init cleanup ); pr "}\n"; diff --git a/generator/types.ml b/generator/types.ml index 63aa235..59aa1a0 100644 --- a/generator/types.ml +++ b/generator/types.ml @@ -253,6 +253,11 @@ and c_api_test_prereq (* Run the test only if 'string' is available in the daemon. *) | IfAvailable of string + (* Run the test when the appliance and the OS differ - for example, + * when using a fixed appliance created in a different OS/distribution. + *) + | IfNotCrossAppliance + (* Some initial scenarios for testing. *) and c_api_test_init (* Do nothing, block devices could contain random stuff including diff --git a/tests/c-api/tests-main.c b/tests/c-api/tests-main.c index e81e15e..6f4816f 100644 --- a/tests/c-api/tests-main.c +++ b/tests/c-api/tests-main.c @@ -25,6 +25,7 @@ #include <unistd.h> #include <fcntl.h> #include <assert.h> +#include <sys/utsname.h> #include <pcre.h> @@ -38,6 +39,8 @@ #include "tests.h" +static int is_cross_appliance; + int init_none (guestfs_h *g) { @@ -395,6 +398,12 @@ substitute_srcdir (const char *path) return ret; } +int +using_cross_appliance (void) +{ + return is_cross_appliance; +} + static void next_test (guestfs_h *g, size_t test_num, const char *test_name) { @@ -475,6 +484,35 @@ create_handle (void) return g; } +static int +check_cross_appliance (guestfs_h *g) +{ + struct utsname host; + CLEANUP_FREE_UTSNAME struct guestfs_utsname *appliance = NULL; + int r; + struct guestfs_utsname host_utsname; + + r = uname (&host); + if (r == -1) { + fprintf (stderr, "call to uname failed\n"); + exit (EXIT_FAILURE); + } + + appliance = guestfs_utsname (g); + if (appliance == NULL) { + fprintf (stderr, "call to guestfs_utsname failed: %d, %s\n", + guestfs_last_errno (g), guestfs_last_error (g)); + exit (EXIT_FAILURE); + } + + host_utsname.uts_sysname = host.sysname; + host_utsname.uts_release = host.release; + host_utsname.uts_version = host.version; + host_utsname.uts_machine = host.machine; + + return guestfs_compare_utsname (appliance, &host_utsname); +} + static size_t perform_tests (guestfs_h *g) { @@ -505,6 +543,7 @@ main (int argc, char *argv[]) no_test_warnings (); g = create_handle (); + is_cross_appliance = check_cross_appliance (g); nr_failed = perform_tests (g); diff --git a/tests/c-api/tests.h b/tests/c-api/tests.h index 7959570..12fd316 100644 --- a/tests/c-api/tests.h +++ b/tests/c-api/tests.h @@ -43,6 +43,7 @@ extern int check_file_md5 (const char *ret, const char *filename); extern const char *get_key (char **hash, const char *key); extern int check_hash (char **ret, const char *key, const char *expected); extern int match_re (const char *str, const char *pattern); +extern int using_cross_appliance (void); extern char *substitute_srcdir (const char *path); extern void skipped (const char *test_name, const char *fs, ...) __attribute__((format (printf,2,3))); -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 13/16] actions: mark as IfNotCrossAppliance tests of command and command_lines
All these tests copy to the appliance a tool built on the host, and run it. --- generator/actions.ml | 48 ++++++++++++++++++++++++------------------------ 1 file changed, 24 insertions(+), 24 deletions(-) diff --git a/generator/actions.ml b/generator/actions.ml index 955f638..ed36951 100644 --- a/generator/actions.ml +++ b/generator/actions.ml @@ -4236,67 +4236,67 @@ C<guestfs_is_file>, C<guestfs_is_blockdev> (etc), C<guestfs_is_zero>." }; proc_nr = Some 50; protocol_limit_warning = true; tests = [ - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command"]; ["upload"; "test-command"; "/command/test-command"]; ["chmod"; "0o755"; "/command/test-command"]; ["command"; "/command/test-command 1"]], "Result1"), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command2"]; ["upload"; "test-command"; "/command2/test-command"]; ["chmod"; "0o755"; "/command2/test-command"]; ["command"; "/command2/test-command 2"]], "Result2\n"), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command3"]; ["upload"; "test-command"; "/command3/test-command"]; ["chmod"; "0o755"; "/command3/test-command"]; ["command"; "/command3/test-command 3"]], "\nResult3"), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command4"]; ["upload"; "test-command"; "/command4/test-command"]; ["chmod"; "0o755"; "/command4/test-command"]; ["command"; "/command4/test-command 4"]], "\nResult4\n"), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command5"]; ["upload"; "test-command"; "/command5/test-command"]; ["chmod"; "0o755"; "/command5/test-command"]; ["command"; "/command5/test-command 5"]], "\nResult5\n\n"), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command6"]; ["upload"; "test-command"; "/command6/test-command"]; ["chmod"; "0o755"; "/command6/test-command"]; ["command"; "/command6/test-command 6"]], "\n\nResult6\n\n"), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command7"]; ["upload"; "test-command"; "/command7/test-command"]; ["chmod"; "0o755"; "/command7/test-command"]; ["command"; "/command7/test-command 7"]], ""), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command8"]; ["upload"; "test-command"; "/command8/test-command"]; ["chmod"; "0o755"; "/command8/test-command"]; ["command"; "/command8/test-command 8"]], "\n"), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command9"]; ["upload"; "test-command"; "/command9/test-command"]; ["chmod"; "0o755"; "/command9/test-command"]; ["command"; "/command9/test-command 9"]], "\n\n"), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command10"]; ["upload"; "test-command"; "/command10/test-command"]; ["chmod"; "0o755"; "/command10/test-command"]; ["command"; "/command10/test-command 10"]], "Result10-1\nResult10-2\n"), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/command11"]; ["upload"; "test-command"; "/command11/test-command"]; ["chmod"; "0o755"; "/command11/test-command"]; ["command"; "/command11/test-command 11"]], "Result11-1\nResult11-2"), []; - InitScratchFS, Always, TestLastFail ( + InitScratchFS, IfNotCrossAppliance, TestLastFail ( [["mkdir"; "/command12"]; ["upload"; "test-command"; "/command12/test-command"]; ["chmod"; "0o755"; "/command12/test-command"]; ["command"; "/command12/test-command"]]), []; - InitScratchFS, Always, TestResultString ( + InitScratchFS, IfNotCrossAppliance, TestResultString ( [["mkdir"; "/pwd"]; ["upload"; "test-pwd"; "/pwd/test-pwd"]; ["chmod"; "0o755"; "/pwd/test-pwd"]; @@ -4340,67 +4340,67 @@ locations." }; proc_nr = Some 51; protocol_limit_warning = true; tests = [ - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines"]; ["upload"; "test-command"; "/command_lines/test-command"]; ["chmod"; "0o755"; "/command_lines/test-command"]; ["command_lines"; "/command_lines/test-command 1"]], "is_string_list (ret, 1, \"Result1\")"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines2"]; ["upload"; "test-command"; "/command_lines2/test-command"]; ["chmod"; "0o755"; "/command_lines2/test-command"]; ["command_lines"; "/command_lines2/test-command 2"]], "is_string_list (ret, 1, \"Result2\")"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines3"]; ["upload"; "test-command"; "/command_lines3/test-command"]; ["chmod"; "0o755"; "/command_lines3/test-command"]; ["command_lines"; "/command_lines3/test-command 3"]], "is_string_list (ret, 2, \"\", \"Result3\")"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines4"]; ["upload"; "test-command"; "/command_lines4/test-command"]; ["chmod"; "0o755"; "/command_lines4/test-command"]; ["command_lines"; "/command_lines4/test-command 4"]], "is_string_list (ret, 2, \"\", \"Result4\")"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines5"]; ["upload"; "test-command"; "/command_lines5/test-command"]; ["chmod"; "0o755"; "/command_lines5/test-command"]; ["command_lines"; "/command_lines5/test-command 5"]], "is_string_list (ret, 3, \"\", \"Result5\", \"\")"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines6"]; ["upload"; "test-command"; "/command_lines6/test-command"]; ["chmod"; "0o755"; "/command_lines6/test-command"]; ["command_lines"; "/command_lines6/test-command 6"]], "is_string_list (ret, 4, \"\", \"\", \"Result6\", \"\")"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines7"]; ["upload"; "test-command"; "/command_lines7/test-command"]; ["chmod"; "0o755"; "/command_lines7/test-command"]; ["command_lines"; "/command_lines7/test-command 7"]], "is_string_list (ret, 0)"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines8"]; ["upload"; "test-command"; "/command_lines8/test-command"]; ["chmod"; "0o755"; "/command_lines8/test-command"]; ["command_lines"; "/command_lines8/test-command 8"]], "is_string_list (ret, 1, \"\")"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines9"]; ["upload"; "test-command"; "/command_lines9/test-command"]; ["chmod"; "0o755"; "/command_lines9/test-command"]; ["command_lines"; "/command_lines9/test-command 9"]], "is_string_list (ret, 2, \"\", \"\")"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines10"]; ["upload"; "test-command"; "/command_lines10/test-command"]; ["chmod"; "0o755"; "/command_lines10/test-command"]; ["command_lines"; "/command_lines10/test-command 10"]], "is_string_list (ret, 2, \"Result10-1\", \"Result10-2\")"), []; - InitScratchFS, Always, TestResult ( + InitScratchFS, IfNotCrossAppliance, TestResult ( [["mkdir"; "/command_lines11"]; ["upload"; "test-command"; "/command_lines11/test-command"]; ["chmod"; "0o755"; "/command_lines11/test-command"]; -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 14/16] customize, mllib: use the libvirt CFLAGS
uri-c.c and perl_edit-c.c end up (directly or indirectly) including guestfs-internal-frontend.h, which in turns includes libvirt/libvirt.h; hence, make sure to use the libvirt CFLAGS. --- customize/Makefile.am | 1 + mllib/Makefile.am | 1 + 2 files changed, 2 insertions(+) diff --git a/customize/Makefile.am b/customize/Makefile.am index 0ea8d39..39759dc 100644 --- a/customize/Makefile.am +++ b/customize/Makefile.am @@ -150,6 +150,7 @@ endif # we do, so we have to provide it ourselves. DEFAULT_INCLUDES = \ + $(LIBVIRT_CFLAGS) \ -I. \ -I$(top_builddir) \ -I$(shell $(OCAMLC) -where) \ diff --git a/mllib/Makefile.am b/mllib/Makefile.am index 903a77d..2ad4eaa 100644 --- a/mllib/Makefile.am +++ b/mllib/Makefile.am @@ -137,6 +137,7 @@ libdir.ml: Makefile # we do, so we have to provide it ourselves. DEFAULT_INCLUDES = \ + $(LIBVIRT_CFLAGS) \ -I. \ -I$(top_builddir) \ -I$(shell $(OCAMLC) -where) \ -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 15/16] tests: switch from get_current_dir_name to getcwd(0, NULL)
get_current_dir_name exists on GNU libc only, so not portable. On the other hand, while POSIX leaves a null buffer argument for getcwd as unspecified behaviour, basically the most used/important Unix implementations (GNU libc, FreeBSD's libc, etc) allow such value, returning a new allocated buffer with the current directory. In any case, the change just affects two tests, so even if it hits a libc not implementing this behaviour for getcwd, only tests are affected. --- tests/c-api/test-pwd.c | 2 +- tests/events/test-libvirt-auth-callbacks.c | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/tests/c-api/test-pwd.c b/tests/c-api/test-pwd.c index 60b978c..61b88ec 100644 --- a/tests/c-api/test-pwd.c +++ b/tests/c-api/test-pwd.c @@ -28,7 +28,7 @@ int main (int argc, char *argv[]) { - char *cwd = get_current_dir_name(); + char *cwd = getcwd(NULL, 0); printf("%s", cwd); exit (EXIT_SUCCESS); diff --git a/tests/events/test-libvirt-auth-callbacks.c b/tests/events/test-libvirt-auth-callbacks.c index 7c26bbe..383f20f 100644 --- a/tests/events/test-libvirt-auth-callbacks.c +++ b/tests/events/test-libvirt-auth-callbacks.c @@ -70,9 +70,9 @@ main (int argc, char *argv[]) exit (EXIT_FAILURE); } - cwd = get_current_dir_name (); + cwd = getcwd (NULL, 0); if (cwd == NULL) { - perror ("get_current_dir_name"); + perror ("getcwd"); exit (EXIT_FAILURE); } -- 1.9.3
Pino Toscano
2014-Oct-23 18:18 UTC
[Libguestfs] [PATCH 16/16] configure: map also amd64 as host_cpu to x86_64 qemu
--- configure.ac | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/configure.ac b/configure.ac index 8cd29d7..6174c7c 100644 --- a/configure.ac +++ b/configure.ac @@ -733,7 +733,8 @@ dnl back to basic 'qemu'. Allow the user to override it. qemu_system="$( echo qemu-system-$host_cpu | $SED -e 's/-i@<:@456@:>@86/-i386/g' \ - -e 's/-arm.*/-arm/g' + -e 's/-arm.*/-arm/g' \ + -e 's/-amd64/-x86_64/g' )" default_qemu="qemu-kvm kvm $qemu_system qemu" AC_ARG_WITH([qemu], -- 1.9.3
Richard W.M. Jones
2014-Oct-23 20:26 UTC
Re: [Libguestfs] [PATCH 16/16] configure: map also amd64 as host_cpu to x86_64 qemu
On Thu, Oct 23, 2014 at 08:18:44PM +0200, Pino Toscano wrote:> --- > configure.ac | 3 ++- > 1 file changed, 2 insertions(+), 1 deletion(-) > > diff --git a/configure.ac b/configure.ac > index 8cd29d7..6174c7c 100644 > --- a/configure.ac > +++ b/configure.ac > @@ -733,7 +733,8 @@ dnl back to basic 'qemu'. Allow the user to override it. > qemu_system="$( > echo qemu-system-$host_cpu | > $SED -e 's/-i@<:@456@:>@86/-i386/g' \ > - -e 's/-arm.*/-arm/g' > + -e 's/-arm.*/-arm/g' \ > + -e 's/-amd64/-x86_64/g' > )" > default_qemu="qemu-kvm kvm $qemu_system qemu" > AC_ARG_WITH([qemu], > -- > 1.9.3ACK whole series. Thanks, Rich. -- Richard Jones, Virtualization Group, Red Hat http://people.redhat.com/~rjones Read my programming and virtualization blog: http://rwmj.wordpress.com virt-p2v converts physical machines to virtual machines. Boot with a live CD or over the network (PXE) and turn machines into KVM guests. http://libguestfs.org/virt-v2v
Reasonably Related Threads
- [PATCH 0/6] generator: Split up generator/actions.ml
- [PATCH v7 00/10] tests: Introduce test harness for running tests.
- [PATCH 00/10] tests: Introduce test harness for running tests.
- [PATCH v4 00/17] tests: Introduce test harness for running tests.
- [PATCH v4 0/4] tests: Introduce test harness for running tests.