test644: verify --xattr (with redirect)

This commit is contained in:
Daniel Stenberg 2022-10-19 11:40:11 +02:00
parent 3ab3c16b2c
commit f5e5384ec3
No known key found for this signature in database
GPG key ID: 5CC908FDB71E12C2
9 changed files with 111 additions and 22 deletions

View file

@ -22,17 +22,6 @@
*
***************************************************************************/
#include "tool_setup.h"
#ifdef HAVE_FSETXATTR
# include <sys/xattr.h> /* header from libc, not from libattr */
# define USE_XATTR
#elif (defined(__FreeBSD_version) && (__FreeBSD_version > 500000)) || \
defined(__MidnightBSD_version)
# include <sys/types.h>
# include <sys/extattr.h>
# define USE_XATTR
#endif
#include "tool_xattr.h"
#include "memdebug.h" /* keep this as LAST include */
@ -144,13 +133,4 @@ int fwrite_xattr(CURL *curl, const char *url, int fd)
}
return err;
}
#else
int fwrite_xattr(CURL *curl, const char *url, int fd)
{
(void)curl;
(void)url;
(void)fd;
return 0;
}
#endif

View file

@ -25,6 +25,21 @@
***************************************************************************/
#include "tool_setup.h"
#ifdef HAVE_FSETXATTR
# include <sys/xattr.h> /* header from libc, not from libattr */
# define USE_XATTR
#elif (defined(__FreeBSD_version) && (__FreeBSD_version > 500000)) || \
defined(__MidnightBSD_version)
# include <sys/types.h>
# include <sys/extattr.h>
# define USE_XATTR
#endif
#ifdef USE_XATTR
int fwrite_xattr(CURL *curl, const char *url, int fd);
#else
#define fwrite_xattr(a,b,c) 0
#endif
#endif /* HEADER_CURL_TOOL_XATTR_H */

View file

@ -447,6 +447,7 @@ Features testable here are:
- `win32`
- `wolfssh`
- `wolfssl`
- `xattr`
as well as each protocol that curl supports. A protocol only needs to be
specified if it is different from the server (useful when the server is

View file

@ -91,7 +91,7 @@ test608 test609 test610 test611 test612 test613 test614 test615 test616 \
test617 test618 test619 test620 test621 test622 test623 test624 test625 \
test626 test627 test628 test629 test630 test631 test632 test633 test634 \
test635 test636 test637 test638 test639 test640 test641 test642 \
test643 test645 test646 test647 test648 test649 test650 test651 \
test643 test644 test645 test646 test647 test648 test649 test650 test651 \
test652 test653 test654 test655 test656 test658 test659 test660 test661 \
test662 test663 test664 test665 test666 test667 test668 test669 \
test670 test671 test672 test673 test674 test675 test676 test677 test678 \

85
tests/data/test644 Normal file
View file

@ -0,0 +1,85 @@
<testcase>
<info>
<keywords>
HTTP
xattr
</keywords>
</info>
#
# Server-side
<reply>
<data nocheck="yes">
HTTP/1.1 301 OK
Date: Tue, 09 Nov 2010 14:49:00 GMT
Server: test-server/fake
Last-Modified: Tue, 13 Jun 2000 12:10:00 GMT
ETag: "21025-dc7-39462498"
Accept-Ranges: bytes
Content-Length: 6
Connection: close
Content-Type: fake/data
Funny-head: yesyes
Location: data/%TESTNUMBER0002.txt?coolsite=yes
-foo-
</data>
<data2 nocheck="yes">
HTTP/1.1 200 OK
Date: Tue, 09 Nov 2010 14:49:00 GMT
Server: test-server/real
Last-Modified: Tue, 13 Jun 2000 12:10:00 GMT
ETag: "21025-dc7-39462498"
Accept-Ranges: bytes
Content-Length: 6
Connection: close
Content-Type: text/html
Funny-head: yesyes
-foo-
</data2>
</reply>
#
# Client-side
<client>
<server>
http
</server>
<features>
debug
xattr
</features>
# simulate the xattr operations
<setenv>
CURL_FAKE_XATTR=1
</setenv>
<name>
--xattr with redirect
</name>
<command>
http://%HOSTIP:%HTTPPORT/%TESTNUMBER --xattr -L -o log/out%TESTNUMBER
</command>
</client>
#
# Verify data after the test has been "shot"
<verify>
<protocol>
GET /%TESTNUMBER HTTP/1.1
Host: %HOSTIP:%HTTPPORT
User-Agent: curl/%VERSION
Accept: */*
GET /data/%TESTNUMBER0002.txt?coolsite=yes HTTP/1.1
Host: %HOSTIP:%HTTPPORT
User-Agent: curl/%VERSION
Accept: */*
</protocol>
<stdout mode="text">
user.mime_type => text/html
user.xdg.origin.url => http://%HOSTIP:%HTTPPORT/%TESTNUMBER
</stdout>
</verify>
</testcase>

View file

@ -2958,7 +2958,7 @@ sub setupfeatures {
$feature{"verbose-strings"} = 1;
$feature{"wakeup"} = 1;
$feature{"headers-api"} = 1;
$feature{"xattr"} = 1;
}
#######################################################################

View file

@ -36,6 +36,7 @@ function(SETUP_EXECUTABLE TEST_NAME) # ARGN are the files in the test
${CURL_SOURCE_DIR}/lib # To be able to reach "curl_setup_once.h"
${CURL_BINARY_DIR}/lib # To be able to reach "curl_config.h"
${CURL_BINARY_DIR}/include # To be able to reach "curl/curl.h"
${CURL_SOURCE_DIR}/src # To be able to reach "tool_xattr.h"
)
if(USE_ARES)
include_directories(${CARES_INCLUDE_DIR})

View file

@ -36,6 +36,9 @@ AM_CPPFLAGS = -I$(top_srcdir)/include \
-I$(top_builddir)/lib \
-I$(top_srcdir)/lib
disabled_CPPFLAGS = $(AM_CPPFLAGS) \
-I$(top_srcdir)/src
# Prevent LIBS from being used for all link targets
LIBS = $(BLANK_AT_MAKETIME)

View file

@ -33,6 +33,7 @@
#include "curl_setup.h"
#include "multihandle.h" /* for ENABLE_WAKEUP */
#include "tool_xattr.h" /* for USE_XATTR */
#include <stdio.h>
static const char *disabled[]={
@ -74,6 +75,9 @@ static const char *disabled[]={
#endif
#ifdef CURL_DISABLE_HEADERS_API
"headers-api",
#endif
#ifndef USE_XATTR
"xattr",
#endif
NULL
};