[ovs-dev] [PATCH] test-lockfile: Provide better diagnostics on failure.
Ben Pfaff
blp at nicira.com
Wed Oct 19 16:47:06 UTC 2011
Thank you. I pushed this.
On Tue, Oct 18, 2011 at 11:47:10PM -0700, Justin Pettit wrote:
> Looks good. Sorry for the delay.
>
> --Justin
>
>
> On Sep 29, 2011, at 10:40 AM, Ben Pfaff wrote:
>
> > We spotted one failure of the "lock_timeout_runs_out" test several builds
> > ago, but there weren't enough diagnostics to track it down and I couldn't
> > reproduce it.
> >
> > This commit should make the failure easier to understand if it recurs.
> >
> > CC: Michael Hu <mhu at nicira.com>
> > ---
> > tests/test-lockfile.c | 69 +++++++++++++++++++++++++++---------------------
> > 1 files changed, 39 insertions(+), 30 deletions(-)
> >
> > diff --git a/tests/test-lockfile.c b/tests/test-lockfile.c
> > index 121b2ba..a9ac17f 100644
> > --- a/tests/test-lockfile.c
> > +++ b/tests/test-lockfile.c
> > @@ -28,9 +28,6 @@
> > #include "util.h"
> > #include "vlog.h"
> >
> > -#undef NDEBUG
> > -#include <assert.h>
> > -
> > struct test {
> > const char *name;
> > void (*function)(void);
> > @@ -38,12 +35,25 @@ struct test {
> >
> > static const struct test tests[];
> >
> > +#define CHECK(A, B) check(A, B, #A, #B, __FILE__, __LINE__)
> > +static void
> > +check(int a, int b,
> > + const char *a_string, const char *b_string, const char *file, int line)
> > +{
> > + if (a != b) {
> > + fprintf(stderr, "%s:%d: expected %s == %s but %d != %d\n",
> > + file, line, a_string, b_string, a, b);
> > + fflush(stderr);
> > + abort();
> > + }
> > +}
> > +
> > static void
> > run_lock_and_unlock(void)
> > {
> > struct lockfile *lockfile;
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> > lockfile_unlock(lockfile);
> > }
> >
> > @@ -52,10 +62,10 @@ run_lock_and_unlock_twice(void)
> > {
> > struct lockfile *lockfile;
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> > lockfile_unlock(lockfile);
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> > lockfile_unlock(lockfile);
> > }
> >
> > @@ -64,8 +74,8 @@ run_lock_blocks_same_process(void)
> > {
> > struct lockfile *lockfile;
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > - assert(lockfile_lock("file", 0, &lockfile) == EDEADLK);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), EDEADLK);
> > lockfile_unlock(lockfile);
> > }
> >
> > @@ -74,9 +84,9 @@ run_lock_blocks_same_process_twice(void)
> > {
> > struct lockfile *lockfile;
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > - assert(lockfile_lock("file", 0, &lockfile) == EDEADLK);
> > - assert(lockfile_lock("file", 0, &lockfile) == EDEADLK);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), EDEADLK);
> > + CHECK(lockfile_lock("file", 0, &lockfile), EDEADLK);
> > lockfile_unlock(lockfile);
> > }
> >
> > @@ -107,10 +117,10 @@ run_lock_blocks_other_process(void)
> > * this function that does the wait() call. */
> > static struct lockfile *lockfile;
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> > if (do_fork() == CHILD) {
> > lockfile_unlock(lockfile);
> > - assert(lockfile_lock("file", 0, &lockfile) == EAGAIN);
> > + CHECK(lockfile_lock("file", 0, &lockfile), EAGAIN);
> > exit(11);
> > }
> > }
> > @@ -120,10 +130,10 @@ run_lock_twice_blocks_other_process(void)
> > {
> > struct lockfile *lockfile, *dummy;
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > - assert(lockfile_lock("file", 0, &dummy) == EDEADLK);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> > + CHECK(lockfile_lock("file", 0, &dummy), EDEADLK);
> > if (do_fork() == CHILD) {
> > - assert(lockfile_lock("file", 0, &dummy) == EAGAIN);
> > + CHECK(lockfile_lock("file", 0, &dummy), EAGAIN);
> > exit(11);
> > }
> > }
> > @@ -133,11 +143,11 @@ run_lock_and_unlock_allows_other_process(void)
> > {
> > struct lockfile *lockfile;
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> > lockfile_unlock(lockfile);
> >
> > if (do_fork() == CHILD) {
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> > exit(11);
> > }
> > }
> > @@ -147,12 +157,11 @@ run_lock_timeout_gets_the_lock(void)
> > {
> > struct lockfile *lockfile;
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> >
> > if (do_fork() == CHILD) {
> > lockfile_unlock(lockfile);
> > - assert(lockfile_lock("file", TIME_UPDATE_INTERVAL * 3,
> > - &lockfile) == 0);
> > + CHECK(lockfile_lock("file", TIME_UPDATE_INTERVAL * 3, &lockfile), 0);
> > exit(11);
> > } else {
> > long long int now = time_msec();
> > @@ -168,12 +177,12 @@ run_lock_timeout_runs_out(void)
> > {
> > struct lockfile *lockfile;
> >
> > - assert(lockfile_lock("file", 0, &lockfile) == 0);
> > + CHECK(lockfile_lock("file", 0, &lockfile), 0);
> >
> > if (do_fork() == CHILD) {
> > lockfile_unlock(lockfile);
> > - assert(lockfile_lock("file", TIME_UPDATE_INTERVAL,
> > - &lockfile) == ETIMEDOUT);
> > + CHECK(lockfile_lock("file", TIME_UPDATE_INTERVAL, &lockfile),
> > + ETIMEDOUT);
> > exit(11);
> > } else {
> > long long int now = time_msec();
> > @@ -189,17 +198,17 @@ run_lock_multiple(void)
> > {
> > struct lockfile *a, *b, *c, *dummy;
> >
> > - assert(lockfile_lock("a", 0, &a) == 0);
> > - assert(lockfile_lock("b", 0, &b) == 0);
> > - assert(lockfile_lock("c", 0, &c) == 0);
> > + CHECK(lockfile_lock("a", 0, &a), 0);
> > + CHECK(lockfile_lock("b", 0, &b), 0);
> > + CHECK(lockfile_lock("c", 0, &c), 0);
> >
> > lockfile_unlock(a);
> > - assert(lockfile_lock("a", 0, &a) == 0);
> > - assert(lockfile_lock("a", 0, &dummy) == EDEADLK);
> > + CHECK(lockfile_lock("a", 0, &a), 0);
> > + CHECK(lockfile_lock("a", 0, &dummy), EDEADLK);
> > lockfile_unlock(a);
> >
> > lockfile_unlock(b);
> > - assert(lockfile_lock("a", 0, &a) == 0);
> > + CHECK(lockfile_lock("a", 0, &a), 0);
> >
> > lockfile_unlock(c);
> > lockfile_unlock(a);
> > --
> > 1.7.4.4
> >
> > _______________________________________________
> > dev mailing list
> > dev at openvswitch.org
> > http://openvswitch.org/mailman/listinfo/dev
>
More information about the dev
mailing list