bug-findutils
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: canonicalize-lgpl-tests on cygwin


From: Eric Blake
Subject: Re: canonicalize-lgpl-tests on cygwin
Date: Fri, 06 Jul 2007 08:21:54 -0600
User-agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.0.12) Gecko/20070509 Thunderbird/1.5.0.12 Mnenhy/0.7.5.666

-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

According to Eric Blake on 7/5/2007 10:08 AM:
> The canonicalize-lgpl module is being pulled into findutils by virtue of
> the fchdir module.  Perhaps we need fchdir and fchdir-lgpl?  Or maybe the
> solution is just for findutils to use --avoid=canonicalize-lgpl when using
> gnulib-tool?  Or conditionalize test-canonicalize-lgpl.c to be a no-op
> when it is detected that the canonicalize module is also in use?
> 
> This patch goes with the latter approach.  I tested that with it, plus
> bumping findutils to use this instead of 2007-06-20 as the gnulib source,
> findutils makes it through building.  OK to apply?  Should I also create a
> module canonicalize-tests that gets run instead when both modules are in use?

Here's what I'm committing to gnulib.

2007-07-06  Eric Blake  <address@hidden>

        Fix testing canonicalize on cygwin.
        * modules/canonicalize-lgpl-tests (test_canonicalize_lgpl_LDADD):
        Revert patch from 2007-06-19.
        * tests/test-canonicalize-lgpl.c (main): Instead, skip test when
        canonicalize module is also in use.
        * tests/test-canonicalize.c: New file.
        * tests/test-canonicalize.sh: Likewise.
        * modules/canonicalize-tests: Likewise.

- --
Don't work too hard, make some time for fun as well!

Eric Blake             address@hidden
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.5 (Cygwin)
Comment: Public key at home.comcast.net/~ericblake/eblake.gpg
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org

iD8DBQFGjlAC84KuGfSFAYARApGrAJwN4t2ZJz1maXl7EIGKtOb5knG09ACg2MG+
IvPeqe4TEpNiFKynIFfmBQA=
=BTSQ
-----END PGP SIGNATURE-----
Index: modules/canonicalize-lgpl-tests
===================================================================
RCS file: /sources/gnulib/gnulib/modules/canonicalize-lgpl-tests,v
retrieving revision 1.4
diff -u -p -r1.4 canonicalize-lgpl-tests
--- modules/canonicalize-lgpl-tests     19 Jun 2007 13:00:19 -0000      1.4
+++ modules/canonicalize-lgpl-tests     6 Jul 2007 14:17:42 -0000
@@ -11,4 +11,4 @@ TESTS += test-canonicalize-lgpl.sh
 TESTS_ENVIRONMENT += EXEEXT='@EXEEXT@'
 check_PROGRAMS += test-canonicalize-lgpl
 EXTRA_DIST += test-canonicalize-lgpl.sh
-test_canonicalize_lgpl_LDADD = $(LDADD) @LIBINTL@
+test_canonicalize_lgpl_LDADD = $(LDADD)
Index: modules/canonicalize-tests
===================================================================
RCS file: modules/canonicalize-tests
diff -N modules/canonicalize-tests
--- /dev/null   1 Jan 1970 00:00:00 -0000
+++ modules/canonicalize-tests  6 Jul 2007 14:17:42 -0000
@@ -0,0 +1,14 @@
+Files:
+tests/test-canonicalize.sh
+tests/test-canonicalize.c
+
+Depends-on:
+
+configure.ac:
+
+Makefile.am:
+TESTS += test-canonicalize.sh
+TESTS_ENVIRONMENT += EXEEXT='@EXEEXT@'
+check_PROGRAMS += test-canonicalize
+EXTRA_DIST += test-canonicalize.sh
+test_canonicalize_LDADD = $(LDADD) @LIBINTL@
Index: tests/test-canonicalize-lgpl.c
===================================================================
RCS file: /sources/gnulib/gnulib/tests/test-canonicalize-lgpl.c,v
retrieving revision 1.3
diff -u -p -r1.3 test-canonicalize-lgpl.c
--- tests/test-canonicalize-lgpl.c      28 May 2007 16:49:42 -0000      1.3
+++ tests/test-canonicalize-lgpl.c      6 Jul 2007 14:17:42 -0000
@@ -39,6 +39,12 @@
 int
 main ()
 {
+#ifdef GNULIB_CANONICALIZE
+  /* No need to test canonicalize-lgpl module if canonicalize is also
+     in use.  */
+  return 0;
+#endif
+
   /* Check that the symbolic link to a file can be resolved.  */
   {
     char *result1 = canonicalize_file_name ("t-can-lgpl.tmp/huk");
Index: tests/test-canonicalize.c
===================================================================
RCS file: tests/test-canonicalize.c
diff -N tests/test-canonicalize.c
--- /dev/null   1 Jan 1970 00:00:00 -0000
+++ tests/test-canonicalize.c   6 Jul 2007 14:17:42 -0000
@@ -0,0 +1,131 @@
+/* Test of execution of file name canonicalization.
+   Copyright (C) 2007 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
+   the Free Software Foundation; either version 2, or (at your option)
+   any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program; if not, write to the Free Software Foundation,
+   Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.  */
+
+/* Written by Bruno Haible <address@hidden>, 2007.  */
+
+#include <config.h>
+
+#include "canonicalize.h"
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#define ASSERT(expr) \
+  do                                                                        \
+    {                                                                       \
+      if (!(expr))                                                          \
+        {                                                                   \
+          fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \
+          abort ();                                                         \
+        }                                                                   \
+    }                                                                       \
+  while (0)
+
+const char *program_name = "test-canonicalize";
+
+int
+main ()
+{
+  /* Check that the symbolic link to a file can be resolved.  */
+  {
+    char *result1 = canonicalize_file_name ("t-can.tmp/huk");
+    char *result2 = canonicalize_file_name ("t-can.tmp/tra");
+    char *result3 = canonicalize_filename_mode ("t-can.tmp/huk", CAN_EXISTING);
+    ASSERT (result1 != NULL);
+    ASSERT (result2 != NULL);
+    ASSERT (result3 != NULL);
+    ASSERT (strcmp (result1, result2) == 0);
+    ASSERT (strcmp (result2, result3) == 0);
+    ASSERT (strcmp (result1 + strlen (result1) - 14, "/t-can.tmp/tra") == 0);
+    free (result1);
+    free (result2);
+    free (result3);
+  }
+
+  /* Check that the symbolic link to a directory can be resolved.  */
+  {
+    char *result1 = canonicalize_file_name ("t-can.tmp/plo");
+    char *result2 = canonicalize_file_name ("t-can.tmp/bef");
+    char *result3 = canonicalize_file_name ("t-can.tmp/lum");
+    char *result4 = canonicalize_filename_mode ("t-can.tmp/plo", CAN_EXISTING);
+    ASSERT (result1 != NULL);
+    ASSERT (result2 != NULL);
+    ASSERT (result3 != NULL);
+    ASSERT (result4 != NULL);
+    ASSERT (strcmp (result1, result2) == 0);
+    ASSERT (strcmp (result2, result3) == 0);
+    ASSERT (strcmp (result3, result4) == 0);
+    ASSERT (strcmp (result1 + strlen (result1) - 14, "/t-can.tmp/lum") == 0);
+    free (result1);
+    free (result2);
+    free (result3);
+    free (result4);
+  }
+
+  /* Check that a symbolic link to a nonexistent file yields NULL.  */
+  {
+    char *result1 = canonicalize_file_name ("t-can.tmp/ouk");
+    char *result2 = canonicalize_filename_mode ("t-can.tmp/ouk", CAN_EXISTING);
+    ASSERT (result1 == NULL);
+    ASSERT (result2 == NULL);
+  }
+
+  /* Check that a loop of symbolic links is detected.  */
+  {
+    char *result1 = canonicalize_file_name ("ise");
+    char *result2 = canonicalize_filename_mode ("ise", CAN_EXISTING);
+    ASSERT (result1 == NULL);
+    ASSERT (result2 == NULL);
+  }
+
+  /* Check that alternate modes can resolve missing basenames.  */
+  {
+    char *result1 = canonicalize_filename_mode ("t-can.tmp/zzz", 
CAN_ALL_BUT_LAST);
+    char *result2 = canonicalize_filename_mode ("t-can.tmp/zzz", CAN_MISSING);
+    ASSERT (result1 != NULL);
+    ASSERT (result2 != NULL);
+    ASSERT (strcmp (result1, result2) == 0);
+    ASSERT (strcmp (result1 + strlen (result1) - 14, "/t-can.tmp/zzz") == 0);
+    free (result1);
+    free (result2);
+  }
+
+  /* Check that alternate modes can resolve broken symlink basenames.  */
+  {
+    char *result1 = canonicalize_filename_mode ("t-can.tmp/ouk", 
CAN_ALL_BUT_LAST);
+    char *result2 = canonicalize_filename_mode ("t-can.tmp/ouk", CAN_MISSING);
+    ASSERT (result1 != NULL);
+    ASSERT (result2 != NULL);
+    ASSERT (strcmp (result1, result2) == 0);
+    ASSERT (strcmp (result1 + strlen (result1) - 14, "/t-can.tmp/wum") == 0);
+    free (result1);
+    free (result2);
+  }
+
+  /* Check that alternate modes can handle missing dirnames.  */
+  {
+    char *result1 = canonicalize_filename_mode ("t-can.zzz/zzz", 
CAN_ALL_BUT_LAST);
+    char *result2 = canonicalize_filename_mode ("t-can.zzz/zzz", CAN_MISSING);
+    ASSERT (result1 == NULL);
+    ASSERT (result2 != NULL);
+    ASSERT (strcmp (result2 + strlen (result2) - 14, "/t-can.zzz/zzz") == 0);
+    free (result2);
+  }
+
+  return 0;
+}
Index: tests/test-canonicalize.sh
===================================================================
RCS file: tests/test-canonicalize.sh
diff -N tests/test-canonicalize.sh
--- /dev/null   1 Jan 1970 00:00:00 -0000
+++ tests/test-canonicalize.sh  6 Jul 2007 14:17:42 -0000
@@ -0,0 +1,28 @@
+#!/bin/sh
+
+tmpfiles=""
+trap 'rm -fr $tmpfiles' 1 2 3 15
+
+tmpfiles="$tmpfiles t-can.tmp ise"
+mkdir t-can.tmp
+ln -s t-can.tmp/ket ise \
+  || { echo "Skipping test: symbolic links not supported on this filesystem"
+       rm -fr $tmpfiles
+       exit 77
+     }
+(cd t-can.tmp \
+ && ln -s bef plo \
+ && ln -s tra huk \
+ && ln -s lum bef \
+ && ln -s wum ouk \
+ && ln -s ../ise ket \
+ && echo > tra \
+ && mkdir lum
+) || exit 1
+
+./test-canonicalize${EXEEXT}
+result=$?
+
+rm -fr $tmpfiles
+
+exit $result

reply via email to

[Prev in Thread] Current Thread [Next in Thread]