Signed-off-by: Juan Quintela <quint...@redhat.com> --- 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