Whamcloud - gitweb
AOSP: Android: stop suppressing warnings controlled by -Wall
[tools/e2fsprogs.git] / lib / uuid / tst_uuid.c
index b9fc5f6..c1c2901 100644 (file)
@@ -4,23 +4,71 @@
  * Copyright (C) 1996, 1997, 1998 Theodore Ts'o.
  *
  * %Begin-Header%
- * This file may be redistributed under the terms of the GNU Public
- * License.
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, and the entire permission notice in its entirety,
+ *    including the disclaimer of warranties.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. The name of the author may not be used to endorse or promote
+ *    products derived from this software without specific prior
+ *    written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ALL OF
+ * WHICH ARE HEREBY DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
+ * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
+ * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
+ * USE OF THIS SOFTWARE, EVEN IF NOT ADVISED OF THE POSSIBILITY OF SUCH
+ * DAMAGE.
  * %End-Header%
  */
 
+#include "config.h"
+
 #include <stdio.h>
-#include <linux/ext2_fs.h>
+#include <stdlib.h>
 
-#include "uuid.h"
+#include <uuid/uuid.h>
+
+static int test_uuid(const char * uuid, int isValid)
+{
+       static const char * validStr[2] = {"invalid", "valid"};
+       uuid_t uuidBits;
+       int parsedOk;
+
+       parsedOk = uuid_parse(uuid, uuidBits) == 0;
+
+       printf("%s is %s", uuid, validStr[isValid]);
+       if (parsedOk != isValid) {
+               printf(" but uuid_parse says %s\n", validStr[parsedOk]);
+               return 1;
+       }
+       printf(", OK\n");
+       return 0;
+}
+
+#ifdef __GNUC__
+#define ATTR(x) __attribute__(x)
+#else
+#define ATTR(x)
+#endif
 
 int
-main(int argc, char **argv)
+main(int argc ATTR((unused)) , char **argv ATTR((unused)))
 {
        uuid_t          buf, tst;
        char            str[100];
        struct timeval  tv;
-       time_t          time_reg;
+       time_t          time_reg, time_gen;
        unsigned char   *cp;
        int i;
        int failed = 0;
@@ -50,7 +98,8 @@ main(int argc, char **argv)
                printf("%02x", *cp++);
        }
        printf("\n");
-       type = uuid_type(buf);  variant = uuid_variant(buf);
+       type = uuid_type(buf);
+       variant = uuid_variant(buf);
        printf("UUID type = %d, UUID variant = %d\n", type, variant);
        if (variant != UUID_VARIANT_DCE) {
                printf("Incorrect UUID Variant; was expecting DCE!\n");
@@ -62,7 +111,8 @@ main(int argc, char **argv)
                failed++;
        }
        printf("\n");
-       
+
+       time_gen = time(0);
        uuid_generate_time(buf);
        uuid_unparse(buf, str);
        printf("UUID string = %s\n", str);
@@ -71,7 +121,8 @@ main(int argc, char **argv)
                printf("%02x", *cp++);
        }
        printf("\n");
-       type = uuid_type(buf);  variant = uuid_variant(buf);
+       type = uuid_type(buf);
+       variant = uuid_variant(buf);
        printf("UUID type = %d, UUID variant = %d\n", type, variant);
        if (variant != UUID_VARIANT_DCE) {
                printf("Incorrect UUID Variant; was expecting DCE!\n");
@@ -82,15 +133,29 @@ main(int argc, char **argv)
                       "1 (time-based type)!\\n");
                failed++;
        }
+
        tv.tv_sec = 0;
        tv.tv_usec = 0;
        time_reg = uuid_time(buf, &tv);
-       printf("UUID time is: (%d, %d): %s\n", tv.tv_sec, tv.tv_usec,
-              ctime(&time_reg));
-       uuid_parse(str, tst);
-       if (!uuid_compare(buf, tst))
+       printf("UUID generated at %lu reports %lu (%ld.%ld)\n",
+              (unsigned long)time_gen, (unsigned long)time_reg,
+              (long)tv.tv_sec, (long)tv.tv_usec);
+       /* allow 1s margin in case of rollover between sampling
+        * the current time and when the UUID is generated. */
+       if (time_reg > time_gen + 1) {
+               printf("UUID time comparison failed!\n");
+               failed++;
+       } else {
+               printf("UUID time comparison succeeded.\n");
+       }
+
+       if (uuid_parse(str, tst) < 0) {
+               printf("UUID parse failed\n");
+               failed++;
+       }
+       if (!uuid_compare(buf, tst)) {
                printf("UUID parse and compare succeeded.\n");
-       else {
+       else {
                printf("UUID parse and compare failed!\n");
                failed++;
        }
@@ -108,12 +173,22 @@ main(int argc, char **argv)
                printf("UUID copy and compare failed!\n");
                failed++;
        }
+
+       failed += test_uuid("84949cc5-4701-4a84-895b-354c584a981b", 1);
+       failed += test_uuid("84949CC5-4701-4A84-895B-354C584A981B", 1);
+       failed += test_uuid("84949cc5-4701-4a84-895b-354c584a981bc", 0);
+       failed += test_uuid("84949cc5-4701-4a84-895b-354c584a981", 0);
+       failed += test_uuid("84949cc5x4701-4a84-895b-354c584a981b", 0);
+       failed += test_uuid("84949cc504701-4a84-895b-354c584a981b", 0);
+       failed += test_uuid("84949cc5-470104a84-895b-354c584a981b", 0);
+       failed += test_uuid("84949cc5-4701-4a840895b-354c584a981b", 0);
+       failed += test_uuid("84949cc5-4701-4a84-895b0354c584a981b", 0);
+       failed += test_uuid("g4949cc5-4701-4a84-895b-354c584a981b", 0);
+       failed += test_uuid("84949cc5-4701-4a84-895b-354c584a981g", 0);
+
        if (failed) {
                printf("%d failures.\n", failed);
                exit(1);
        }
        return 0;
 }
-
-       
-