Add versionsort test
authorGreg V <greg@unrelenting.technology>
Wed, 18 Jul 2018 18:37:25 +0000 (21:37 +0300)
committerGreg V <greg@unrelenting.technology>
Thu, 19 Jul 2018 19:29:00 +0000 (22:29 +0300)
And make local versionsort testable even when the native one is present.

src/libinput-versionsort.h
test/test-misc.c

index 356ec8da2f56ccedefb4f30cbeb353a1140e175a..62fc31ae338bef19f999d32aecfff326a4247703 100644 (file)
@@ -1,9 +1,5 @@
 #pragma once
 
-#include "config.h"
-
-#ifndef HAVE_VERSIONSORT
-
 /* Copyright © 2005-2014 Rich Felker, et al.
  *
  * Permission is hereby granted, free of charge, to any person obtaining
  * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  */
 
+#include "config.h"
+
 #include <ctype.h>
 #include <string.h>
 #include <dirent.h>
 
+#if !defined(HAVE_VERSIONSORT) || defined(TEST_VERSIONSORT)
 static int
-strverscmp(const char *l0, const char *r0)
+libinput_strverscmp(const char *l0, const char *r0)
 {
        const unsigned char *l = (const void *)l0;
        const unsigned char *r = (const void *)r0;
@@ -61,11 +60,20 @@ strverscmp(const char *l0, const char *r0)
 
        return l[i] - r[i];
 }
+#endif
+
+/* Defined with libinput_ names for testing from platforms with native functions. */
+
+#ifndef HAVE_VERSIONSORT
+static int
+strverscmp(const char *l0, const char *r0)
+{
+       return libinput_strverscmp(l0, r0);
+}
 
 static int
 versionsort(const struct dirent **a, const struct dirent **b)
 {
-       return strverscmp((*a)->d_name, (*b)->d_name);
+       return libinput_strverscmp((*a)->d_name, (*b)->d_name);
 }
-
 #endif
index 93d20812b3571b75ce9cc78b11cd9cc8632d8dc0..2257156902887e23f026c168c958b3430ba9a9c8 100644 (file)
@@ -33,6 +33,8 @@
 
 #include "litest.h"
 #include "libinput-util.h"
+#define  TEST_VERSIONSORT
+#include "libinput-versionsort.h"
 
 static int open_restricted(const char *path, int flags, void *data)
 {
@@ -1756,6 +1758,21 @@ START_TEST(list_test_append)
 }
 END_TEST
 
+START_TEST(strverscmp_test)
+{
+       ck_assert_int_eq(libinput_strverscmp("", ""), 0);
+       ck_assert_int_gt(libinput_strverscmp("0.0.1", ""), 0);
+       ck_assert_int_lt(libinput_strverscmp("", "0.0.1"), 0);
+       ck_assert_int_eq(libinput_strverscmp("0.0.1", "0.0.1"), 0);
+       ck_assert_int_eq(libinput_strverscmp("0.0.1", "0.0.2"), -1);
+       ck_assert_int_eq(libinput_strverscmp("0.0.2", "0.0.1"), 1);
+       ck_assert_int_eq(libinput_strverscmp("0.0.1", "0.1.0"), -1);
+       ck_assert_int_eq(libinput_strverscmp("0.1.0", "0.0.1"), 1);
+}
+END_TEST
+
+
+
 TEST_COLLECTION(misc)
 {
        litest_add_no_device("events:conversion", event_conversion_device_notify);
@@ -1805,4 +1822,5 @@ TEST_COLLECTION(misc)
 
        litest_add_deviceless("misc:list", list_test_insert);
        litest_add_deviceless("misc:list", list_test_append);
+       litest_add_deviceless("misc:versionsort", strverscmp_test);
 }