2009-10-09 14:17:21 -04:00
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
|
#include "internal.h"
|
|
|
|
#include "testutils.h"
|
|
|
|
#include "storage_conf.h"
|
|
|
|
#include "testutilsqemu.h"
|
2013-04-03 12:36:23 +02:00
|
|
|
#include "virstring.h"
|
2009-10-09 14:17:21 -04:00
|
|
|
|
2013-06-07 17:10:28 +02:00
|
|
|
#define VIR_FROM_THIS VIR_FROM_NONE
|
|
|
|
|
2011-04-25 00:25:10 +02:00
|
|
|
static int
|
|
|
|
testCompareXMLToXMLFiles(const char *poolxml, const char *inxml,
|
2015-02-05 16:20:17 +01:00
|
|
|
const char *outxml, unsigned int flags)
|
2011-04-25 00:25:10 +02:00
|
|
|
{
|
2009-10-09 14:17:21 -04:00
|
|
|
char *actual = NULL;
|
|
|
|
int ret = -1;
|
|
|
|
virStoragePoolDefPtr pool = NULL;
|
|
|
|
virStorageVolDefPtr dev = NULL;
|
|
|
|
|
2015-04-23 11:10:15 -04:00
|
|
|
if (!(pool = virStoragePoolDefParseFile(poolxml)))
|
2009-10-09 14:17:21 -04:00
|
|
|
goto fail;
|
|
|
|
|
2015-04-23 11:10:15 -04:00
|
|
|
if (!(dev = virStorageVolDefParseFile(pool, inxml, flags)))
|
2009-10-09 14:17:21 -04:00
|
|
|
goto fail;
|
|
|
|
|
2010-02-10 11:42:56 +00:00
|
|
|
if (!(actual = virStorageVolDefFormat(pool, dev)))
|
2009-10-09 14:17:21 -04:00
|
|
|
goto fail;
|
|
|
|
|
2016-05-26 17:01:53 +02:00
|
|
|
if (virTestCompareToFile(actual, outxml) < 0)
|
2009-10-09 14:17:21 -04:00
|
|
|
goto fail;
|
|
|
|
|
|
|
|
ret = 0;
|
|
|
|
|
|
|
|
fail:
|
2012-02-02 16:16:43 -07:00
|
|
|
VIR_FREE(actual);
|
2009-10-09 14:17:21 -04:00
|
|
|
virStoragePoolDefFree(pool);
|
|
|
|
virStorageVolDefFree(dev);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct testInfo {
|
|
|
|
const char *pool;
|
|
|
|
const char *name;
|
2015-02-05 16:20:17 +01:00
|
|
|
unsigned int flags;
|
2009-10-09 14:17:21 -04:00
|
|
|
};
|
|
|
|
|
2011-04-25 00:25:10 +02:00
|
|
|
static int
|
|
|
|
testCompareXMLToXMLHelper(const void *data)
|
|
|
|
{
|
|
|
|
int result = -1;
|
2009-10-09 14:17:21 -04:00
|
|
|
const struct testInfo *info = data;
|
2011-04-25 00:25:10 +02:00
|
|
|
char *poolxml = NULL;
|
|
|
|
char *inxml = NULL;
|
|
|
|
char *outxml = NULL;
|
|
|
|
|
|
|
|
if (virAsprintf(&poolxml, "%s/storagepoolxml2xmlin/%s.xml",
|
|
|
|
abs_srcdir, info->pool) < 0 ||
|
|
|
|
virAsprintf(&inxml, "%s/storagevolxml2xmlin/%s.xml",
|
|
|
|
abs_srcdir, info->name) < 0 ||
|
|
|
|
virAsprintf(&outxml, "%s/storagevolxml2xmlout/%s.xml",
|
|
|
|
abs_srcdir, info->name) < 0) {
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
2015-02-05 16:20:17 +01:00
|
|
|
result = testCompareXMLToXMLFiles(poolxml, inxml, outxml, info->flags);
|
2011-04-25 00:25:10 +02:00
|
|
|
|
2014-03-25 07:53:44 +01:00
|
|
|
cleanup:
|
2012-02-02 16:16:43 -07:00
|
|
|
VIR_FREE(poolxml);
|
|
|
|
VIR_FREE(inxml);
|
|
|
|
VIR_FREE(outxml);
|
2009-10-09 14:17:21 -04:00
|
|
|
|
2011-04-25 00:25:10 +02:00
|
|
|
return result;
|
2009-10-09 14:17:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int
|
2011-04-29 10:21:20 -06:00
|
|
|
mymain(void)
|
2009-10-09 14:17:21 -04:00
|
|
|
{
|
|
|
|
int ret = 0;
|
|
|
|
|
2015-02-05 16:20:17 +01:00
|
|
|
#define DO_TEST_FULL(pool, name, flags) \
|
2013-09-20 19:13:35 +01:00
|
|
|
do { \
|
2015-02-05 16:20:17 +01:00
|
|
|
struct testInfo info = { pool, name, flags }; \
|
2016-05-26 17:01:50 +02:00
|
|
|
if (virTestRun("Storage Vol XML-2-XML " name, \
|
|
|
|
testCompareXMLToXMLHelper, &info) < 0) \
|
2013-09-20 19:13:35 +01:00
|
|
|
ret = -1; \
|
|
|
|
} \
|
2012-10-17 10:23:12 +01:00
|
|
|
while (0);
|
2009-10-09 14:17:21 -04:00
|
|
|
|
2015-02-05 16:20:17 +01:00
|
|
|
#define DO_TEST(pool, name) DO_TEST_FULL(pool, name, 0)
|
|
|
|
|
2009-10-09 14:17:21 -04:00
|
|
|
DO_TEST("pool-dir", "vol-file");
|
storage: use valid XML for awkward volume names
$ touch /var/lib/libvirt/images/'a<b>c'
$ virsh pool-refresh default
$ virsh vol-dumpxml 'a<b>c' default | head -n2
<volume>
<name>a<b>c</name>
Oops. That's not valid XML. And when we fix the XML
generation, it fails RelaxNG validation.
I'm also tired of seeing <key>(null)</key> in the example
output for volume xml; while we used NULLSTR() to avoid
a NULL deref rather than relying on glibc's printf
extension behavior, it's even better if we avoid the issue
in the first place. But this requires being careful that
we don't invalidate any storage backends that were relying
on key being unassigned during virStoragVolCreateXML[From].
I would have split this into two patches (one for escaping,
one for avoiding <key>(null)</key>), but since they both
end up touching a lot of the same test files, I ended up
merging it into one.
Note that this patch allows pretty much any volume name
that can appear in a directory (excluding . and .. because
those are special), but does nothing to change the current
(unenforced) RelaxNG claim that pool names will consist
only of letters, numbers, _, -, and +. Tightening the C
code to match RelaxNG patterns and/or relaxing the grammar
to match the C code for pool names is a task for another
day (but remember, we DID recently tighten C code for
domain names to exclude a leading '.').
* src/conf/storage_conf.c (virStoragePoolSourceFormat)
(virStoragePoolDefFormat, virStorageVolTargetDefFormat)
(virStorageVolDefFormat): Escape user-controlled strings.
(virStorageVolDefParseXML): Parse key, for use in unit tests.
* src/storage/storage_driver.c (storageVolCreateXML)
(storageVolCreateXMLFrom): Ensure parsed key doesn't confuse
volume creation.
* docs/schemas/basictypes.rng (volName): Relax definition.
* tests/storagepoolxml2xmltest.c (mymain): Test it.
* tests/storagevolxml2xmltest.c (mymain): Likewise.
* tests/storagepoolxml2xmlin/pool-dir-naming.xml: New file.
* tests/storagepoolxml2xmlout/pool-dir-naming.xml: Likewise.
* tests/storagevolxml2xmlin/vol-file-naming.xml: Likewise.
* tests/storagevolxml2xmlout/vol-file-naming.xml: Likewise.
* tests/storagevolxml2xmlout/vol-*.xml: Fix fallout.
Signed-off-by: Eric Blake <eblake@redhat.com>
2013-11-20 17:04:05 -07:00
|
|
|
DO_TEST("pool-dir", "vol-file-naming");
|
2009-10-09 14:17:21 -04:00
|
|
|
DO_TEST("pool-dir", "vol-file-backing");
|
2017-03-07 10:50:59 -05:00
|
|
|
DO_TEST("pool-dir", "vol-file-iso");
|
2009-10-09 14:17:21 -04:00
|
|
|
DO_TEST("pool-dir", "vol-qcow2");
|
2013-05-16 12:38:26 +02:00
|
|
|
DO_TEST("pool-dir", "vol-qcow2-1.1");
|
|
|
|
DO_TEST("pool-dir", "vol-qcow2-lazy");
|
2013-07-22 15:44:06 +02:00
|
|
|
DO_TEST("pool-dir", "vol-qcow2-0.10-lazy");
|
|
|
|
DO_TEST("pool-dir", "vol-qcow2-nobacking");
|
2016-06-01 15:01:31 -04:00
|
|
|
DO_TEST("pool-dir", "vol-luks");
|
2016-06-01 19:21:26 -04:00
|
|
|
DO_TEST("pool-dir", "vol-luks-cipher");
|
2009-10-09 14:17:21 -04:00
|
|
|
DO_TEST("pool-disk", "vol-partition");
|
|
|
|
DO_TEST("pool-logical", "vol-logical");
|
|
|
|
DO_TEST("pool-logical", "vol-logical-backing");
|
2012-07-18 20:06:58 +01:00
|
|
|
DO_TEST("pool-sheepdog", "vol-sheepdog");
|
2013-11-20 13:17:55 -07:00
|
|
|
DO_TEST("pool-gluster", "vol-gluster-dir");
|
2014-12-10 13:54:10 +01:00
|
|
|
DO_TEST("pool-gluster", "vol-gluster-dir-neg-uid");
|
2015-02-17 16:54:53 +01:00
|
|
|
DO_TEST_FULL("pool-dir", "vol-qcow2-nocapacity",
|
|
|
|
VIR_VOL_XML_PARSE_NO_CAPACITY);
|
2009-10-09 14:17:21 -04:00
|
|
|
|
2014-03-17 10:38:38 +01:00
|
|
|
return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
|
2009-10-09 14:17:21 -04:00
|
|
|
}
|
|
|
|
|
2017-03-29 16:45:42 +02:00
|
|
|
VIR_TEST_MAIN(mymain)
|