Blame SOURCES/0003-server-Add-D-nbdkit.backend.controlpath-and-D-nbdkit.patch

efa7a1
From 83c72d9bf9d6a9ccf6939b4ebd0028b62673a78a Mon Sep 17 00:00:00 2001
efa7a1
From: "Richard W.M. Jones" <rjones@redhat.com>
efa7a1
Date: Thu, 12 Dec 2019 10:57:52 +0000
60545c
Subject: [PATCH 03/19] server: Add -D nbdkit.backend.controlpath and -D
efa7a1
 nbdkit.backend.datapath.
efa7a1
efa7a1
These can be used to suppress verbose debugging messages from the
efa7a1
backend.
efa7a1
efa7a1
BugLink: https://bugzilla.redhat.com/1782868
efa7a1
efa7a1
Cherry picked from commit 231717e8cd5f27d76631be6651062d5a5ccf7fdc.
efa7a1
Remove use of nofilter from the test.
efa7a1
---
efa7a1
 docs/nbdkit.pod                    | 35 ++++++++++++-
efa7a1
 server/backend.c                   | 83 ++++++++++++++++++------------
efa7a1
 tests/Makefile.am                  |  4 ++
efa7a1
 tests/test-nbdkit-backend-debug.sh | 70 +++++++++++++++++++++++++
efa7a1
 4 files changed, 158 insertions(+), 34 deletions(-)
efa7a1
 create mode 100755 tests/test-nbdkit-backend-debug.sh
efa7a1
efa7a1
diff --git a/docs/nbdkit.pod b/docs/nbdkit.pod
60545c
index 346d8332..38e6bfca 100644
efa7a1
--- a/docs/nbdkit.pod
efa7a1
+++ b/docs/nbdkit.pod
efa7a1
@@ -182,7 +182,7 @@ value C<N>.  See L<nbdkit-plugin(3)/Debug Flags>.
efa7a1
 =item B<--debug> nbdkit.FLAG=N
efa7a1
 
efa7a1
 Set the nbdkit server Debug Flag called C<FLAG> to the integer value
efa7a1
-C<N>.
efa7a1
+C<N>.  See L</SERVER DEBUG FLAGS> below.
efa7a1
 
efa7a1
 =item B<--dump-config>
efa7a1
 
efa7a1
@@ -527,6 +527,39 @@ languages.  The file should be executable.  For example:
efa7a1
 
efa7a1
 (see L<nbdkit-perl-plugin(3)> for a full example).
efa7a1
 
efa7a1
+=head1 SERVER DEBUG FLAGS
efa7a1
+
efa7a1
+As well as enabling or disabling debugging in the server using
efa7a1
+I<--verbose> you can control extra debugging in the server using the
efa7a1
+C<-D nbdkit.*> flags listed in this section.  Note these flags are an
efa7a1
+internal implementation detail of the server and may be changed or
efa7a1
+removed at any time in the future.
efa7a1
+
efa7a1
+=over 4
efa7a1
+
efa7a1
+=item B<-D nbdkit.backend.controlpath=0>
efa7a1
+
efa7a1
+=item B<-D nbdkit.backend.controlpath=1>
efa7a1
+
efa7a1
+=item B<-D nbdkit.backend.datapath=0>
efa7a1
+
efa7a1
+=item B<-D nbdkit.backend.datapath=1>
efa7a1
+
efa7a1
+These flags control the verbosity of nbdkit backend debugging messages
efa7a1
+(the ones which show every request processed by the server).  The
efa7a1
+default for both settings is C<1> (normal debugging) but you can set
efa7a1
+them to C<0> to suppress these messages.
efa7a1
+
efa7a1
+C<-D nbdkit.backend.datapath=0> is the more useful setting which lets you
efa7a1
+suppress messages about pread, pwrite, zero, trim, etc. commands.
efa7a1
+When transferring large amounts of data these messages are numerous
efa7a1
+and not usually very interesting.
efa7a1
+
efa7a1
+C<-D nbdkit.backend.controlpath=0> suppresses the non-datapath
efa7a1
+commands (config, open, close, can_write, etc.)
efa7a1
+
efa7a1
+=back
efa7a1
+
efa7a1
 =head1 SIGNALS
efa7a1
 
efa7a1
 nbdkit responds to the following signals:
efa7a1
diff --git a/server/backend.c b/server/backend.c
60545c
index b9fe2a21..208c07b1 100644
efa7a1
--- a/server/backend.c
efa7a1
+++ b/server/backend.c
efa7a1
@@ -46,6 +46,22 @@
efa7a1
 
efa7a1
 /* Helpers for registering a new backend. */
efa7a1
 
efa7a1
+/* Use:
efa7a1
+ * -D nbdkit.backend.controlpath=0 to suppress control path debugging.
efa7a1
+ * -D nbdkit.backend.datapath=0 to suppress data path debugging.
efa7a1
+ */
efa7a1
+int nbdkit_debug_backend_controlpath = 1;
efa7a1
+int nbdkit_debug_backend_datapath = 1;
efa7a1
+
efa7a1
+#define controlpath_debug(fs, ...)                                     \
efa7a1
+  do {                                                                 \
efa7a1
+    if (nbdkit_debug_backend_controlpath) debug ((fs), ##__VA_ARGS__); \
efa7a1
+  } while (0)
efa7a1
+#define datapath_debug(fs, ...)                                        \
efa7a1
+  do {                                                                 \
efa7a1
+    if (nbdkit_debug_backend_datapath) debug ((fs), ##__VA_ARGS__);    \
efa7a1
+  } while (0)
efa7a1
+
efa7a1
 void
efa7a1
 backend_init (struct backend *b, struct backend *next, size_t index,
efa7a1
               const char *filename, void *dl, const char *type)
efa7a1
@@ -108,7 +124,7 @@ backend_load (struct backend *b, const char *name, void (*load) (void))
efa7a1
   apply_debug_flags (b->dl, name);
efa7a1
 
efa7a1
   /* Call the on-load callback if it exists. */
efa7a1
-  debug ("%s: load", name);
efa7a1
+  controlpath_debug ("%s: load", name);
efa7a1
   if (load)
efa7a1
     load ();
efa7a1
 }
efa7a1
@@ -121,7 +137,7 @@ backend_unload (struct backend *b, void (*unload) (void))
efa7a1
    */
efa7a1
   lock_unload ();
efa7a1
 
efa7a1
-  debug ("%s: unload %s", b->name, b->type);
efa7a1
+  controlpath_debug ("%s: unload %s", b->name, b->type);
efa7a1
   if (unload)
efa7a1
     unload ();
efa7a1
 
efa7a1
@@ -139,7 +155,7 @@ backend_open (struct backend *b, struct connection *conn, int readonly)
efa7a1
 {
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
 
efa7a1
-  debug ("%s: open readonly=%d", b->name, readonly);
efa7a1
+  controlpath_debug ("%s: open readonly=%d", b->name, readonly);
efa7a1
 
efa7a1
   assert (h->handle == NULL);
efa7a1
   assert ((h->state & HANDLE_OPEN) == 0);
efa7a1
@@ -151,7 +167,7 @@ backend_open (struct backend *b, struct connection *conn, int readonly)
efa7a1
    * inner-to-outer ordering.
efa7a1
    */
efa7a1
   h->handle = b->open (b, conn, readonly);
efa7a1
-  debug ("%s: open returned handle %p", b->name, h->handle);
efa7a1
+  controlpath_debug ("%s: open returned handle %p", b->name, h->handle);
efa7a1
 
efa7a1
   if (h->handle == NULL) {
efa7a1
     if (b->i) /* Do not strand backend if this layer failed */
efa7a1
@@ -179,7 +195,7 @@ backend_prepare (struct backend *b, struct connection *conn)
efa7a1
   if (b->i && backend_prepare (b->next, conn) == -1)
efa7a1
     return -1;
efa7a1
 
efa7a1
-  debug ("%s: prepare readonly=%d", b->name, h->can_write == 0);
efa7a1
+  controlpath_debug ("%s: prepare readonly=%d", b->name, h->can_write == 0);
efa7a1
 
efa7a1
   if (b->prepare (b, conn, h->handle, h->can_write == 0) == -1)
efa7a1
     return -1;
efa7a1
@@ -196,7 +212,7 @@ backend_finalize (struct backend *b, struct connection *conn)
efa7a1
    * filter furthest away from the plugin, and matching .close order.
efa7a1
    */
efa7a1
 
efa7a1
-  debug ("%s: finalize", b->name);
efa7a1
+  controlpath_debug ("%s: finalize", b->name);
efa7a1
 
efa7a1
   /* Once finalize fails, we can do nothing further on this connection */
efa7a1
   if (h->state & HANDLE_FAILED)
efa7a1
@@ -223,7 +239,7 @@ backend_close (struct backend *b, struct connection *conn)
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
 
efa7a1
   /* outer-to-inner order, opposite .open */
efa7a1
-  debug ("%s: close", b->name);
efa7a1
+  controlpath_debug ("%s: close", b->name);
efa7a1
 
efa7a1
   if (h->handle) {
efa7a1
     assert (h->state & HANDLE_OPEN);
efa7a1
@@ -252,7 +268,7 @@ backend_valid_range (struct backend *b, struct connection *conn,
efa7a1
 int
efa7a1
 backend_reopen (struct backend *b, struct connection *conn, int readonly)
efa7a1
 {
efa7a1
-  debug ("%s: reopen readonly=%d", b->name, readonly);
efa7a1
+  controlpath_debug ("%s: reopen readonly=%d", b->name, readonly);
efa7a1
 
efa7a1
   if (backend_finalize (b, conn) == -1)
efa7a1
     return -1;
efa7a1
@@ -274,7 +290,7 @@ backend_get_size (struct backend *b, struct connection *conn)
efa7a1
 {
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
 
efa7a1
-  debug ("%s: get_size", b->name);
efa7a1
+  controlpath_debug ("%s: get_size", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->exportsize == -1)
efa7a1
@@ -287,7 +303,7 @@ backend_can_write (struct backend *b, struct connection *conn)
efa7a1
 {
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
 
efa7a1
-  debug ("%s: can_write", b->name);
efa7a1
+  controlpath_debug ("%s: can_write", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->can_write == -1)
efa7a1
@@ -300,7 +316,7 @@ backend_can_flush (struct backend *b, struct connection *conn)
efa7a1
 {
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
 
efa7a1
-  debug ("%s: can_flush", b->name);
efa7a1
+  controlpath_debug ("%s: can_flush", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->can_flush == -1)
efa7a1
@@ -313,7 +329,7 @@ backend_is_rotational (struct backend *b, struct connection *conn)
efa7a1
 {
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
 
efa7a1
-  debug ("%s: is_rotational", b->name);
efa7a1
+  controlpath_debug ("%s: is_rotational", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->is_rotational == -1)
efa7a1
@@ -327,7 +343,7 @@ backend_can_trim (struct backend *b, struct connection *conn)
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
   int r;
efa7a1
 
efa7a1
-  debug ("%s: can_trim", b->name);
efa7a1
+  controlpath_debug ("%s: can_trim", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->can_trim == -1) {
efa7a1
@@ -347,7 +363,7 @@ backend_can_zero (struct backend *b, struct connection *conn)
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
   int r;
efa7a1
 
efa7a1
-  debug ("%s: can_zero", b->name);
efa7a1
+  controlpath_debug ("%s: can_zero", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->can_zero == -1) {
efa7a1
@@ -367,7 +383,7 @@ backend_can_fast_zero (struct backend *b, struct connection *conn)
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
   int r;
efa7a1
 
efa7a1
-  debug ("%s: can_fast_zero", b->name);
efa7a1
+  controlpath_debug ("%s: can_fast_zero", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->can_fast_zero == -1) {
efa7a1
@@ -386,7 +402,7 @@ backend_can_extents (struct backend *b, struct connection *conn)
efa7a1
 {
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
 
efa7a1
-  debug ("%s: can_extents", b->name);
efa7a1
+  controlpath_debug ("%s: can_extents", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->can_extents == -1)
efa7a1
@@ -400,7 +416,7 @@ backend_can_fua (struct backend *b, struct connection *conn)
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
   int r;
efa7a1
 
efa7a1
-  debug ("%s: can_fua", b->name);
efa7a1
+  controlpath_debug ("%s: can_fua", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->can_fua == -1) {
efa7a1
@@ -420,7 +436,7 @@ backend_can_multi_conn (struct backend *b, struct connection *conn)
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
-  debug ("%s: can_multi_conn", b->name);
efa7a1
+  controlpath_debug ("%s: can_multi_conn", b->name);
efa7a1
 
efa7a1
   if (h->can_multi_conn == -1)
efa7a1
     h->can_multi_conn = b->can_multi_conn (b, conn, h->handle);
efa7a1
@@ -432,7 +448,7 @@ backend_can_cache (struct backend *b, struct connection *conn)
efa7a1
 {
efa7a1
   struct b_conn_handle *h = &conn->handles[b->i];
efa7a1
 
efa7a1
-  debug ("%s: can_cache", b->name);
efa7a1
+  controlpath_debug ("%s: can_cache", b->name);
efa7a1
 
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   if (h->can_cache == -1)
efa7a1
@@ -451,8 +467,8 @@ backend_pread (struct backend *b, struct connection *conn,
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   assert (backend_valid_range (b, conn, offset, count));
efa7a1
   assert (flags == 0);
efa7a1
-  debug ("%s: pread count=%" PRIu32 " offset=%" PRIu64,
efa7a1
-         b->name, count, offset);
efa7a1
+  datapath_debug ("%s: pread count=%" PRIu32 " offset=%" PRIu64,
efa7a1
+                  b->name, count, offset);
efa7a1
 
efa7a1
   r = b->pread (b, conn, h->handle, buf, count, offset, flags, err);
efa7a1
   if (r == -1)
efa7a1
@@ -475,8 +491,8 @@ backend_pwrite (struct backend *b, struct connection *conn,
efa7a1
   assert (!(flags & ~NBDKIT_FLAG_FUA));
efa7a1
   if (fua)
efa7a1
     assert (h->can_fua > NBDKIT_FUA_NONE);
efa7a1
-  debug ("%s: pwrite count=%" PRIu32 " offset=%" PRIu64 " fua=%d",
efa7a1
-         b->name, count, offset, fua);
efa7a1
+  datapath_debug ("%s: pwrite count=%" PRIu32 " offset=%" PRIu64 " fua=%d",
efa7a1
+                  b->name, count, offset, fua);
efa7a1
 
efa7a1
   r = b->pwrite (b, conn, h->handle, buf, count, offset, flags, err);
efa7a1
   if (r == -1)
efa7a1
@@ -494,7 +510,7 @@ backend_flush (struct backend *b, struct connection *conn,
efa7a1
   assert (h->handle && (h->state & HANDLE_CONNECTED));
efa7a1
   assert (h->can_flush == 1);
efa7a1
   assert (flags == 0);
efa7a1
-  debug ("%s: flush", b->name);
efa7a1
+  datapath_debug ("%s: flush", b->name);
efa7a1
 
efa7a1
   r = b->flush (b, conn, h->handle, flags, err);
efa7a1
   if (r == -1)
efa7a1
@@ -518,8 +534,8 @@ backend_trim (struct backend *b, struct connection *conn,
efa7a1
   assert (!(flags & ~NBDKIT_FLAG_FUA));
efa7a1
   if (fua)
efa7a1
     assert (h->can_fua > NBDKIT_FUA_NONE);
efa7a1
-  debug ("%s: trim count=%" PRIu32 " offset=%" PRIu64 " fua=%d",
efa7a1
-         b->name, count, offset, fua);
efa7a1
+  datapath_debug ("%s: trim count=%" PRIu32 " offset=%" PRIu64 " fua=%d",
efa7a1
+                  b->name, count, offset, fua);
efa7a1
 
efa7a1
   r = b->trim (b, conn, h->handle, count, offset, flags, err);
efa7a1
   if (r == -1)
efa7a1
@@ -547,9 +563,10 @@ backend_zero (struct backend *b, struct connection *conn,
efa7a1
     assert (h->can_fua > NBDKIT_FUA_NONE);
efa7a1
   if (fast)
efa7a1
     assert (h->can_fast_zero == 1);
efa7a1
-  debug ("%s: zero count=%" PRIu32 " offset=%" PRIu64
efa7a1
-         " may_trim=%d fua=%d fast=%d",
efa7a1
-         b->name, count, offset, !!(flags & NBDKIT_FLAG_MAY_TRIM), fua, fast);
efa7a1
+  datapath_debug ("%s: zero count=%" PRIu32 " offset=%" PRIu64
efa7a1
+                  " may_trim=%d fua=%d fast=%d",
efa7a1
+                  b->name, count, offset,
efa7a1
+                  !!(flags & NBDKIT_FLAG_MAY_TRIM), fua, fast);
efa7a1
 
efa7a1
   r = b->zero (b, conn, h->handle, count, offset, flags, err);
efa7a1
   if (r == -1) {
efa7a1
@@ -572,8 +589,8 @@ backend_extents (struct backend *b, struct connection *conn,
efa7a1
   assert (h->can_extents >= 0);
efa7a1
   assert (backend_valid_range (b, conn, offset, count));
efa7a1
   assert (!(flags & ~NBDKIT_FLAG_REQ_ONE));
efa7a1
-  debug ("%s: extents count=%" PRIu32 " offset=%" PRIu64 " req_one=%d",
efa7a1
-         b->name, count, offset, !!(flags & NBDKIT_FLAG_REQ_ONE));
efa7a1
+  datapath_debug ("%s: extents count=%" PRIu32 " offset=%" PRIu64 " req_one=%d",
efa7a1
+                  b->name, count, offset, !!(flags & NBDKIT_FLAG_REQ_ONE));
efa7a1
 
efa7a1
   if (h->can_extents == 0) {
efa7a1
     /* By default it is safe assume that everything in the range is
efa7a1
@@ -602,8 +619,8 @@ backend_cache (struct backend *b, struct connection *conn,
efa7a1
   assert (h->can_cache > NBDKIT_CACHE_NONE);
efa7a1
   assert (backend_valid_range (b, conn, offset, count));
efa7a1
   assert (flags == 0);
efa7a1
-  debug ("%s: cache count=%" PRIu32 " offset=%" PRIu64,
efa7a1
-         b->name, count, offset);
efa7a1
+  datapath_debug ("%s: cache count=%" PRIu32 " offset=%" PRIu64,
efa7a1
+                  b->name, count, offset);
efa7a1
 
efa7a1
   if (h->can_cache == NBDKIT_CACHE_EMULATE) {
efa7a1
     static char buf[MAX_REQUEST_SIZE]; /* data sink, never read */
efa7a1
diff --git a/tests/Makefile.am b/tests/Makefile.am
60545c
index 01341973..d225cc63 100644
efa7a1
--- a/tests/Makefile.am
efa7a1
+++ b/tests/Makefile.am
efa7a1
@@ -135,6 +135,7 @@ EXTRA_DIST = \
efa7a1
 	test-nbd-extents.sh \
efa7a1
 	test-nbd-tls.sh \
efa7a1
 	test-nbd-tls-psk.sh \
efa7a1
+	test-nbdkit-backend-debug.sh \
efa7a1
 	test-nozero.sh \
efa7a1
 	test-null-extents.sh \
efa7a1
 	test_ocaml_plugin.ml \
efa7a1
@@ -746,6 +747,9 @@ endif HAVE_VDDK
efa7a1
 # zero plugin test.
efa7a1
 TESTS += test-zero.sh
efa7a1
 
efa7a1
+# -D nbdkit.backend.* settings.
efa7a1
+TESTS += test-nbdkit-backend-debug.sh
efa7a1
+
efa7a1
 #----------------------------------------------------------------------
efa7a1
 # Tests of language plugins.
efa7a1
 
efa7a1
diff --git a/tests/test-nbdkit-backend-debug.sh b/tests/test-nbdkit-backend-debug.sh
efa7a1
new file mode 100755
60545c
index 00000000..69a69a7c
efa7a1
--- /dev/null
efa7a1
+++ b/tests/test-nbdkit-backend-debug.sh
efa7a1
@@ -0,0 +1,70 @@
efa7a1
+#!/usr/bin/env bash
efa7a1
+# nbdkit
efa7a1
+# Copyright (C) 2019 Red Hat Inc.
efa7a1
+#
efa7a1
+# Redistribution and use in source and binary forms, with or without
efa7a1
+# modification, are permitted provided that the following conditions are
efa7a1
+# met:
efa7a1
+#
efa7a1
+# * Redistributions of source code must retain the above copyright
efa7a1
+# notice, this list of conditions and the following disclaimer.
efa7a1
+#
efa7a1
+# * Redistributions in binary form must reproduce the above copyright
efa7a1
+# notice, this list of conditions and the following disclaimer in the
efa7a1
+# documentation and/or other materials provided with the distribution.
efa7a1
+#
efa7a1
+# * Neither the name of Red Hat nor the names of its contributors may be
efa7a1
+# used to endorse or promote products derived from this software without
efa7a1
+# specific prior written permission.
efa7a1
+#
efa7a1
+# THIS SOFTWARE IS PROVIDED BY RED HAT AND CONTRIBUTORS ''AS IS'' AND
efa7a1
+# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
efa7a1
+# THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
efa7a1
+# PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL RED HAT OR
efa7a1
+# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
efa7a1
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
efa7a1
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
efa7a1
+# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
efa7a1
+# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
efa7a1
+# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
efa7a1
+# OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
efa7a1
+# SUCH DAMAGE.
efa7a1
+
efa7a1
+source ./functions.sh
efa7a1
+set -x
efa7a1
+set -e
efa7a1
+
efa7a1
+requires qemu-img --version
efa7a1
+
efa7a1
+out="test-nbdkit-backend-debug.out"
efa7a1
+debug="test-nbdkit-backend-debug.debug"
efa7a1
+files="$out $debug"
efa7a1
+rm -f $files
efa7a1
+cleanup_fn rm -f $files
efa7a1
+
efa7a1
+nbdkit -U - \
efa7a1
+       -v \
efa7a1
+       memory 10M \
efa7a1
+       --run "qemu-img convert \$nbd $out" |& tee $debug
efa7a1
+
efa7a1
+# Should contain all debugging messages.
efa7a1
+grep '^nbdkit:.*debug: memory: open' $debug
efa7a1
+grep '^nbdkit:.*debug: memory: pread' $debug
efa7a1
+
efa7a1
+nbdkit -U - \
efa7a1
+       -v -D nbdkit.backend.controlpath=0 \
efa7a1
+       memory 10M \
efa7a1
+       --run "qemu-img convert \$nbd $out" |& tee $debug
efa7a1
+
efa7a1
+# Should contain only datapath messages.
efa7a1
+grep -v '^nbdkit:.*debug: memory: open' $debug
efa7a1
+grep '^nbdkit:.*debug: memory: pread' $debug
efa7a1
+
efa7a1
+nbdkit -U - \
efa7a1
+       -v -D nbdkit.backend.datapath=0 \
efa7a1
+       memory 10M \
efa7a1
+       --run "qemu-img convert \$nbd $out" |& tee $debug
efa7a1
+
efa7a1
+# Should contain only controlpath messages.
efa7a1
+grep '^nbdkit:.*debug: memory: open' $debug
efa7a1
+grep -v '^nbdkit:.*debug: memory: pread' $debug
efa7a1
-- 
efa7a1
2.18.2
efa7a1