On 04/13/2018 02:26 PM, Nir Soffer wrote: > Add new test module for tesing the --nolist option. > > Signed-off-by: Nir Soffer <nir...@gmail.com> > ---
> +iotests.log('Check that listing exports is allowed by default') > +disk, nbd_sock = iotests.file_path('disk1', 'nbd-sock1') > +iotests.qemu_img_create('-f', iotests.imgfmt, disk, '1m') > +iotests.qemu_nbd('-k', nbd_sock, '-f', iotests.imgfmt, '-x', 'export', disk) > +out = iotests.run('nbd-client', '-l', '--unix', nbd_sock) Should we really be relying on the third-party nbd-client to be installed? Would it not be better to teach our own NBD client to learn how to do interesting things over NBD? Your use case of listing the output of NBD_OPT_LIST is one, but another that readily comes to mind is listing the possibilities of NBD_OPT_LIST_META_CONTEXT that just went into 2.12. Maybe making 'qemu-img info' give more details when connecting to an NBD server, compared to what is normally needed just for connecting to an export on that server? Additionally, once we merge in Vladimir's work to expose persistent dirty bitmaps via NBD_OPT_SET_META_CONTEXT/NBD_CMD_BLOCK_STATUS, it would be nice to have an in-tree tool for reading out the context information of an NBD export, perhaps extending what 'qemu-img map' can already do (Vladimir already mentioned that he only implemented the server side, and left the client side for an out-of-tree solution [1], although I'm wondering if that is still the wisest course of action). [1] https://lists.gnu.org/archive/html/qemu-devel/2018-03/msg05701.html > + > +assert 'export' in out.splitlines(), 'Export not in %r' % out > + > +iotests.log('Check that listing exports is forbidden with --nolist') > +disk, nbd_sock = iotests.file_path('disk2', 'nbd-sock2') > +iotests.qemu_img_create('-f', iotests.imgfmt, disk, '1m') > +iotests.qemu_nbd('-k', nbd_sock, '-f', iotests.imgfmt, '-x', 'secret', > + '--nolist', disk) > + > +# nbd-client fails when listing is not allowed, but lets not depend on 3rd s/lets/let's/ -- Eric Blake, Principal Software Engineer Red Hat, Inc. +1-919-301-3266 Virtualization: qemu.org | libvirt.org
signature.asc
Description: OpenPGP digital signature