* [PATCH 0/3] Fixes for OS X @ 2013-08-05 15:59 Brian Gernhardt 2013-08-05 15:59 ` [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 Brian Gernhardt ` (2 more replies) 0 siblings, 3 replies; 12+ messages in thread From: Brian Gernhardt @ 2013-08-05 15:59 UTC (permalink / raw) To: Git List; +Cc: Junio C Hamano A few changes recently broke my build on Mac 10.8, possibly because I have a more strict set of warnings/errors enabled. The first two handle minor problems with the use of APPLE_COMMON_CRYPTO, which was expanded for use in imap-send but had a couple of problems. The last is likely due to curl version skew between Dave Borowitz and myself. (see 912b2ac). There are a few notes on the patches indicating where I was less than sure about my solutions. Brian Gernhardt (3): Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 OS X: Fix redeclaration of die warning t5551: Remove header from curl cookie file Makefile | 4 +++- git-compat-util.h | 20 ++++++++++---------- t/t5551-http-fetch.sh | 6 ++---- 3 files changed, 15 insertions(+), 15 deletions(-) -- 1.8.4.rc1.384.g0976a17.dirty ^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 2013-08-05 15:59 [PATCH 0/3] Fixes for OS X Brian Gernhardt @ 2013-08-05 15:59 ` Brian Gernhardt 2013-08-05 16:16 ` Jeremy Huddleston Sequoia 2013-08-05 17:52 ` Junio C Hamano 2013-08-05 15:59 ` [PATCH 2/3] OS X: Fix redeclaration of die warning Brian Gernhardt 2013-08-05 15:59 ` [PATCH 3/3] t5551: Remove header from curl cookie file Brian Gernhardt 2 siblings, 2 replies; 12+ messages in thread From: Brian Gernhardt @ 2013-08-05 15:59 UTC (permalink / raw) To: Git List; +Cc: Junio C Hamano, Jeremy Huddleston It used to be that APPLE_COMMON_CRYPTO did nothing when BLK_SHA1 was set. But APPLE_COMMON_CRYPTO is now used for more than just SHA1 (see 3ef2bca) so make sure that the appropriate libraries are always set. Signed-off-by: Brian Gernhardt <brian@gernhardtsoftware.com> --- Makefile | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 82f2e22..7051956 100644 --- a/Makefile +++ b/Makefile @@ -1182,6 +1182,9 @@ ifdef NEEDS_SSL_WITH_CRYPTO else LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto endif +ifdef APPLE_COMMON_CRYPTO + LIB_4_CRYPTO += -framework Security -framework CoreFoundation +endif endif ifdef NEEDS_LIBICONV ifdef ICONVDIR @@ -1413,7 +1416,6 @@ ifdef PPC_SHA1 LIB_H += ppc/sha1.h else ifdef APPLE_COMMON_CRYPTO - LIB_4_CRYPTO += -framework Security -framework CoreFoundation COMPAT_CFLAGS += -DCOMMON_DIGEST_FOR_OPENSSL SHA1_HEADER = <CommonCrypto/CommonDigest.h> else -- 1.8.4.rc1.384.g0976a17.dirty ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 2013-08-05 15:59 ` [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 Brian Gernhardt @ 2013-08-05 16:16 ` Jeremy Huddleston Sequoia 2013-08-05 17:52 ` Junio C Hamano 1 sibling, 0 replies; 12+ messages in thread From: Jeremy Huddleston Sequoia @ 2013-08-05 16:16 UTC (permalink / raw) To: Brian Gernhardt; +Cc: Git List, Junio C Hamano [-- Attachment #1: Type: text/plain, Size: 1184 bytes --] Thanks Brian, Reviewed-by: Jeremy Huddleston Sequoia <jeremyhu@apple.com> On Aug 5, 2013, at 8:59, Brian Gernhardt <brian@gernhardtsoftware.com> wrote: > It used to be that APPLE_COMMON_CRYPTO did nothing when BLK_SHA1 was > set. But APPLE_COMMON_CRYPTO is now used for more than just SHA1 (see > 3ef2bca) so make sure that the appropriate libraries are always set. > > Signed-off-by: Brian Gernhardt <brian@gernhardtsoftware.com> > --- > Makefile | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/Makefile b/Makefile > index 82f2e22..7051956 100644 > --- a/Makefile > +++ b/Makefile > @@ -1182,6 +1182,9 @@ ifdef NEEDS_SSL_WITH_CRYPTO > else > LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto > endif > +ifdef APPLE_COMMON_CRYPTO > + LIB_4_CRYPTO += -framework Security -framework CoreFoundation > +endif > endif > ifdef NEEDS_LIBICONV > ifdef ICONVDIR > @@ -1413,7 +1416,6 @@ ifdef PPC_SHA1 > LIB_H += ppc/sha1.h > else > ifdef APPLE_COMMON_CRYPTO > - LIB_4_CRYPTO += -framework Security -framework CoreFoundation > COMPAT_CFLAGS += -DCOMMON_DIGEST_FOR_OPENSSL > SHA1_HEADER = <CommonCrypto/CommonDigest.h> > else > -- > 1.8.4.rc1.384.g0976a17.dirty > [-- Attachment #2: smime.p7s --] [-- Type: application/pkcs7-signature, Size: 4136 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 2013-08-05 15:59 ` [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 Brian Gernhardt 2013-08-05 16:16 ` Jeremy Huddleston Sequoia @ 2013-08-05 17:52 ` Junio C Hamano 2013-08-06 11:25 ` David Aguilar 1 sibling, 1 reply; 12+ messages in thread From: Junio C Hamano @ 2013-08-05 17:52 UTC (permalink / raw) To: Brian Gernhardt; +Cc: Git List, Jeremy Huddleston Brian Gernhardt <brian@gernhardtsoftware.com> writes: > It used to be that APPLE_COMMON_CRYPTO did nothing when BLK_SHA1 was > set. But APPLE_COMMON_CRYPTO is now used for more than just SHA1 (see > 3ef2bca) so make sure that the appropriate libraries are always set. > > Signed-off-by: Brian Gernhardt <brian@gernhardtsoftware.com> > --- > Makefile | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/Makefile b/Makefile > index 82f2e22..7051956 100644 > --- a/Makefile > +++ b/Makefile > @@ -1182,6 +1182,9 @@ ifdef NEEDS_SSL_WITH_CRYPTO > else > LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto > endif > +ifdef APPLE_COMMON_CRYPTO > + LIB_4_CRYPTO += -framework Security -framework CoreFoundation > +endif > endif > ifdef NEEDS_LIBICONV > ifdef ICONVDIR > @@ -1413,7 +1416,6 @@ ifdef PPC_SHA1 > LIB_H += ppc/sha1.h > else > ifdef APPLE_COMMON_CRYPTO > - LIB_4_CRYPTO += -framework Security -framework CoreFoundation > COMPAT_CFLAGS += -DCOMMON_DIGEST_FOR_OPENSSL > SHA1_HEADER = <CommonCrypto/CommonDigest.h> > else Hmph. So the people previously tested this must have built imap-send without blk-sha1, which not just linked with these libs but also included the <CommonCrypto/CommonDigest.h> header file and defined the -DCOMMON_DIGEST_FOR_OPENSSL preprocessor macro. Building with blk-sha1 would not have worked for them. Now we always link with these libraries, even when building with blk-sha1. Do the COMPAT_CFLAGS and SHA1_HEADER pieces only needed when using the SHA1 digest implementation from CommonCrypto and nothing imap-send uses? ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 2013-08-05 17:52 ` Junio C Hamano @ 2013-08-06 11:25 ` David Aguilar 2013-08-06 17:24 ` Junio C Hamano 0 siblings, 1 reply; 12+ messages in thread From: David Aguilar @ 2013-08-06 11:25 UTC (permalink / raw) To: Junio C Hamano; +Cc: Brian Gernhardt, Git List, Jeremy Huddleston On Mon, Aug 5, 2013 at 10:52 AM, Junio C Hamano <gitster@pobox.com> wrote: > Brian Gernhardt <brian@gernhardtsoftware.com> writes: > >> It used to be that APPLE_COMMON_CRYPTO did nothing when BLK_SHA1 was >> set. But APPLE_COMMON_CRYPTO is now used for more than just SHA1 (see >> 3ef2bca) so make sure that the appropriate libraries are always set. >> >> Signed-off-by: Brian Gernhardt <brian@gernhardtsoftware.com> >> --- >> Makefile | 4 +++- >> 1 file changed, 3 insertions(+), 1 deletion(-) >> >> diff --git a/Makefile b/Makefile >> index 82f2e22..7051956 100644 >> --- a/Makefile >> +++ b/Makefile >> @@ -1182,6 +1182,9 @@ ifdef NEEDS_SSL_WITH_CRYPTO >> else >> LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto >> endif >> +ifdef APPLE_COMMON_CRYPTO >> + LIB_4_CRYPTO += -framework Security -framework CoreFoundation >> +endif >> endif >> ifdef NEEDS_LIBICONV >> ifdef ICONVDIR >> @@ -1413,7 +1416,6 @@ ifdef PPC_SHA1 >> LIB_H += ppc/sha1.h >> else >> ifdef APPLE_COMMON_CRYPTO >> - LIB_4_CRYPTO += -framework Security -framework CoreFoundation >> COMPAT_CFLAGS += -DCOMMON_DIGEST_FOR_OPENSSL >> SHA1_HEADER = <CommonCrypto/CommonDigest.h> >> else > > Hmph. > > So the people previously tested this must have built imap-send > without blk-sha1, which not just linked with these libs but also > included the <CommonCrypto/CommonDigest.h> header file and defined > the -DCOMMON_DIGEST_FOR_OPENSSL preprocessor macro. Building with > blk-sha1 would not have worked for them. > Now we always link with these libraries, even when building with > blk-sha1. Do the COMPAT_CFLAGS and SHA1_HEADER pieces only needed > when using the SHA1 digest implementation from CommonCrypto and > nothing imap-send uses? LIB_4_CRYPTO is used by imap-send only, and these libraries are needed for the base64 git_CC_EVP_(Encode|Decode), so unconditionally adding these libraries there is correct. COMPAT_CFLAGS and SHA1_HEADER enable the common crypto SHA1 only. BLK_SHA1 provides its own SHA1 so they're not needed there. I tested the tip of da/darwin (pu) w/ and w/out BLK_SHA1. Tested-by: David Aguilar <davvid@gmail.com> -- David ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 2013-08-06 11:25 ` David Aguilar @ 2013-08-06 17:24 ` Junio C Hamano 0 siblings, 0 replies; 12+ messages in thread From: Junio C Hamano @ 2013-08-06 17:24 UTC (permalink / raw) To: David Aguilar; +Cc: Brian Gernhardt, Git List, Jeremy Huddleston David Aguilar <davvid@gmail.com> writes: > I tested the tip of da/darwin (pu) w/ and w/out BLK_SHA1. > > Tested-by: David Aguilar <davvid@gmail.com> Thanks. ^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH 2/3] OS X: Fix redeclaration of die warning 2013-08-05 15:59 [PATCH 0/3] Fixes for OS X Brian Gernhardt 2013-08-05 15:59 ` [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 Brian Gernhardt @ 2013-08-05 15:59 ` Brian Gernhardt 2013-08-05 16:17 ` Jeremy Huddleston Sequoia 2013-08-05 18:00 ` Junio C Hamano 2013-08-05 15:59 ` [PATCH 3/3] t5551: Remove header from curl cookie file Brian Gernhardt 2 siblings, 2 replies; 12+ messages in thread From: Brian Gernhardt @ 2013-08-05 15:59 UTC (permalink / raw) To: Git List; +Cc: Junio C Hamano, Jeremy Huddleston compat/apple-common-crypto.h uses die() in one of its macros, but was included in git-compat-util.h before the definition of die. Fix by simply moving the relevant block after the die/error/warning declarations. Signed-off-by: Brian Gernhardt <brian@gernhardtsoftware.com> --- Not sure if this is the best place to move it to, but it's the earliest it can be in the file without causing errors. (Namely that clang has to guess what die() means in apple-common-crypto.h and guesses differently than the actual definition.) git-compat-util.h | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/git-compat-util.h b/git-compat-util.h index af5f6bb..d60e28d 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -129,16 +129,6 @@ #include <poll.h> #endif -#ifndef NO_OPENSSL -#ifdef APPLE_COMMON_CRYPTO -#include "compat/apple-common-crypto.h" -#else -#include <openssl/evp.h> -#include <openssl/hmac.h> -#endif /* APPLE_COMMON_CRYPTO */ -#include <openssl/x509v3.h> -#endif /* NO_OPENSSL */ - #if defined(__MINGW32__) /* pull in Windows compatibility stuff */ #include "compat/mingw.h" @@ -340,6 +330,16 @@ extern NORETURN void die_errno(const char *err, ...) __attribute__((format (prin extern int error(const char *err, ...) __attribute__((format (printf, 1, 2))); extern void warning(const char *err, ...) __attribute__((format (printf, 1, 2))); +#ifndef NO_OPENSSL +#ifdef APPLE_COMMON_CRYPTO +#include "compat/apple-common-crypto.h" +#else +#include <openssl/evp.h> +#include <openssl/hmac.h> +#endif /* APPLE_COMMON_CRYPTO */ +#include <openssl/x509v3.h> +#endif /* NO_OPENSSL */ + /* * Let callers be aware of the constant return value; this can help * gcc with -Wuninitialized analysis. We restrict this trick to gcc, though, -- 1.8.4.rc1.384.g0976a17.dirty ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH 2/3] OS X: Fix redeclaration of die warning 2013-08-05 15:59 ` [PATCH 2/3] OS X: Fix redeclaration of die warning Brian Gernhardt @ 2013-08-05 16:17 ` Jeremy Huddleston Sequoia 2013-08-05 18:00 ` Junio C Hamano 1 sibling, 0 replies; 12+ messages in thread From: Jeremy Huddleston Sequoia @ 2013-08-05 16:17 UTC (permalink / raw) To: Brian Gernhardt; +Cc: Git List, Junio C Hamano [-- Attachment #1: Type: text/plain, Size: 2152 bytes --] Thanks Brian, Reviewed-by: Jeremy Huddleston Sequoia <jeremyhu@apple.com> On Aug 5, 2013, at 8:59, Brian Gernhardt <brian@gernhardtsoftware.com> wrote: > compat/apple-common-crypto.h uses die() in one of its macros, but was > included in git-compat-util.h before the definition of die. > > Fix by simply moving the relevant block after the die/error/warning > declarations. > > Signed-off-by: Brian Gernhardt <brian@gernhardtsoftware.com> > --- > > Not sure if this is the best place to move it to, but it's the earliest it can > be in the file without causing errors. (Namely that clang has to guess what > die() means in apple-common-crypto.h and guesses differently than the actual > definition.) > > git-compat-util.h | 20 ++++++++++---------- > 1 file changed, 10 insertions(+), 10 deletions(-) > > diff --git a/git-compat-util.h b/git-compat-util.h > index af5f6bb..d60e28d 100644 > --- a/git-compat-util.h > +++ b/git-compat-util.h > @@ -129,16 +129,6 @@ > #include <poll.h> > #endif > > -#ifndef NO_OPENSSL > -#ifdef APPLE_COMMON_CRYPTO > -#include "compat/apple-common-crypto.h" > -#else > -#include <openssl/evp.h> > -#include <openssl/hmac.h> > -#endif /* APPLE_COMMON_CRYPTO */ > -#include <openssl/x509v3.h> > -#endif /* NO_OPENSSL */ > - > #if defined(__MINGW32__) > /* pull in Windows compatibility stuff */ > #include "compat/mingw.h" > @@ -340,6 +330,16 @@ extern NORETURN void die_errno(const char *err, ...) __attribute__((format (prin > extern int error(const char *err, ...) __attribute__((format (printf, 1, 2))); > extern void warning(const char *err, ...) __attribute__((format (printf, 1, 2))); > > +#ifndef NO_OPENSSL > +#ifdef APPLE_COMMON_CRYPTO > +#include "compat/apple-common-crypto.h" > +#else > +#include <openssl/evp.h> > +#include <openssl/hmac.h> > +#endif /* APPLE_COMMON_CRYPTO */ > +#include <openssl/x509v3.h> > +#endif /* NO_OPENSSL */ > + > /* > * Let callers be aware of the constant return value; this can help > * gcc with -Wuninitialized analysis. We restrict this trick to gcc, though, > -- > 1.8.4.rc1.384.g0976a17.dirty > [-- Attachment #2: smime.p7s --] [-- Type: application/pkcs7-signature, Size: 4136 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 2/3] OS X: Fix redeclaration of die warning 2013-08-05 15:59 ` [PATCH 2/3] OS X: Fix redeclaration of die warning Brian Gernhardt 2013-08-05 16:17 ` Jeremy Huddleston Sequoia @ 2013-08-05 18:00 ` Junio C Hamano 2013-08-06 11:30 ` David Aguilar 1 sibling, 1 reply; 12+ messages in thread From: Junio C Hamano @ 2013-08-05 18:00 UTC (permalink / raw) To: Brian Gernhardt; +Cc: Git List, Jeremy Huddleston Brian Gernhardt <brian@gernhardtsoftware.com> writes: > compat/apple-common-crypto.h uses die() in one of its macros, but was > included in git-compat-util.h before the definition of die. > > Fix by simply moving the relevant block after the die/error/warning > declarations. Puzzled. What needs fixing??? Ahh, that one is not just making #define macros, but defining static inline functions. I wonder if they need to be static inlines to be duplicated at each call sites in the first place. Wouldn't it be better to create a compat/something.c file to be linked with? > Signed-off-by: Brian Gernhardt <brian@gernhardtsoftware.com> > --- > > Not sure if this is the best place to move it to, but it's the earliest it can > be in the file without causing errors. (Namely that clang has to guess what > die() means in apple-common-crypto.h and guesses differently than the actual > definition.) > > git-compat-util.h | 20 ++++++++++---------- > 1 file changed, 10 insertions(+), 10 deletions(-) > > diff --git a/git-compat-util.h b/git-compat-util.h > index af5f6bb..d60e28d 100644 > --- a/git-compat-util.h > +++ b/git-compat-util.h > @@ -129,16 +129,6 @@ > #include <poll.h> > #endif > > -#ifndef NO_OPENSSL > -#ifdef APPLE_COMMON_CRYPTO > -#include "compat/apple-common-crypto.h" > -#else > -#include <openssl/evp.h> > -#include <openssl/hmac.h> > -#endif /* APPLE_COMMON_CRYPTO */ > -#include <openssl/x509v3.h> > -#endif /* NO_OPENSSL */ > - > #if defined(__MINGW32__) > /* pull in Windows compatibility stuff */ > #include "compat/mingw.h" > @@ -340,6 +330,16 @@ extern NORETURN void die_errno(const char *err, ...) __attribute__((format (prin > extern int error(const char *err, ...) __attribute__((format (printf, 1, 2))); > extern void warning(const char *err, ...) __attribute__((format (printf, 1, 2))); > > +#ifndef NO_OPENSSL > +#ifdef APPLE_COMMON_CRYPTO > +#include "compat/apple-common-crypto.h" > +#else > +#include <openssl/evp.h> > +#include <openssl/hmac.h> > +#endif /* APPLE_COMMON_CRYPTO */ > +#include <openssl/x509v3.h> > +#endif /* NO_OPENSSL */ > + > /* > * Let callers be aware of the constant return value; this can help > * gcc with -Wuninitialized analysis. We restrict this trick to gcc, though, ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 2/3] OS X: Fix redeclaration of die warning 2013-08-05 18:00 ` Junio C Hamano @ 2013-08-06 11:30 ` David Aguilar 0 siblings, 0 replies; 12+ messages in thread From: David Aguilar @ 2013-08-06 11:30 UTC (permalink / raw) To: Junio C Hamano; +Cc: Brian Gernhardt, Git List, Jeremy Huddleston On Mon, Aug 5, 2013 at 11:00 AM, Junio C Hamano <gitster@pobox.com> wrote: > Brian Gernhardt <brian@gernhardtsoftware.com> writes: > >> compat/apple-common-crypto.h uses die() in one of its macros, but was >> included in git-compat-util.h before the definition of die. >> >> Fix by simply moving the relevant block after the die/error/warning >> declarations. > > Puzzled. What needs fixing??? > > Ahh, that one is not just making #define macros, but defining static > inline functions. > > I wonder if they need to be static inlines to be duplicated at each > call sites in the first place. Wouldn't it be better to create a > compat/something.c file to be linked with? IMO it's not worth it right now because there's only a single call site (imap-send). The moment another call site is introduced then compat/apple-common-crypto.c would be the natural home for it. -- David ^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH 3/3] t5551: Remove header from curl cookie file 2013-08-05 15:59 [PATCH 0/3] Fixes for OS X Brian Gernhardt 2013-08-05 15:59 ` [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 Brian Gernhardt 2013-08-05 15:59 ` [PATCH 2/3] OS X: Fix redeclaration of die warning Brian Gernhardt @ 2013-08-05 15:59 ` Brian Gernhardt 2013-08-06 0:29 ` Dave Borowitz 2 siblings, 1 reply; 12+ messages in thread From: Brian Gernhardt @ 2013-08-05 15:59 UTC (permalink / raw) To: Git List; +Cc: Junio C Hamano, Dave Borowitz The URL included in the header appears to vary from curl version to curl version. Since we only care about the final few lines, only test them. However, make sure the blank line after the header is still included to make sure there are no extra cookie lines. Signed-off-by: Brian Gernhardt <brian@gernhardtsoftware.com> --- I suppose a sed invocation to strip out the URL or comments might be better, but this seemed simpler. t/t5551-http-fetch.sh | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/t/t5551-http-fetch.sh b/t/t5551-http-fetch.sh index 287d22b..8196af1 100755 --- a/t/t5551-http-fetch.sh +++ b/t/t5551-http-fetch.sh @@ -191,9 +191,6 @@ cat >cookies.txt <<EOF 127.0.0.1 FALSE /smart_cookies/ FALSE 0 othername othervalue EOF cat >expect_cookies.txt <<EOF -# Netscape HTTP Cookie File -# http://curl.haxx.se/docs/http-cookies.html -# This file was generated by libcurl! Edit at your own risk. 127.0.0.1 FALSE /smart_cookies/ FALSE 0 othername othervalue 127.0.0.1 FALSE /smart_cookies/repo.git/info/ FALSE 0 name value @@ -202,7 +199,8 @@ test_expect_success 'cookies stored in http.cookiefile when http.savecookies set git config http.cookiefile cookies.txt && git config http.savecookies true && git ls-remote $HTTPD_URL/smart_cookies/repo.git master && - test_cmp expect_cookies.txt cookies.txt + tail -3 cookies.txt > cookies_tail.txt + test_cmp expect_cookies.txt cookies_tail.txt ' test -n "$GIT_TEST_LONG" && test_set_prereq EXPENSIVE -- 1.8.4.rc1.384.g0976a17.dirty ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH 3/3] t5551: Remove header from curl cookie file 2013-08-05 15:59 ` [PATCH 3/3] t5551: Remove header from curl cookie file Brian Gernhardt @ 2013-08-06 0:29 ` Dave Borowitz 0 siblings, 0 replies; 12+ messages in thread From: Dave Borowitz @ 2013-08-06 0:29 UTC (permalink / raw) To: Brian Gernhardt; +Cc: Git List, Junio C Hamano On Mon, Aug 5, 2013 at 8:59 AM, Brian Gernhardt <brian@gernhardtsoftware.com> wrote: > > The URL included in the header appears to vary from curl version to > curl version. Since we only care about the final few lines, only test > them. However, make sure the blank line after the header is still > included to make sure there are no extra cookie lines. > > Signed-off-by: Brian Gernhardt <brian@gernhardtsoftware.com> > --- > > I suppose a sed invocation to strip out the URL or comments might be better, > but this seemed simpler. > > t/t5551-http-fetch.sh | 6 ++---- > 1 file changed, 2 insertions(+), 4 deletions(-) > > diff --git a/t/t5551-http-fetch.sh b/t/t5551-http-fetch.sh > index 287d22b..8196af1 100755 > --- a/t/t5551-http-fetch.sh > +++ b/t/t5551-http-fetch.sh > @@ -191,9 +191,6 @@ cat >cookies.txt <<EOF > 127.0.0.1 FALSE /smart_cookies/ FALSE 0 othername othervalue > EOF > cat >expect_cookies.txt <<EOF > -# Netscape HTTP Cookie File > -# http://curl.haxx.se/docs/http-cookies.html > -# This file was generated by libcurl! Edit at your own risk. > > 127.0.0.1 FALSE /smart_cookies/ FALSE 0 othername othervalue > 127.0.0.1 FALSE /smart_cookies/repo.git/info/ FALSE 0 name value > @@ -202,7 +199,8 @@ test_expect_success 'cookies stored in http.cookiefile when http.savecookies set > git config http.cookiefile cookies.txt && > git config http.savecookies true && > git ls-remote $HTTPD_URL/smart_cookies/repo.git master && > - test_cmp expect_cookies.txt cookies.txt > + tail -3 cookies.txt > cookies_tail.txt Would it make more sense to ignore comments entirely? I.e. instead of taking the tail, pipe through sed 's/#.*//'. Thanks for catching this by the way; you can probably guess that I only checked with a single curl version. > > + test_cmp expect_cookies.txt cookies_tail.txt > ' > > test -n "$GIT_TEST_LONG" && test_set_prereq EXPENSIVE > -- > 1.8.4.rc1.384.g0976a17.dirty > ^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2013-08-06 17:25 UTC | newest] Thread overview: 12+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2013-08-05 15:59 [PATCH 0/3] Fixes for OS X Brian Gernhardt 2013-08-05 15:59 ` [PATCH 1/3] Makefile: Fix APPLE_COMMON_CRYPTO with BLK_SHA1 Brian Gernhardt 2013-08-05 16:16 ` Jeremy Huddleston Sequoia 2013-08-05 17:52 ` Junio C Hamano 2013-08-06 11:25 ` David Aguilar 2013-08-06 17:24 ` Junio C Hamano 2013-08-05 15:59 ` [PATCH 2/3] OS X: Fix redeclaration of die warning Brian Gernhardt 2013-08-05 16:17 ` Jeremy Huddleston Sequoia 2013-08-05 18:00 ` Junio C Hamano 2013-08-06 11:30 ` David Aguilar 2013-08-05 15:59 ` [PATCH 3/3] t5551: Remove header from curl cookie file Brian Gernhardt 2013-08-06 0:29 ` Dave Borowitz
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).