summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorWerner Koch <wk@gnupg.org>2018-11-15 19:18:53 +0100
committerWerner Koch <wk@gnupg.org>2018-11-15 19:28:20 +0100
commita5d4a4b32b11814d673241d62624ecec1d577571 (patch)
treef276ffcc2ae1522ee83666dc6da4774bb602a26e /tests
parent4a92763a6e529824f1c6043b75ac1346af41a926 (diff)
downloadlibgpg-error-a5d4a4b32b11814d673241d62624ecec1d577571.tar.gz
core: New API gpgrt_cmp_version
* src/gpg-error.h.in: New API gpgrt_cmp_version. * src/visibility.c (gpgrt_cmp_version): New wrapper. * src/version.c (parse_version_string): Revamped. (do_cmp_version): New. (_gpgrt_cmp_version): New. (_gpg_error_check_version): Re-implemented using the new func. * tests/t-version.c: Include t-common.h. (t_gpgrt_cmp_version): New test. (main): Run new test. Change test for new version number to require a 2 level number. -- We have implementations of very similar functions in all out libs. Thus it makes sense to provide a generic version. This version is actually derived from the ftp-indexer.c we use for the gnupg website (see the gnupg-doc repo). Signed-off-by: Werner Koch <wk@gnupg.org>
Diffstat (limited to 'tests')
-rw-r--r--tests/t-version.c93
1 files changed, 86 insertions, 7 deletions
diff --git a/tests/t-version.c b/tests/t-version.c
index 4606dbc..240d4b4 100644
--- a/tests/t-version.c
+++ b/tests/t-version.c
@@ -26,12 +26,90 @@
#include <string.h>
#include <assert.h>
-#include "../src/gpg-error.h"
+#define PGM "t-version"
+#include "t-common.h"
+
+static const char *logpfx = PGM;
+
+
+static void
+t_gpgrt_cmp_version (void)
+{
+ struct { int result; int level; const char *a; const char *b; } t[] = {
+ { 0, 1, "0", "0" },
+ { -1, 1, "0", "1" },
+ { 1, 1, "1", "0" },
+ { -1, 1, "0.0", "0.1" },
+ { -1, 1, "0.1", "1.2" },
+ { 1, 1, "1.0", "0.9" },
+ { -1, 1, "-1.0", "0.9" }, /* A is invalid */
+ { 0, 1, "0rc0", "0rc0" },
+ { 1, 1, "0rc1", "0rc0" },
+ { -1, 1, "0rc1", "0rc2" },
+ { 0, 1, "0.rc0", "0.rc0" },
+ { 1, 1, "0.rc1", "0.rc0" },
+ { -1, 1, "0.rc1", "0.rc2" },
+ { 0, 1, "0.rc1", "0.rc1" },
+ { -1, 1, "0qc1", "0rc0" },
+ { -1, 1, "0.qc1", "0.rc0" },
+ { 0, 2, "0.0", "0.0" },
+ { -1, 2, "0.1", "0.2" },
+ { -1, 2, "3.1", "3.2" },
+ { -1, 2, "3.1", "4.0" },
+ { 0, 2, "1.1rc0", "1.1rc0" },
+ { 1, 2, "1.1rc1", "1.1rc0" },
+ { -1, 2, "1.1rc0", "1.1rc1" },
+ { 0, 3, "7.0.0", "7.0.0" },
+ { -1, 3, "7.0.1", "7.0.2" },
+ { -1, 3, "7.3.1", "7.3.2" },
+ { -1, 3, "7.3.1", "7.4.0" },
+ { 0, 3, "7.1.1rc0", "7.1.1rc0" },
+ { 1, 3, "7.1.1rc1", "7.1.1rc0" },
+ { -1, 3, "7.1.1rc0", "7.1.1rc1" },
+ { 1, 3, "6.0.0", "5.0.0" },
+ { 0, 3, "6.0.0", "6.0.0" },
+ { 1, 3, "6.0.1", "6.0.0" },
+ { 1, 3, "6.1.0", "6.0.0" },
+ { 1, 3, "6.2.1", "6.2.0" },
+ { -1, 3, "6.2.1", "6.2.2" },
+ { -1, 3, "6.0.0", "6.0.2" },
+ { -1, 3, "6.0.0", "6.1.0" },
+ { -1, 3, "6.2.0", "6.2.1" },
+ { 1, 3, "6.0.0-beta1", "6.0.0-beta0" },
+ { 0, 3, "6.0.0-beta2", "6.0.0-beta2" },
+ { 1, 3, "6.0.0-beta20", "6.0.0-beta19" },
+ { -1, 3, "6.0.0-beta1", "6.0.0-beta2" },
+ { 1, 3, "6.0.0-beta2", "6.0.0-beta1" },
+ { -1, 3, "6.0.0-beta20", "6.0.0-beta21" },
+ { 0,13, "6.0.0-beta1", "6.0.0-beta0" },
+ { 0,13, "6.0.0-beta2", "6.0.0-beta2" },
+ { 0,13, "6.0.0-beta20", "6.0.0-beta19" },
+ { 0,13, "6.0.0-beta1", "6.0.0-beta2" },
+ { 0,13, "6.0.0-beta2", "6.0.0-beta1" },
+ { 0,13, "6.0.0-beta20", "6.0.0-beta21" }
+ };
+ int i;
+ int result, expected;
+
+ for (i=0; i < DIM (t); i++)
+ {
+ expected = t[i].result;
+ result = gpgrt_cmp_version (t[i].a, t[i].b, t[i].level);
+ if (result != expected)
+ fail ("test %d failed: cmp('%s','%s',%d) = %d expected %d",
+ i, t[i].a, t[i].b, t[i].level, result, expected);
+ }
+ for (i=0; i < DIM (t); i++)
+ {
+ expected = 0 - t[i].result;
+ result = gpgrt_cmp_version (t[i].a, t[i].b, -t[i].level);
+ if (result != expected)
+ fail ("test %d-rev failed: cmp('%s','%s',%d) = %d expected %d",
+ i, t[i].a, t[i].b, -t[i].level, result, expected);
+ }
+}
+
-static const char *logpfx = "";
-static int verbose;
-static int debug;
-static int errorcount;
int
main (int argc, char **argv)
@@ -40,7 +118,6 @@ main (int argc, char **argv)
if (argc)
{
- logpfx = *argv;
argc--; argv++;
}
while (argc && last_argc != argc )
@@ -68,6 +145,8 @@ main (int argc, char **argv)
}
}
+ t_gpgrt_cmp_version ();
+
if (!gpg_error_check_version (GPG_ERROR_VERSION))
{
fprintf (stderr, "%s: gpg_error_check_version returned an error\n",
@@ -80,7 +159,7 @@ main (int argc, char **argv)
"error for an old version\n", logpfx);
errorcount++;
}
- if (gpg_error_check_version ("15"))
+ if (gpg_error_check_version ("15.0"))
{
fprintf (stderr, "%s: gpg_error_check_version did not return an error"
" for a newer version\n", logpfx);