[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 093/124] vmstate: Test for VMSTATE_BUFFER_TEST
From: |
Juan Quintela |
Subject: |
[Qemu-devel] [PATCH 093/124] vmstate: Test for VMSTATE_BUFFER_TEST |
Date: |
Mon, 21 Apr 2014 16:41:13 +0200 |
Signed-off-by: Juan Quintela <address@hidden>
---
tests/test-vmstate.c | 36 ++++++++++++++++++++++++++++++++++++
1 file changed, 36 insertions(+)
diff --git a/tests/test-vmstate.c b/tests/test-vmstate.c
index 8b114fa..3c4c0f8 100644
--- a/tests/test-vmstate.c
+++ b/tests/test-vmstate.c
@@ -928,6 +928,41 @@ static void test_buffer_simple(void)
SUCCESS(memcmp(obj.middle+6, obj_buffer.middle+6, sizeof(obj.middle)-6));
}
+static const VMStateDescription vmstate_buffer_test = {
+ .name = "buffer/test",
+ .version_id = 1,
+ .minimum_version_id = 1,
+ .minimum_version_id_old = 1,
+ .fields = (VMStateField[]) {
+ VMSTATE_BUFFER_TEST(buffer, TestBuffer, test_true),
+ VMSTATE_BUFFER_TEST(partial, TestBuffer, test_false),
+ VMSTATE_END_OF_LIST()
+ }
+};
+
+uint8_t wire_buffer_test[] = {
+ /* buffer */ 0x68, 0x65, 0x6c, 0x6c, 0x6f, 0x00,
+ QEMU_VM_EOF, /* just to ensure we won't get EOF reported prematurely */
+};
+
+static void test_buffer_test(void)
+{
+ TestBuffer obj, obj_clone;
+
+ memset(&obj, 0, sizeof(obj));
+
+ save_vmstate(&vmstate_buffer_test, &obj_buffer);
+
+ compare_vmstate(wire_buffer_test, sizeof(wire_buffer_test));
+
+ SUCCESS(load_vmstate(&vmstate_buffer_test, &obj, &obj_clone,
+ obj_buffer_copy, 1, wire_buffer_test,
+ sizeof(wire_buffer_test)));
+
+ SUCCESS(memcmp(obj.buffer, obj_buffer.buffer, sizeof(obj.buffer)));
+ FAILURE(memcmp(obj.partial, obj_buffer.partial, sizeof(obj.partial)));
+}
+
typedef struct TestVersioned {
uint32_t a, b, c, e;
uint64_t d, f;
@@ -1165,6 +1200,7 @@ int main(int argc, char **argv)
g_test_add_func("/vmstate/array/test", test_array_test);
g_test_add_func("/vmstate/array/sub", test_array_sub);
g_test_add_func("/vmstate/buffer/simple", test_buffer_simple);
+ g_test_add_func("/vmstate/buffer/test", test_buffer_test);
g_test_run();
close(temp_fd);
--
1.9.0
- [Qemu-devel] [PATCH 082/124] vmstate: Create VMSTATE_VARRAY macro, (continued)
- [Qemu-devel] [PATCH 082/124] vmstate: Create VMSTATE_VARRAY macro, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 083/124] vmstate: Create VMSTATE_POINTER_UNSAFE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 084/124] vmstate: Create VMSTATE_OPENCODED_UNSAFE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 085/124] vmstate: Create VMSTATE_SYNTHETIC, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 086/124] vmstate: version_id is gone from fields, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 087/124] vmstate: Test for VMSTATE_SYNTHETIC, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 089/124] vmstate: Test for VMSTATE_UINT32_SUB_ARRAY, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 090/124] vmstate: Test for VMSTATE_BUFFER, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 088/124] vmstate: Test for VMSTATE_UINT8_SUB_ARRAY, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 091/124] vmstate: Test for VMSTATE_PARTIAL_BUFFER, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 093/124] vmstate: Test for VMSTATE_BUFFER_TEST,
Juan Quintela <=
- [Qemu-devel] [PATCH 094/124] vmstate: Use VMSTATE_UINT8_2DARRAY instead of VMSTATE_BUFFER_TEST, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 092/124] vmstate: Test for VMSTATE_BUFFER_START_MIDDLE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 095/124] vmstate: Test for VMSTATE_BUFFER_UNSAFE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 096/124] vmstate: Remove unused VMSTATE_SUB_VBUFFER, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 097/124] vmstate: Remove unused VMSTATE_PARTIAL_VBUFFER_UINT32, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 099/124] vmstate: Rename VMSTATE_PARTIAL_VBUFFER to VMSTATE_VBUFFER_INT32, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 098/124] vmstate: Test for VMSTATE_PARTIAL_VBUFFER, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 100/124] vmstate: Create VMS_VBUFFER_UINT32, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 101/124] vmstate: Rename VMS_VBUFFER to VMST_VBUFFER_INT32 for consintency, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 102/124] vmstate: Test for VMSTATE_VBUFFER_UINT32, Juan Quintela, 2014/04/21