1
0
mirror of https://gitlab.com/libvirt/libvirt.git synced 2025-01-10 05:17:59 +03:00

storage: expose volume meta-type in XML

I got annoyed at having to use both 'virsh vol-list $pool --details'
AND 'virsh vol-dumpxml $vol $pool' to learn if I had populated
the volume correctly.  Since two-thirds of the data present in
virStorageVolGetInfo() already appears in virStorageVolGetXMLDesc(),
this just adds the remaining piece of information, as:

<volume type='...'>
  ...
</volume>

* docs/formatstorage.html.in: Document new <volume type=...>.
* docs/schemas/storagevol.rng (vol): Add it to RelaxNG.
* src/conf/storage_conf.h (virStorageVolTypeToString): Declare.
* src/conf/storage_conf.c (virStorageVolTargetDefFormat): Output
the metatype.
(virStorageVolDefParseXML): Parse it, for unit tests.
* tests/storagevolxml2xmlout/vol-*.xml: Update tests to match.

Signed-off-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
Eric Blake 2013-11-19 13:14:54 -07:00
parent 4d52b465bd
commit 1b5c8d4cbc
20 changed files with 52 additions and 20 deletions

View File

@ -283,14 +283,18 @@
<h2><a name="StorageVol">Storage volume XML</a></h2> <h2><a name="StorageVol">Storage volume XML</a></h2>
<p> <p>
A storage volume will be either a file or a device node. A storage volume will generally be either a file or a device
The storage volume XML format is available <span class="since">since 0.4.1</span> node; <span class="since">since 1.2.0</span>, an optional
output-only attribute <code>type</code> lists the actual type
(file, block, dir, or network), which is also available
from <code>virStorageVolGetInfo()</code>. The storage volume
XML format is available <span class="since">since 0.4.1</span>
</p> </p>
<h3><a name="StorageVolFirst">General metadata</a></h3> <h3><a name="StorageVolFirst">General metadata</a></h3>
<pre> <pre>
&lt;volume&gt; &lt;volume type='file'&gt;
&lt;name&gt;sparse.img&lt;/name&gt; &lt;name&gt;sparse.img&lt;/name&gt;
&lt;key&gt;/var/lib/xen/images/sparse.img&lt;/key&gt; &lt;key&gt;/var/lib/xen/images/sparse.img&lt;/key&gt;
&lt;allocation&gt;0&lt;/allocation&gt; &lt;allocation&gt;0&lt;/allocation&gt;

View File

@ -13,6 +13,16 @@
<define name='vol'> <define name='vol'>
<element name='volume'> <element name='volume'>
<optional>
<attribute name='type'>
<choice>
<value>file</value>
<value>block</value>
<value>dir</value>
<value>network</value>
</choice>
</attribute>
</optional>
<interleave> <interleave>
<element name='name'> <element name='name'>
<ref name='volName'/> <ref name='volName'/>

View File

@ -51,6 +51,10 @@
#define DEFAULT_POOL_PERM_MODE 0755 #define DEFAULT_POOL_PERM_MODE 0755
#define DEFAULT_VOL_PERM_MODE 0600 #define DEFAULT_VOL_PERM_MODE 0600
VIR_ENUM_IMPL(virStorageVol,
VIR_STORAGE_VOL_LAST,
"file", "block", "dir", "network")
VIR_ENUM_IMPL(virStoragePool, VIR_ENUM_IMPL(virStoragePool,
VIR_STORAGE_POOL_LAST, VIR_STORAGE_POOL_LAST,
"dir", "fs", "netfs", "dir", "fs", "netfs",
@ -1253,6 +1257,7 @@ virStorageVolDefParseXML(virStoragePoolDefPtr pool,
{ {
virStorageVolDefPtr ret; virStorageVolDefPtr ret;
virStorageVolOptionsPtr options; virStorageVolOptionsPtr options;
char *type = NULL;
char *allocation = NULL; char *allocation = NULL;
char *capacity = NULL; char *capacity = NULL;
char *unit = NULL; char *unit = NULL;
@ -1278,6 +1283,16 @@ virStorageVolDefParseXML(virStoragePoolDefPtr pool,
/* Normally generated by pool refresh, but useful for unit tests */ /* Normally generated by pool refresh, but useful for unit tests */
ret->key = virXPathString("string(./key)", ctxt); ret->key = virXPathString("string(./key)", ctxt);
/* Technically overridden by pool refresh, but useful for unit tests */
type = virXPathString("string(./@type)", ctxt);
if (type) {
if ((ret->type = virStorageVolTypeFromString(type)) < 0) {
virReportError(VIR_ERR_XML_ERROR,
_("unknown volume type '%s'"), type);
goto error;
}
}
capacity = virXPathString("string(./capacity)", ctxt); capacity = virXPathString("string(./capacity)", ctxt);
unit = virXPathString("string(./capacity/@unit)", ctxt); unit = virXPathString("string(./capacity/@unit)", ctxt);
if (capacity == NULL) { if (capacity == NULL) {
@ -1394,6 +1409,7 @@ cleanup:
VIR_FREE(allocation); VIR_FREE(allocation);
VIR_FREE(capacity); VIR_FREE(capacity);
VIR_FREE(unit); VIR_FREE(unit);
VIR_FREE(type);
return ret; return ret;
error: error:
@ -1563,7 +1579,8 @@ virStorageVolDefFormat(virStoragePoolDefPtr pool,
if (options == NULL) if (options == NULL)
return NULL; return NULL;
virBufferAddLit(&buf, "<volume>\n"); virBufferAsprintf(&buf, "<volume type='%s'>\n",
virStorageVolTypeToString(def->type));
virBufferEscapeString(&buf, " <name>%s</name>\n", def->name); virBufferEscapeString(&buf, " <name>%s</name>\n", def->name);
virBufferEscapeString(&buf, " <key>%s</key>\n", def->key); virBufferEscapeString(&buf, " <key>%s</key>\n", def->key);
virBufferAddLit(&buf, " <source>\n"); virBufferAddLit(&buf, " <source>\n");

View File

@ -116,6 +116,7 @@ struct _virStorageVolDefList {
virStorageVolDefPtr *objs; virStorageVolDefPtr *objs;
}; };
VIR_ENUM_DECL(virStorageVol)
enum virStoragePoolType { enum virStoragePoolType {
VIR_STORAGE_POOL_DIR, /* Local directory */ VIR_STORAGE_POOL_DIR, /* Local directory */

View File

@ -1,4 +1,4 @@
<volume> <volume type='block'>
<name>Swap</name> <name>Swap</name>
<key>r4xkCv-MQhr-WKIT-R66x-Epn2-e8hG-1Z5gY0</key> <key>r4xkCv-MQhr-WKIT-R66x-Epn2-e8hG-1Z5gY0</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='block'>
<name>Swap</name> <name>Swap</name>
<key>r4xkCv-MQhr-WKIT-R66x-Epn2-e8hG-1Z5gY0</key> <key>r4xkCv-MQhr-WKIT-R66x-Epn2-e8hG-1Z5gY0</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='block'>
<name>sda1</name> <name>sda1</name>
<key>/dev/sda1</key> <key>/dev/sda1</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='network'>
<name>test2</name> <name>test2</name>
<source> <source>
</source> </source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='file'>
<name>sparse.img</name> <name>sparse.img</name>
<key>/var/lib/libvirt/images/sparse.img</key> <key>/var/lib/libvirt/images/sparse.img</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='file'>
<name>&lt;sparse&gt;.img</name> <name>&lt;sparse&gt;.img</name>
<source> <source>
</source> </source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='file'>
<name>sparse.img</name> <name>sparse.img</name>
<source> <source>
</source> </source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='block'>
<name>Swap</name> <name>Swap</name>
<key>r4xkCv-MQhr-WKIT-R66x-Epn2-e8hG-1Z5gY0</key> <key>r4xkCv-MQhr-WKIT-R66x-Epn2-e8hG-1Z5gY0</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='block'>
<name>Swap</name> <name>Swap</name>
<key>r4xkCv-MQhr-WKIT-R66x-Epn2-e8hG-1Z5gY0</key> <key>r4xkCv-MQhr-WKIT-R66x-Epn2-e8hG-1Z5gY0</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='block'>
<name>sda1</name> <name>sda1</name>
<key>/dev/sda1</key> <key>/dev/sda1</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='file'>
<name>OtherDemo.img</name> <name>OtherDemo.img</name>
<key>/var/lib/libvirt/images/OtherDemo.img</key> <key>/var/lib/libvirt/images/OtherDemo.img</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='file'>
<name>OtherDemo.img</name> <name>OtherDemo.img</name>
<key>/var/lib/libvirt/images/OtherDemo.img</key> <key>/var/lib/libvirt/images/OtherDemo.img</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='file'>
<name>OtherDemo.img</name> <name>OtherDemo.img</name>
<key>/var/lib/libvirt/images/OtherDemo.img</key> <key>/var/lib/libvirt/images/OtherDemo.img</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='file'>
<name>OtherDemo.img</name> <name>OtherDemo.img</name>
<key>/var/lib/libvirt/images/OtherDemo.img</key> <key>/var/lib/libvirt/images/OtherDemo.img</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='file'>
<name>OtherDemo.img</name> <name>OtherDemo.img</name>
<key>/var/lib/libvirt/images/OtherDemo.img</key> <key>/var/lib/libvirt/images/OtherDemo.img</key>
<source> <source>

View File

@ -1,4 +1,4 @@
<volume> <volume type='network'>
<name>test2</name> <name>test2</name>
<source> <source>
</source> </source>