X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=tests%2Ftest-fstrcmp.c;h=b266b59460453489051c7f9be2c13855e9e29121;hb=a9bf022b6d70c5f3a55cf5b2a2b36a4a3f96da6c;hp=1e58ece0c50d6c26d8c3482d08189709fbe097cc;hpb=57fdfd3f8ec62b105c53bcdf6f127c35c7fe7391;p=gnulib.git diff --git a/tests/test-fstrcmp.c b/tests/test-fstrcmp.c index 1e58ece0c..b266b5946 100644 --- a/tests/test-fstrcmp.c +++ b/tests/test-fstrcmp.c @@ -1,5 +1,5 @@ /* Test of fuzzy string comparison. - Copyright (C) 2007 Free Software Foundation, Inc. + Copyright (C) 2007-2008 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -30,6 +30,7 @@ if (!(expr)) \ { \ fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \ + fflush (stderr); \ abort (); \ } \ } \ @@ -44,8 +45,33 @@ check_fstrcmp (const char *string1, const char *string2, double expected) compliant by default, to avoid that msgmerge results become platform and compiler option dependent. 'volatile' is a portable alternative to gcc's -ffloat-store option. */ - volatile double result = fstrcmp (string1, string2); - return (result == expected); + { + volatile double result = fstrcmp (string1, string2); + if (!(result == expected)) + return false; + } + { + volatile double result = fstrcmp_bounded (string1, string2, expected); + if (!(result == expected)) + return false; + } + { + double bound = expected * 0.5; /* implies bound <= expected */ + volatile double result = fstrcmp_bounded (string1, string2, bound); + if (!(result == expected)) + return false; + } + { + double bound = (1 + expected) * 0.5; + if (expected < bound) + { + volatile double result = fstrcmp_bounded (string1, string2, bound); + if (!(result < bound)) + return false; + } + } + + return true; } int