From: Juan Quintela <quintela@redhat.com>
To: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
Cc: qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [PATCH 04/27] vmstate: Port versioned tests to new format
Date: Wed, 25 Jun 2014 15:00:49 +0200 [thread overview]
Message-ID: <87a991ywhq.fsf@troll.troll> (raw)
In-Reply-To: <20140617115639.GH2503@work-vm> (David Alan Gilbert's message of "Tue, 17 Jun 2014 12:56:40 +0100")
"Dr. David Alan Gilbert" <dgilbert@redhat.com> wrote:
> * Juan Quintela (quintela@redhat.com) wrote:
>> Signed-off-by: Juan Quintela <quintela@redhat.com>
>> +static void obj_versioned_copy(void *arg1, void *arg2)
>> {
>> - QEMUFile *fsave = open_test_file(true);
>> - uint8_t buf[] = {
>> - 0, 0, 0, 10, /* a */
>> - 0, 0, 0, 30, /* c */
>> - 0, 0, 0, 0, 0, 0, 0, 40, /* d */
>> - QEMU_VM_EOF, /* just to ensure we won't get EOF reported prematurely */
>> - };
>> - qemu_put_buffer(fsave, buf, sizeof(buf));
>> - qemu_fclose(fsave);
>> -
>> - QEMUFile *loading = open_test_file(false);
>> - TestStruct obj = { .b = 200, .e = 500, .f = 600 };
>> - vmstate_load_state(loading, &vmstate_versioned, &obj, 1);
>> - g_assert(!qemu_file_get_error(loading));
>> - g_assert_cmpint(obj.a, ==, 10);
>> - g_assert_cmpint(obj.b, ==, 200);
>> - g_assert_cmpint(obj.c, ==, 30);
>> - g_assert_cmpint(obj.d, ==, 40);
>> - g_assert_cmpint(obj.e, ==, 500);
>> - g_assert_cmpint(obj.f, ==, 600);
>> - qemu_fclose(loading);
>> + TestVersioned *target = arg1;
>> + TestVersioned *source = arg2;
>> +
>> + target->a = source->a;
>> + target->b = source->b;
>> + target->c = source->c;
>> + target->d = source->d;
>> + target->e = source->e;
>> + target->f = source->f;
>> + target->skip_c_e = source->skip_c_e;
>
> Why's that not simply *target = *source?
To be able to only copy some of the fields, depending on what we want to
test O:-)
>> + TestVersioned obj, obj_clone;
>> +
>> + memset(&obj, 0, sizeof(obj));
>> + save_vmstate(&vmstate_simple_versioned, &obj_versioned);
>> +
>> + compare_vmstate(wire_simple_v2, sizeof(wire_simple_v2));
>> +
>> + SUCCESS(load_vmstate(&vmstate_simple_versioned, &obj, &obj_clone,
>> + obj_versioned_copy, 2, wire_simple_v2,
>> + sizeof(wire_simple_v2)));
>> +
>> +#define FIELD_EQUAL(name) g_assert_cmpint(obj.name, ==, obj_versioned.name)
>> +#define FIELD_NOT_EQUAL(name) \
>> + g_assert_cmpint(obj.name, !=, obj_versioned.name)
>
> Given that macro is shared with the next few functions it would be seem
> to declare it outside of the function.
>
It is not always the same (see the whole series otherwise). I ended
finding easier to do it this way. I ended defining it the 1st time that
I needed it. That is coherent with the whole series, but I can change
it (don't really matter).
>> + memset(&obj, 0, sizeof(obj));
>> + obj_versioned.skip_c_e = false;
>> + save_vmstate(&vmstate_simple_skipping, &obj_versioned);
>> +
>> + compare_vmstate(wire_simple_no_skip, sizeof(wire_simple_no_skip));
>> +
>> + /* We abuse the fact that f has a 0x00 value in the right position */
>
> A bit nasty.
Any better ideas?
>> + compare_vmstate(wire_simple_skip, sizeof(wire_simple_skip));
>> +
>> + /* We abuse the fact that f has a 0x00 value in the right position */
>> + SUCCESS(load_vmstate(&vmstate_simple_skipping, &obj, &obj_clone,
>> + obj_versioned_copy, 1, wire_simple_skip,
>> + sizeof(wire_simple_skip) - 8));
>> +
>> + FIELD_EQUAL(skip_c_e);
>> + FIELD_EQUAL(a);
>> + FIELD_EQUAL(b);
>> + FIELD_NOT_EQUAL(c);
>> + FIELD_EQUAL(d);
>> + FIELD_NOT_EQUAL(e);
>> + FIELD_NOT_EQUAL(f);
>> +
>> + SUCCESS(load_vmstate(&vmstate_simple_skipping, &obj, &obj_clone,
>> + obj_versioned_copy, 2, wire_simple_skip,
>> + sizeof(wire_simple_skip)));
>> +
>> + FIELD_EQUAL(skip_c_e);
>> + FIELD_EQUAL(a);
>> + FIELD_EQUAL(b);
>> + FIELD_NOT_EQUAL(c);
>> + FIELD_EQUAL(d);
>> + FIELD_NOT_EQUAL(e);
>> + FIELD_EQUAL(f);
>> }
>
> Couldn't those functions just be merged and take a flag?
>I think it is clear this way, but that is the same to me.
FIELD_EQUAL(a)
FIELD_NOT_EQUAL(a)
vs
COMPARE_FIELD(a, true)
COMPARE_FILED(b, false)
For me, I don't need to go to the definition of the macro in the 1st
case, and I do on the second one.
Or do you mean anything different?
Thanks, Juan.
next prev parent reply other threads:[~2014-06-25 13:01 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-06-16 9:57 [Qemu-devel] [PATCH 00/27] vmstate-simplification queue Juan Quintela
2014-06-16 9:57 ` [Qemu-devel] [PATCH 01/27] migration: Remove unneeded minimum_version_id_old Juan Quintela
2014-06-17 10:44 ` Dr. David Alan Gilbert
2014-06-16 9:57 ` [Qemu-devel] [PATCH 02/27] vmstate: Return error in case of error Juan Quintela
2014-06-17 10:43 ` Dr. David Alan Gilbert
2014-06-16 9:57 ` [Qemu-devel] [PATCH 03/27] vmstate: Refactor & increase tests for primitive types Juan Quintela
2014-06-17 11:34 ` Dr. David Alan Gilbert
2014-06-16 9:58 ` [Qemu-devel] [PATCH 04/27] vmstate: Port versioned tests to new format Juan Quintela
2014-06-17 11:56 ` Dr. David Alan Gilbert
2014-06-25 13:00 ` Juan Quintela [this message]
2014-06-25 13:14 ` Dr. David Alan Gilbert
2014-06-25 13:51 ` Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 05/27] vmstate: Create test functions for versions until 15 Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 06/27] vmstate: Remove VMSTATE_UINTL_EQUAL_V Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 07/27] vmstate: Change VMSTATE_INTTL_V to VMSTATE_INTTL_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 08/27] vmstate: Remove unused VMSTATE_UINTTL_ARRAY_V Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 09/27] vmstate: Test for VMSTATE_BOOL_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 10/27] vmstate: Test for VMSTATE_INT8_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 11/27] vmstate: Test for VMSTATE_INT16_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 12/27] vmstate: Test for VMSTATE_INT32_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 13/27] vmstate: test for VMSTATE_INT64_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 14/27] vmstate: Test for VMSTATE_UINT8_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 15/27] vmstate: Test for VMSTATE_UINT16_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 16/27] vmstate: Test for VMSTATE_UINT32_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 17/27] vmstate: Test for VMSTATE_UINT64_TEST Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 18/27] vmstate: Test for VMSTATE_FLOAT64 Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 19/27] vmstate: Test for VMSTATE_UNUSED Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 20/27] vmstate: Test for VMSTATE_BITMAP Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 21/27] vmstate: Test for VMSTATE_UINT8_EQUAL Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 22/27] vmstate: Test for VMSTATE_UINT16_EQUAL Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 23/27] vmstate: Test for VMSTATE_UINT32_EQUAL Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 24/27] vmstate: Test for VMSTATE_UINT64_EQUAL Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 25/27] vmstate: Test for VMSTATE_INT32_EQUAL Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 26/27] vmstate: Test for VMSTATE_INT32_LE Juan Quintela
2014-06-16 9:58 ` [Qemu-devel] [PATCH 27/27] vmstate: s/VMSTATE_INT32_LE/VMSTATE_INT32_POSITIVE_LE/ Juan Quintela
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87a991ywhq.fsf@troll.troll \
--to=quintela@redhat.com \
--cc=dgilbert@redhat.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.