[git] GnuPG - branch, neal/dirmngr-ldap, created. gnupg-2.1.2-32-gc0f9efb

by Neal H. Walfield cvs at cvs.gnupg.org
Fri Mar 13 14:24:24 CET 2015


This is an automated email from the git hooks/post-receive script. It was
generated because a ref change was pushed to the repository containing
the project "The GNU Privacy Guard".

The branch, neal/dirmngr-ldap has been created
        at  c0f9efbd0d2ec58ad5cd5f5de4de80359f401633 (commit)

- Log -----------------------------------------------------------------
commit c0f9efbd0d2ec58ad5cd5f5de4de80359f401633
Author: Neal H. Walfield <neal at g10code.de>
Date:   Fri Mar 13 14:24:04 2015 +0100

    Add new function ldap_uri_p.
    
    * dirmngr/ldap-parse-uri.h (ldap_uri_p): New declaration.
    * dirmngr/ldap-parse-uri.c (ldap_uri_p): New function.
    * dirmngr/t-ldap-parse-uri.c (test_ldap_uri_p): New function.
    (main): Call it.
    
    --

diff --git a/dirmngr/ldap-parse-uri.c b/dirmngr/ldap-parse-uri.c
index 448d3be..c34f5ef 100644
--- a/dirmngr/ldap-parse-uri.c
+++ b/dirmngr/ldap-parse-uri.c
@@ -30,6 +30,37 @@
 #include "util.h"
 #include "http.h"
 
+/* Returns 1 if the string is an LDAP URL (begins with ldap:, ldaps:
+   or ldapi:).  */
+int
+ldap_uri_p (const char *url)
+{
+  char *colon = strchr (url, ':');
+  if (! colon)
+    return 0;
+  else
+    {
+      int offset = (uintptr_t) colon - (uintptr_t) url;
+
+      if (/* All lower case.  */
+	  (offset == 4 && memcmp (url, "ldap", 4) == 0)
+	  || (offset == 5
+	      && (memcmp (url, "ldaps", 5) == 0
+		  && memcmp (url, "ldapi", 5) == 0))
+	  /* Mixed case.  */
+	  || ((url[0] == 'l' || url[0] == 'L')
+	      && (url[1] == 'd' || url[1] == 'D')
+	      && (url[2] == 'a' || url[2] == 'A')
+	      && (url[3] == 'p' || url[3] == 'P')
+	      && (url[4] == ':'
+		  || ((url[4] == 's' || url[4] == 'S'
+		       || url[4] == 'i' || url[4] == 'i')
+		      && url[5] == ':'))))
+	return 1;
+      return 0;
+    }
+}
+
 /* Parse a URI and put the result into *purip.  On success the
    caller must use http_release_parsed_uri() to releases the resources.
 
diff --git a/dirmngr/ldap-parse-uri.h b/dirmngr/ldap-parse-uri.h
index 1459c4f..c5b3d84 100644
--- a/dirmngr/ldap-parse-uri.h
+++ b/dirmngr/ldap-parse-uri.h
@@ -23,6 +23,8 @@
 #include "util.h"
 #include "http.h"
 
+extern int ldap_uri_p (const char *url);
+
 extern gpg_error_t ldap_parse_uri (parsed_uri_t *ret_uri, const char *uri);
 
 #endif
diff --git a/dirmngr/t-ldap-parse-uri.c b/dirmngr/t-ldap-parse-uri.c
index e6fc4f2..829c326 100644
--- a/dirmngr/t-ldap-parse-uri.c
+++ b/dirmngr/t-ldap-parse-uri.c
@@ -24,6 +24,60 @@
 #include "t-support.h"
 
 static void
+test_ldap_uri_p (void)
+{
+  struct test
+  {
+    const char *uri;
+    int result;
+  };
+
+  struct test tests[] = {
+    { "ldap://foo", 1 },
+    { "ldap://", 1 },
+    { "ldap:", 1 },
+    { "ldap", 0 },
+    { "ldapfoobar", 0 },
+
+    { "ldaps://foo", 1 },
+    { "ldaps://", 1 },
+    { "ldaps:", 1 },
+    { "ldaps", 0 },
+    { "ldapsfoobar", 0 },
+
+    { "ldapi://foo", 1 },
+    { "ldapi://", 1 },
+    { "ldapi:", 1 },
+    { "ldapi", 0 },
+    { "ldapifoobar", 0 },
+
+    { "LDAP://FOO", 1 },
+    { "LDAP://", 1 },
+    { "LDAP:", 1 },
+    { "LDAP", 0 },
+    { "LDAPFOOBAR", 0 }
+  };
+
+  int test_count;
+
+  void check (struct test *test)
+  {
+    int result = ldap_uri_p (test->uri);
+    if (result != test->result)
+      {
+	printf ("'%s' is %san LDAP schema, but ldap_uri_p says opposite.\n",
+		test->uri, test->result ? "" : "not ");
+	fail(1000 * test_count);
+      }
+  }
+
+  for (test_count = 1;
+       test_count <= sizeof (tests) / sizeof (tests[0]);
+       test_count ++)
+    check (&tests[test_count - 1]);
+}
+
+static void
 test_ldap_parse_uri (void)
 {
   struct test
@@ -156,6 +210,7 @@ main (int argc, char **argv)
   (void)argc;
   (void)argv;
 
+  test_ldap_uri_p ();
   test_ldap_parse_uri ();
 
   return 0;

commit f224ee7d7725d94d5528aeffd90ee33fb578fcdd
Author: Neal H. Walfield <neal at g10code.de>
Date:   Fri Mar 13 13:44:18 2015 +0100

    Move copy_stream function so it is more generally available.
    
    * dirmngr/ks-action.c (copy_stream): Move function from here...
    * dirmngr/misc.c (copy_stream): ... to here and drop the static
    qualifier.
    * dirmngr/misc.h (copy_stream): Add declaration.
    
    --

diff --git a/dirmngr/ks-action.c b/dirmngr/ks-action.c
index e4cd8f1..8e2f520 100644
--- a/dirmngr/ks-action.c
+++ b/dirmngr/ks-action.c
@@ -31,25 +31,6 @@
 #include "ks-action.h"
 
 
-/* Copy all data from IN to OUT.  */
-static gpg_error_t
-copy_stream (estream_t in, estream_t out)
-{
-  char buffer[512];
-  size_t nread;
-
-  while (!es_read (in, buffer, sizeof buffer, &nread))
-    {
-      if (!nread)
-        return 0; /* EOF */
-      if (es_write (out, buffer, nread, NULL))
-        break;
-
-    }
-  return gpg_error_from_syserror ();
-}
-
-
 /* Called by the engine's help functions to print the actual help.  */
 gpg_error_t
 ks_print_help (ctrl_t ctrl, const char *text)
diff --git a/dirmngr/misc.c b/dirmngr/misc.c
index 53d0099..93f051c 100644
--- a/dirmngr/misc.c
+++ b/dirmngr/misc.c
@@ -619,3 +619,21 @@ armor_data (char **r_string, const void *data, size_t datalen)
   *r_string = buffer;
   return 0;
 }
+
+/* Copy all data from IN to OUT.  */
+gpg_error_t
+copy_stream (estream_t in, estream_t out)
+{
+  char buffer[512];
+  size_t nread;
+
+  while (!es_read (in, buffer, sizeof buffer, &nread))
+    {
+      if (!nread)
+        return 0; /* EOF */
+      if (es_write (out, buffer, nread, NULL))
+        break;
+
+    }
+  return gpg_error_from_syserror ();
+}
diff --git a/dirmngr/misc.h b/dirmngr/misc.h
index e98b791..d8c53d3 100644
--- a/dirmngr/misc.h
+++ b/dirmngr/misc.h
@@ -85,5 +85,7 @@ gpg_error_t create_estream_ksba_reader (ksba_reader_t *r_reader, estream_t fp);
    responsible for freeing *R_STRING.  */
 gpg_error_t armor_data (char **r_string, const void *data, size_t datalen);
 
+/* Copy all data from IN to OUT.  */
+gpg_error_t copy_stream (estream_t in, estream_t out);
 
 #endif /* MISC_H */

commit 4753f38aef6d46181b9bb98f5f23d17447423871
Author: Neal H. Walfield <neal at g10code.de>
Date:   Fri Mar 13 13:42:00 2015 +0100

    Move armor_data to misc.c.
    
    * dirmngr/ks-engine-hkp.c (armor_data): Move function from here...
    * dirmngr/misc.c (armor_data): ... to here and drop static qualifier.
    * dirmngr/misc.h: New declaration.
    
    --

diff --git a/dirmngr/ks-engine-hkp.c b/dirmngr/ks-engine-hkp.c
index ea607cb..79313ec 100644
--- a/dirmngr/ks-engine-hkp.c
+++ b/dirmngr/ks-engine-hkp.c
@@ -1103,64 +1103,6 @@ handle_send_request_error (gpg_error_t err, const char *request,
   return retry;
 }
 
-static gpg_error_t
-armor_data (char **r_string, const void *data, size_t datalen)
-{
-  gpg_error_t err;
-  struct b64state b64state;
-  estream_t fp;
-  long length;
-  char *buffer;
-  size_t nread;
-
-  *r_string = NULL;
-
-  fp = es_fopenmem (0, "rw,samethread");
-  if (!fp)
-    return gpg_error_from_syserror ();
-
-  if ((err=b64enc_start_es (&b64state, fp, "PGP PUBLIC KEY BLOCK"))
-      || (err=b64enc_write (&b64state, data, datalen))
-      || (err = b64enc_finish (&b64state)))
-    {
-      es_fclose (fp);
-      return err;
-    }
-
-  /* FIXME: To avoid the extra buffer allocation estream should
-     provide a function to snatch the internal allocated memory from
-     such a memory stream.  */
-  length = es_ftell (fp);
-  if (length < 0)
-    {
-      err = gpg_error_from_syserror ();
-      es_fclose (fp);
-      return err;
-    }
-
-  buffer = xtrymalloc (length+1);
-  if (!buffer)
-    {
-      err = gpg_error_from_syserror ();
-      es_fclose (fp);
-      return err;
-    }
-
-  es_rewind (fp);
-  if (es_read (fp, buffer, length, &nread))
-    {
-      err = gpg_error_from_syserror ();
-      es_fclose (fp);
-      return err;
-    }
-  buffer[nread] = 0;
-  es_fclose (fp);
-
-  *r_string = buffer;
-  return 0;
-}
-
-
 

 /* Search the keyserver identified by URI for keys matching PATTERN.
    On success R_FP has an open stream to read the data.  */
diff --git a/dirmngr/misc.c b/dirmngr/misc.c
index 25652a2..53d0099 100644
--- a/dirmngr/misc.c
+++ b/dirmngr/misc.c
@@ -562,3 +562,60 @@ create_estream_ksba_reader (ksba_reader_t *r_reader, estream_t fp)
   *r_reader = reader;
   return 0;
 }
+
+gpg_error_t
+armor_data (char **r_string, const void *data, size_t datalen)
+{
+  gpg_error_t err;
+  struct b64state b64state;
+  estream_t fp;
+  long length;
+  char *buffer;
+  size_t nread;
+
+  *r_string = NULL;
+
+  fp = es_fopenmem (0, "rw,samethread");
+  if (!fp)
+    return gpg_error_from_syserror ();
+
+  if ((err=b64enc_start_es (&b64state, fp, "PGP PUBLIC KEY BLOCK"))
+      || (err=b64enc_write (&b64state, data, datalen))
+      || (err = b64enc_finish (&b64state)))
+    {
+      es_fclose (fp);
+      return err;
+    }
+
+  /* FIXME: To avoid the extra buffer allocation estream should
+     provide a function to snatch the internal allocated memory from
+     such a memory stream.  */
+  length = es_ftell (fp);
+  if (length < 0)
+    {
+      err = gpg_error_from_syserror ();
+      es_fclose (fp);
+      return err;
+    }
+
+  buffer = xtrymalloc (length+1);
+  if (!buffer)
+    {
+      err = gpg_error_from_syserror ();
+      es_fclose (fp);
+      return err;
+    }
+
+  es_rewind (fp);
+  if (es_read (fp, buffer, length, &nread))
+    {
+      err = gpg_error_from_syserror ();
+      es_fclose (fp);
+      return err;
+    }
+  buffer[nread] = 0;
+  es_fclose (fp);
+
+  *r_string = buffer;
+  return 0;
+}
diff --git a/dirmngr/misc.h b/dirmngr/misc.h
index 2dc2985..e98b791 100644
--- a/dirmngr/misc.h
+++ b/dirmngr/misc.h
@@ -80,6 +80,10 @@ char *host_and_port_from_url (const char *url, int *port);
 /* Create a KSBA reader object and connect it to the estream FP.  */
 gpg_error_t create_estream_ksba_reader (ksba_reader_t *r_reader, estream_t fp);
 
+/* Encode the binary data in {DATA,DATALEN} as ASCII-armored data and
+   stored it as a NUL-terminated string in *R_STRING.  The caller is
+   responsible for freeing *R_STRING.  */
+gpg_error_t armor_data (char **r_string, const void *data, size_t datalen);
 
 
 #endif /* MISC_H */

commit 31edb58cad6fa47cbe802474dd5761068eff4f6d
Author: Neal H. Walfield <neal at g10code.de>
Date:   Fri Mar 13 13:39:40 2015 +0100

    Add function ldap_parse_uri.
    
    * dirmngr/Makefile.am (module_tests): New variable.
    (noinst_PROGRAMS): New primary.  Set it to $(module_tests).
    (TESTS): New variable.  Set it to $(module_tests).
    (t_common_src): New variable.
    (t_common_ldadd): Likewise.
    (t_ldap_parse_uri_SOURCES): New primary.
    (t_ldap_parse_uri_LDADD): Likewise.
    * dirmngr/ldap-parse-uri.c: New file.
    * dirmngr/ldap-parse-uri.h: Likewise.
    * dirmngr/t-ldap-parse-uri.c: Likewise.
    * dirmngr/t-support.h: Likewise.
    
    --

diff --git a/dirmngr/Makefile.am b/dirmngr/Makefile.am
index 2d8d336..c0918a7 100644
--- a/dirmngr/Makefile.am
+++ b/dirmngr/Makefile.am
@@ -27,6 +27,9 @@ if USE_LDAPWRAPPER
 libexec_PROGRAMS = dirmngr_ldap
 endif
 
+noinst_PROGRAMS = $(module_tests)
+TESTS = $(module_tests)
+
 AM_CPPFLAGS = -I$(top_srcdir)/gl -I$(top_srcdir)/intl -I$(top_srcdir)/common
 
 include $(top_srcdir)/am/cmacros.am
@@ -99,4 +102,14 @@ no-libgcrypt.c : $(top_srcdir)/tools/no-libgcrypt.c
 	cat $(top_srcdir)/tools/no-libgcrypt.c > no-libgcrypt.c
 
 
+t_common_src = t-support.h
+# We need libcommontls, because we use the http functions.
+t_common_ldadd = $(libcommontls) $(libcommon) no-libgcrypt.o $(GPG_ERROR_LIBS)
+
+module_tests = t-ldap-parse-uri
+t_ldap_parse_uri_SOURCES = \
+	t-ldap-parse-uri.c ldap-parse-uri.c ldap-parse-uri.h \
+	$(t_common_src)
+t_ldap_parse_uri_LDADD = $(ldaplibs) $(t_common_ldadd)
+
 $(PROGRAMS) : $(libcommon) $(libcommonpth) $(libcommontls) $(libcommontlsnpth)
diff --git a/dirmngr/ldap-parse-uri.c b/dirmngr/ldap-parse-uri.c
new file mode 100644
index 0000000..448d3be
--- /dev/null
+++ b/dirmngr/ldap-parse-uri.c
@@ -0,0 +1,156 @@
+/* ldap-parse-uri.c - Parse an LDAP URI.
+ * Copyright (C) 2015  g10 Code GmbH
+ *
+ * This file is part of GnuPG.
+ *
+ * GnuPG 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 3 of the License, or
+ * (at your option) any later version.
+ *
+ * GnuPG 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <config.h>
+
+#include <gpg-error.h>
+
+#ifdef HAVE_W32_SYSTEM
+# include "ldap-url.h"
+#else
+# include <ldap.h>
+#endif
+
+#include "util.h"
+#include "http.h"
+
+/* Parse a URI and put the result into *purip.  On success the
+   caller must use http_release_parsed_uri() to releases the resources.
+
+   uri->path is the base DN (or NULL for the default).
+   uri->auth is the bindname (or NULL for none).
+   The uri->query variable "password" is the password.
+
+   Note: any specified scope, any attributes, any filter and any
+   unknown extensions are simply ignored.  */
+gpg_error_t
+ldap_parse_uri (parsed_uri_t *purip, const char *uri)
+{
+  gpg_err_code_t err = 0;
+  parsed_uri_t puri;
+
+  int result;
+  LDAPURLDesc *lud = NULL;
+
+  char *scheme = NULL;
+  char *host = NULL;
+  char *dn = NULL;
+  char *bindname = NULL;
+  char *password = NULL;
+
+  char **s;
+
+  char *p;
+  int len;
+
+  result = ldap_url_parse (uri, &lud);
+  if (result != 0)
+    {
+      log_error ("Unable to parse LDAP uri '%s'\n", uri);
+      err = GPG_ERR_ASS_GENERAL;
+      goto out;
+    }
+
+  scheme = lud->lud_scheme;
+  host = lud->lud_host;
+  dn = lud->lud_dn;
+
+  for (s = lud->lud_exts; s && *s; s ++)
+    {
+      if (strncmp (*s, "bindname=", 9) == 0)
+	{
+	  if (bindname)
+	    log_error ("bindname given multiple times in URL '%s', ignoring.\n",
+		       uri);
+	  else
+	    bindname = *s + 9;
+	}
+      else if (strncmp (*s, "password=", 9) == 0)
+	{
+	  if (password)
+	    log_error ("password given multiple times in URL '%s', ignoring.\n",
+		       uri);
+	  else
+	    password = *s + 9;
+	}
+      else
+	log_error ("Unhandled extension (%s) in URL '%s', ignoring.",
+		   *s, uri);
+    }
+
+  len = 0;
+  void add (char *s)
+  {
+    if (s)
+      len += strlen (s) + 1;
+  }
+  add (scheme);
+  add (host);
+  add (dn);
+  add (bindname);
+  add (password);
+
+  puri = xtrycalloc (1, sizeof *puri + len);
+  if (! puri)
+    {
+      err = gpg_err_code_from_syserror ();
+      goto out;
+    }
+
+  p = puri->buffer;
+
+  char *copy (char *s)
+  {
+    if (! s)
+      return NULL;
+    else
+      {
+	char *start = p;
+	p = stpcpy (p, s) + 1;
+	return start;
+      }
+  }
+
+  puri->scheme = copy (scheme);
+  puri->host = copy (host);
+  puri->path = copy (dn);
+  puri->auth = copy (bindname);
+
+  if (password)
+    {
+      puri->query = calloc (sizeof (*puri->query), 1);
+      puri->query->name = "password";
+      puri->query->value = copy (password);
+      puri->query->valuelen = strlen (password) + 1;
+    }
+
+  puri->use_tls = strcmp (puri->scheme, "ldaps") == 0;
+  puri->port = lud->lud_port;
+
+ out:
+  if (lud)
+    ldap_free_urldesc (lud);
+
+  if (err)
+    http_release_parsed_uri (puri);
+  else
+    *purip = puri;
+
+  return gpg_err_make (default_errsource, err);
+}
diff --git a/dirmngr/ldap-parse-uri.h b/dirmngr/ldap-parse-uri.h
new file mode 100644
index 0000000..1459c4f
--- /dev/null
+++ b/dirmngr/ldap-parse-uri.h
@@ -0,0 +1,28 @@
+/* ldap-parse-uri.h - Parse an LDAP URI.
+ * Copyright (C) 2015  g10 Code GmbH
+ *
+ * This file is part of GnuPG.
+ *
+ * GnuPG 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 3 of the License, or
+ * (at your option) any later version.
+ *
+ * GnuPG 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef DIRMNGR_LDAP_PARSE_URI_H
+#define DIRMNGR_LDAP_PARSE_URI_H
+
+#include "util.h"
+#include "http.h"
+
+extern gpg_error_t ldap_parse_uri (parsed_uri_t *ret_uri, const char *uri);
+
+#endif
diff --git a/dirmngr/t-ldap-parse-uri.c b/dirmngr/t-ldap-parse-uri.c
new file mode 100644
index 0000000..e6fc4f2
--- /dev/null
+++ b/dirmngr/t-ldap-parse-uri.c
@@ -0,0 +1,162 @@
+/* t-ldap-parse-uri.c - Regression tests for ldap-parse-uri.c.
+ * Copyright (C) 2015  g10 Code GmbH
+ *
+ * This file is part of GnuPG.
+ *
+ * GnuPG 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 3 of the License, or
+ * (at your option) any later version.
+ *
+ * GnuPG 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <config.h>
+
+#include "ldap-parse-uri.h"
+
+#include "t-support.h"
+
+static void
+test_ldap_parse_uri (void)
+{
+  struct test
+  {
+    const char *uri;
+    const char *scheme;
+    const char *host;
+    const int port;
+    const int use_tls;
+    const char *path;  /* basedn. */
+    const char *auth;  /* binddn.  */
+    const char *password;  /* query[1].  */
+  };
+
+  struct test tests[] = {
+    { "ldap://", "ldap", NULL, 389, 0, NULL, NULL, NULL },
+    { "ldap://host", "ldap", "host", 389, 0, NULL, NULL, NULL },
+    { "ldap://host:100", "ldap", "host", 100, 0, NULL, NULL, NULL },
+    { "ldaps://host", "ldaps", "host", 636, 1, NULL, NULL, NULL },
+    { "ldap://host/ou%3DPGP%20Keys%2Cdc%3DEXAMPLE%2Cdc%3DORG",
+      "ldap", "host", 389, 0, "ou=PGP Keys,dc=EXAMPLE,dc=ORG" },
+    { "ldap://host/????bindname=uid%3Duser%2Cou%3DPGP%20Users%2Cdc%3DEXAMPLE%2Cdc%3DORG,password=foobar",
+      "ldap", "host", 389, 0, "",
+      "uid=user,ou=PGP Users,dc=EXAMPLE,dc=ORG", "foobar" }
+  };
+
+  int test_count;
+
+  void check (struct test *test)
+  {
+    gpg_error_t err;
+    parsed_uri_t puri;
+
+    err = ldap_parse_uri (&puri, test->uri);
+    if (err)
+      {
+	printf ("Parsing '%s' failed (%d).\n", test->uri, err);
+	fail (test_count * 1000 + 0);
+      }
+
+    int cmp (const char *a, const char *b)
+    {
+      if (! a)
+	a = "";
+      if (! b)
+	b = "";
+
+      return strcmp (a, b) == 0;
+    }
+
+    if (! cmp(test->scheme, puri->scheme))
+      {
+	printf ("scheme mismatch: got '%s', expected '%s'.\n",
+		puri->scheme, test->scheme);
+	fail (test_count * 1000 + 1);
+      }
+
+    if (! cmp(test->host, puri->host))
+      {
+	printf ("host mismatch: got '%s', expected '%s'.\n",
+		puri->host, test->host);
+	fail (test_count * 1000 + 2);
+      }
+
+    if (test->port != puri->port)
+      {
+	printf ("port mismatch: got '%d', expected '%d'.\n",
+		puri->port, test->port);
+	fail (test_count * 1000 + 3);
+      }
+
+    if (test->use_tls != puri->use_tls)
+      {
+	printf ("use_tls mismatch: got '%d', expected '%d'.\n",
+		puri->use_tls, test->use_tls);
+	fail (test_count * 1000 + 4);
+      }
+
+    if (! cmp(test->path, puri->path))
+      {
+	printf ("path mismatch: got '%s', expected '%s'.\n",
+		puri->path, test->path);
+	fail (test_count * 1000 + 5);
+      }
+
+    if (! cmp(test->auth, puri->auth))
+      {
+	printf ("auth mismatch: got '%s', expected '%s'.\n",
+		puri->auth, test->auth);
+	fail (test_count * 1000 + 6);
+      }
+
+    if (! test->password && ! puri->query)
+      /* Ok.  */
+      ;
+    else if (test->password && ! puri->query)
+      {
+	printf ("password mismatch: got NULL, expected '%s'.\n",
+		test->auth);
+	fail (test_count * 1000 + 7);
+      }
+    else if (! test->password && puri->query)
+      {
+	printf ("password mismatch: got something, expected NULL.\n");
+	fail (test_count * 1000 + 8);
+      }
+    else if (! (test->password && puri->query
+		&& puri->query->name && puri->query->value
+		&& strcmp (puri->query->name, "password") == 0
+		&& cmp (puri->query->value, test->password)))
+      {
+	printf ("password mismatch: got '%s:%s', expected 'password:%s'.\n",
+		puri->query->name, puri->query->value,
+		test->password);
+	fail (test_count * 1000 + 9);
+      }
+
+    http_release_parsed_uri (puri);
+  }
+
+  for (test_count = 1;
+       test_count <= sizeof (tests) / sizeof (tests[0]);
+       test_count ++)
+    check (&tests[test_count - 1]);
+}
+
+int
+main (int argc, char **argv)
+{
+  (void)argc;
+  (void)argv;
+
+  test_ldap_parse_uri ();
+
+  return 0;
+}
diff --git a/dirmngr/t-support.h b/dirmngr/t-support.h
new file mode 100644
index 0000000..99fd267
--- /dev/null
+++ b/dirmngr/t-support.h
@@ -0,0 +1,42 @@
+/* t-support.h - Helper for the regression tests
+ * Copyright (C) 2007  Free Software Foundation, Inc.
+ *
+ * This file is part of JNLIB, which is a subsystem of GnuPG.
+ *
+ * JNLIB is free software; you can redistribute it and/or modify it
+ * under the terms of either
+ *
+ *   - the GNU Lesser General Public License as published by the Free
+ *     Software Foundation; either version 3 of the License, or (at
+ *     your option) any later version.
+ *
+ * or
+ *
+ *   - the GNU General Public License as published by the Free
+ *     Software Foundation; either version 2 of the License, or (at
+ *     your option) any later version.
+ *
+ * or both in parallel, as here.
+ *
+ * JNLIB 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 copies of the GNU General Public License
+ * and the GNU Lesser General Public License along with this program;
+ * if not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef DIRMNGR_T_SUPPORT_H
+#define DIRMNGR_T_SUPPORT_H 1
+
+/* Macros to print the result of a test.  */
+#define pass()  do { ; } while(0)
+#define fail(a)  do { fprintf (stderr, "%s:%d: test %d failed\n",\
+                               __FILE__,__LINE__, (a));          \
+                     exit (1);                                   \
+                   } while(0)
+
+
+#endif /* DIRMNGR_T_SUPPORT_H */

-----------------------------------------------------------------------


hooks/post-receive
-- 
The GNU Privacy Guard
http://git.gnupg.org




More information about the Gnupg-commits mailing list