mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-25 10:03:49 +03:00
storage: Add new events for *PoolBuild() and *PoolDelete().
This commit adds new events for two methods and operations: *PoolBuild() and *PoolDelete(). Using the event-test and the commands set below we have the following outputs: $ sudo ./event-test Registering event callbacks myStoragePoolEventCallback EVENT: Storage pool test Defined 0 myStoragePoolEventCallback EVENT: Storage pool test Created 0 myStoragePoolEventCallback EVENT: Storage pool test Started 0 myStoragePoolEventCallback EVENT: Storage pool test Stopped 0 myStoragePoolEventCallback EVENT: Storage pool test Deleted 0 myStoragePoolEventCallback EVENT: Storage pool test Undefined 0 Another terminal: $ sudo virsh pool-define test.xml Pool test defined from test.xml $ sudo virsh pool-build test Pool test built $ sudo virsh pool-start test Pool test started $ sudo virsh pool-destroy test Pool test destroyed $ sudo virsh pool-delete test Pool test deleted $ sudo virsh pool-undefine test Pool test has been undefined This commits can be a solution for RHBZ #1475227. Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1475227 Signed-off-by: Julio Faracco <jcfaracco@gmail.com> Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
0dde16be73
commit
b06521928c
@ -356,6 +356,10 @@ storagePoolEventToString(int event)
|
|||||||
return "Started";
|
return "Started";
|
||||||
case VIR_STORAGE_POOL_EVENT_STOPPED:
|
case VIR_STORAGE_POOL_EVENT_STOPPED:
|
||||||
return "Stopped";
|
return "Stopped";
|
||||||
|
case VIR_STORAGE_POOL_EVENT_CREATED:
|
||||||
|
return "Created";
|
||||||
|
case VIR_STORAGE_POOL_EVENT_DELETED:
|
||||||
|
return "Deleted";
|
||||||
case VIR_STORAGE_POOL_EVENT_LAST:
|
case VIR_STORAGE_POOL_EVENT_LAST:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -465,6 +465,8 @@ typedef enum {
|
|||||||
VIR_STORAGE_POOL_EVENT_UNDEFINED = 1,
|
VIR_STORAGE_POOL_EVENT_UNDEFINED = 1,
|
||||||
VIR_STORAGE_POOL_EVENT_STARTED = 2,
|
VIR_STORAGE_POOL_EVENT_STARTED = 2,
|
||||||
VIR_STORAGE_POOL_EVENT_STOPPED = 3,
|
VIR_STORAGE_POOL_EVENT_STOPPED = 3,
|
||||||
|
VIR_STORAGE_POOL_EVENT_CREATED = 4,
|
||||||
|
VIR_STORAGE_POOL_EVENT_DELETED = 5,
|
||||||
|
|
||||||
# ifdef VIR_ENUM_SENTINELS
|
# ifdef VIR_ENUM_SENTINELS
|
||||||
VIR_STORAGE_POOL_EVENT_LAST
|
VIR_STORAGE_POOL_EVENT_LAST
|
||||||
|
@ -956,6 +956,7 @@ storagePoolBuild(virStoragePoolPtr pool,
|
|||||||
{
|
{
|
||||||
virStoragePoolObjPtr obj;
|
virStoragePoolObjPtr obj;
|
||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
|
virObjectEventPtr event = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
if (!(obj = virStoragePoolObjFromStoragePool(pool)))
|
if (!(obj = virStoragePoolObjFromStoragePool(pool)))
|
||||||
@ -977,9 +978,17 @@ storagePoolBuild(virStoragePoolPtr pool,
|
|||||||
if (backend->buildPool &&
|
if (backend->buildPool &&
|
||||||
backend->buildPool(pool->conn, obj, flags) < 0)
|
backend->buildPool(pool->conn, obj, flags) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
|
event = virStoragePoolEventLifecycleNew(obj->def->name,
|
||||||
|
obj->def->uuid,
|
||||||
|
VIR_STORAGE_POOL_EVENT_CREATED,
|
||||||
|
0);
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (event)
|
||||||
|
virObjectEventStateQueue(driver->storageEventState, event);
|
||||||
virStoragePoolObjUnlock(obj);
|
virStoragePoolObjUnlock(obj);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -1059,6 +1068,7 @@ storagePoolDelete(virStoragePoolPtr pool,
|
|||||||
{
|
{
|
||||||
virStoragePoolObjPtr obj;
|
virStoragePoolObjPtr obj;
|
||||||
virStorageBackendPtr backend;
|
virStorageBackendPtr backend;
|
||||||
|
virObjectEventPtr event = NULL;
|
||||||
char *stateFile = NULL;
|
char *stateFile = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
@ -1103,9 +1113,16 @@ storagePoolDelete(virStoragePoolPtr pool,
|
|||||||
if (backend->deletePool(pool->conn, obj, flags) < 0)
|
if (backend->deletePool(pool->conn, obj, flags) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
|
event = virStoragePoolEventLifecycleNew(obj->def->name,
|
||||||
|
obj->def->uuid,
|
||||||
|
VIR_STORAGE_POOL_EVENT_DELETED,
|
||||||
|
0);
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
if (event)
|
||||||
|
virObjectEventStateQueue(driver->storageEventState, event);
|
||||||
virStoragePoolObjUnlock(obj);
|
virStoragePoolObjUnlock(obj);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -4584,13 +4584,20 @@ testStoragePoolBuild(virStoragePoolPtr pool,
|
|||||||
{
|
{
|
||||||
testDriverPtr privconn = pool->conn->privateData;
|
testDriverPtr privconn = pool->conn->privateData;
|
||||||
virStoragePoolObjPtr obj;
|
virStoragePoolObjPtr obj;
|
||||||
|
virObjectEventPtr event = NULL;
|
||||||
|
|
||||||
virCheckFlags(0, -1);
|
virCheckFlags(0, -1);
|
||||||
|
|
||||||
if (!(obj = testStoragePoolObjFindInactiveByName(privconn, pool->name)))
|
if (!(obj = testStoragePoolObjFindInactiveByName(privconn, pool->name)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
event = virStoragePoolEventLifecycleNew(pool->name, pool->uuid,
|
||||||
|
VIR_STORAGE_POOL_EVENT_CREATED,
|
||||||
|
0);
|
||||||
|
|
||||||
virStoragePoolObjUnlock(obj);
|
virStoragePoolObjUnlock(obj);
|
||||||
|
|
||||||
|
testObjectEventQueue(privconn, event);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4675,12 +4682,19 @@ testStoragePoolDelete(virStoragePoolPtr pool,
|
|||||||
{
|
{
|
||||||
testDriverPtr privconn = pool->conn->privateData;
|
testDriverPtr privconn = pool->conn->privateData;
|
||||||
virStoragePoolObjPtr obj;
|
virStoragePoolObjPtr obj;
|
||||||
|
virObjectEventPtr event = NULL;
|
||||||
|
|
||||||
virCheckFlags(0, -1);
|
virCheckFlags(0, -1);
|
||||||
|
|
||||||
if (!(obj = testStoragePoolObjFindInactiveByName(privconn, pool->name)))
|
if (!(obj = testStoragePoolObjFindInactiveByName(privconn, pool->name)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
event = virStoragePoolEventLifecycleNew(pool->name, pool->uuid,
|
||||||
|
VIR_STORAGE_POOL_EVENT_DELETED,
|
||||||
|
0);
|
||||||
|
|
||||||
|
testObjectEventQueue(privconn, event);
|
||||||
|
|
||||||
virStoragePoolObjUnlock(obj);
|
virStoragePoolObjUnlock(obj);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -167,6 +167,10 @@ storagePoolLifecycleCb(virConnectPtr conn ATTRIBUTE_UNUSED,
|
|||||||
counter->defineEvents++;
|
counter->defineEvents++;
|
||||||
else if (event == VIR_STORAGE_POOL_EVENT_UNDEFINED)
|
else if (event == VIR_STORAGE_POOL_EVENT_UNDEFINED)
|
||||||
counter->undefineEvents++;
|
counter->undefineEvents++;
|
||||||
|
else if (event == VIR_STORAGE_POOL_EVENT_CREATED)
|
||||||
|
counter->createdEvents++;
|
||||||
|
else if (event == VIR_STORAGE_POOL_EVENT_DELETED)
|
||||||
|
counter->deletedEvents++;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -722,6 +726,69 @@ testStoragePoolStartStopEvent(const void *data)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
testStoragePoolBuild(const void *data)
|
||||||
|
{
|
||||||
|
const objecteventTest *test = data;
|
||||||
|
lifecycleEventCounter counter;
|
||||||
|
int id;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
lifecycleEventCounter_reset(&counter);
|
||||||
|
|
||||||
|
id = virConnectStoragePoolEventRegisterAny(test->conn, NULL,
|
||||||
|
VIR_STORAGE_POOL_EVENT_ID_LIFECYCLE,
|
||||||
|
VIR_STORAGE_POOL_EVENT_CALLBACK(&storagePoolLifecycleCb),
|
||||||
|
&counter, NULL);
|
||||||
|
|
||||||
|
virStoragePoolBuild(test->pool, 0);
|
||||||
|
|
||||||
|
if (virEventRunDefaultImpl() < 0) {
|
||||||
|
ret = -1;
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (counter.createdEvents != 1) {
|
||||||
|
ret = -1;
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
virConnectStoragePoolEventDeregisterAny(test->conn, id);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
testStoragePoolDelete(const void *data)
|
||||||
|
{
|
||||||
|
const objecteventTest *test = data;
|
||||||
|
lifecycleEventCounter counter;
|
||||||
|
int id;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
lifecycleEventCounter_reset(&counter);
|
||||||
|
|
||||||
|
id = virConnectStoragePoolEventRegisterAny(test->conn, NULL,
|
||||||
|
VIR_STORAGE_POOL_EVENT_ID_LIFECYCLE,
|
||||||
|
VIR_STORAGE_POOL_EVENT_CALLBACK(&storagePoolLifecycleCb),
|
||||||
|
&counter, NULL);
|
||||||
|
|
||||||
|
virStoragePoolDelete(test->pool, 0);
|
||||||
|
|
||||||
|
if (virEventRunDefaultImpl() < 0) {
|
||||||
|
ret = -1;
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (counter.deletedEvents != 1) {
|
||||||
|
ret = -1;
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
virConnectStoragePoolEventDeregisterAny(test->conn, id);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
static int
|
static int
|
||||||
testNodeDeviceCreateXML(const void *data)
|
testNodeDeviceCreateXML(const void *data)
|
||||||
{
|
{
|
||||||
@ -831,6 +898,13 @@ mymain(void)
|
|||||||
if (virTestRun("Storage pool start stop events ",
|
if (virTestRun("Storage pool start stop events ",
|
||||||
testStoragePoolStartStopEvent, &test) < 0)
|
testStoragePoolStartStopEvent, &test) < 0)
|
||||||
ret = EXIT_FAILURE;
|
ret = EXIT_FAILURE;
|
||||||
|
/* Storage pool build and delete events */
|
||||||
|
if (virTestRun("Storage pool build event ",
|
||||||
|
testStoragePoolBuild, &test) < 0)
|
||||||
|
ret = EXIT_FAILURE;
|
||||||
|
if (virTestRun("Storage pool delete event ",
|
||||||
|
testStoragePoolDelete, &test) < 0)
|
||||||
|
ret = EXIT_FAILURE;
|
||||||
|
|
||||||
/* Node device event tests */
|
/* Node device event tests */
|
||||||
if (virTestRun("Node device createXML add event ",
|
if (virTestRun("Node device createXML add event ",
|
||||||
|
@ -1952,7 +1952,9 @@ VIR_ENUM_IMPL(virshPoolEvent,
|
|||||||
N_("Defined"),
|
N_("Defined"),
|
||||||
N_("Undefined"),
|
N_("Undefined"),
|
||||||
N_("Started"),
|
N_("Started"),
|
||||||
N_("Stopped"))
|
N_("Stopped"),
|
||||||
|
N_("Created"),
|
||||||
|
N_("Deleted"))
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
virshPoolEventToString(int event)
|
virshPoolEventToString(int event)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user