blob: 54e360a46fd7ff5679443916fb0ec188cc5138d2 [file] [log] [blame]
lh9ed821d2023-04-07 01:36:19 -07001<testcase>
2<info>
3<keywords>
4HTTP
5HTTP GET
6cookies
7cookiejar
8</keywords>
9</info>
10# Server-side
11<reply>
12<data>
13HTTP/1.1 200 OK
14Date: Thu, 09 Nov 2010 14:49:00 GMT
15Server: test-server/fake
16Content-Length: 4
17Content-Type: text/html
18Funny-head: yesyes
19Set-Cookie: foobar=name; domain=anything.com; path=/ ; secure
20Set-Cookie:ismatch=this ; domain=127.0.0.1; path=/silly/
21Set-Cookie: overwrite=this ; domain=127.0.0.1; path=/overwrite/
22Set-Cookie: overwrite=this2 ; domain=127.0.0.1; path=/overwrite
23Set-Cookie: sec1value=secure1 ; domain=127.0.0.1; path=/secure1/ ; secure
24Set-Cookie: sec2value=secure2 ; domain=127.0.0.1; path=/secure2/ ; secure=
25Set-Cookie: sec3value=secure3 ; domain=127.0.0.1; path=/secure3/ ; secure=
26Set-Cookie: sec4value=secure4 ; secure=; domain=127.0.0.1; path=/secure4/ ;
27Set-Cookie: sec5value=secure5 ; secure; domain=127.0.0.1; path=/secure5/ ;
28Set-Cookie: sec6value=secure6 ; secure ; domain=127.0.0.1; path=/secure6/ ;
29Set-Cookie: sec7value=secure7 ; secure ; domain=127.0.0.1; path=/secure7/ ;
30Set-Cookie: sec8value=secure8 ; secure= ; domain=127.0.0.1; path=/secure8/ ;
31Set-Cookie: secure=very1 ; secure=; domain=127.0.0.1; path=/secure9/;
32Set-Cookie: httpo1=value1 ; domain=127.0.0.1; path=/p1/; httponly
33Set-Cookie: httpo2=value2 ; domain=127.0.0.1; path=/p2/; httponly=
34Set-Cookie: httpo3=value3 ; httponly; domain=127.0.0.1; path=/p3/;
35Set-Cookie: httpo4=value4 ; httponly=; domain=127.0.0.1; path=/p4/;
36Set-Cookie: httponly=myvalue1 ; domain=127.0.0.1; path=/p4/; httponly
37Set-Cookie: httpandsec=myvalue2 ; domain=127.0.0.1; path=/p4/; httponly; secure
38Set-Cookie: httpandsec2=myvalue3; domain=127.0.0.1; path=/p4/; httponly=; secure
39Set-Cookie: httpandsec3=myvalue4 ; domain=127.0.0.1; path=/p4/; httponly; secure=
40Set-Cookie: httpandsec4=myvalue5 ; domain=127.0.0.1; path=/p4/; httponly=; secure=
41Set-Cookie: httpandsec5=myvalue6 ; domain=127.0.0.1; path=/p4/; secure; httponly=
42Set-Cookie: httpandsec6=myvalue7 ; domain=127.0.0.1; path=/p4/; secure=; httponly=
43Set-Cookie: httpandsec7=myvalue8 ; domain=127.0.0.1; path=/p4/; secure; httponly
44Set-Cookie: httpandsec8=myvalue9; domain=127.0.0.1; path=/p4/; secure=; httponly
45Set-Cookie: partmatch=present; domain=127.0.0.1 ; path=/;
46Set-Cookie:eat=this; domain=moo.foo.moo;
47Set-Cookie: eat=this-too; domain=.foo.moo;
48Set-Cookie: nodomainnovalue
49Set-Cookie: nodomain=value; expires=Fri Feb 2 11:56:27 GMT 2035
50Set-Cookie: novalue; domain=reallysilly
51Set-Cookie: test=yes; domain=foo.com; expires=Sat Feb 2 11:56:27 GMT 2030
52Set-Cookie: test2=yes; domain=se; expires=Sat Feb 2 11:56:27 GMT 2030
53Set-Cookie: magic=yessir; path=/silly/; HttpOnly
54Set-Cookie: blexp=yesyes; domain=127.0.0.1; domain=127.0.0.1; expiry=totally bad;
55Set-Cookie: partialip=nono; domain=.0.0.1;
56Set-Cookie: withspaces= yes within and around ;
57Set-Cookie: withspaces2 =before equals;
58Set-Cookie: prespace= yes before;
59Set-Cookie: securewithspace=after ; secure =
60
61boo
62</data>
63</reply>
64
65# Client-side
66<client>
67<server>
68http
69</server>
70 <name>
71HTTP with weirdly formatted cookies and cookiejar storage
72 </name>
73# Explicitly set the time zone to a known good one, in case the user is
74# using one of the 'right' zones that take into account leap seconds
75# which causes the cookie expiry times to be different.
76<setenv>
77TZ=GMT
78</setenv>
79 <command>
80http://%HOSTIP:%HTTPPORT/we/want/31 -b none -c log/jar31.txt
81</command>
82<precheck>
83perl -e "print 'Test requires default test server host' if ( '%HOSTIP' ne '127.0.0.1' );"
84</precheck>
85</client>
86
87# Verify data after the test has been "shot"
88<verify>
89<strip>
90^User-Agent:.*
91</strip>
92<protocol>
93GET /we/want/31 HTTP/1.1
94Host: %HOSTIP:%HTTPPORT
95Accept: */*
96
97</protocol>
98<file name="log/jar31.txt" mode="text">
99# Netscape HTTP Cookie File
100# https://curl.haxx.se/docs/http-cookies.html
101# This file was generated by libcurl! Edit at your own risk.
102
103127.0.0.1 FALSE /silly/ FALSE 0 ismatch this
104127.0.0.1 FALSE /overwrite FALSE 0 overwrite this2
105127.0.0.1 FALSE /secure1/ TRUE 0 sec1value secure1
106127.0.0.1 FALSE /secure2/ TRUE 0 sec2value secure2
107127.0.0.1 FALSE /secure3/ TRUE 0 sec3value secure3
108127.0.0.1 FALSE /secure4/ TRUE 0 sec4value secure4
109127.0.0.1 FALSE /secure5/ TRUE 0 sec5value secure5
110127.0.0.1 FALSE /secure6/ TRUE 0 sec6value secure6
111127.0.0.1 FALSE /secure7/ TRUE 0 sec7value secure7
112127.0.0.1 FALSE /secure8/ TRUE 0 sec8value secure8
113127.0.0.1 FALSE /secure9/ TRUE 0 secure very1
114#HttpOnly_127.0.0.1 FALSE /p1/ FALSE 0 httpo1 value1
115#HttpOnly_127.0.0.1 FALSE /p2/ FALSE 0 httpo2 value2
116#HttpOnly_127.0.0.1 FALSE /p3/ FALSE 0 httpo3 value3
117#HttpOnly_127.0.0.1 FALSE /p4/ FALSE 0 httpo4 value4
118#HttpOnly_127.0.0.1 FALSE /p4/ FALSE 0 httponly myvalue1
119#HttpOnly_127.0.0.1 FALSE /p4/ TRUE 0 httpandsec myvalue2
120#HttpOnly_127.0.0.1 FALSE /p4/ TRUE 0 httpandsec2 myvalue3
121#HttpOnly_127.0.0.1 FALSE /p4/ TRUE 0 httpandsec3 myvalue4
122#HttpOnly_127.0.0.1 FALSE /p4/ TRUE 0 httpandsec4 myvalue5
123#HttpOnly_127.0.0.1 FALSE /p4/ TRUE 0 httpandsec5 myvalue6
124#HttpOnly_127.0.0.1 FALSE /p4/ TRUE 0 httpandsec6 myvalue7
125#HttpOnly_127.0.0.1 FALSE /p4/ TRUE 0 httpandsec7 myvalue8
126#HttpOnly_127.0.0.1 FALSE /p4/ TRUE 0 httpandsec8 myvalue9
127127.0.0.1 FALSE / FALSE 0 partmatch present
128127.0.0.1 FALSE /we/want/ FALSE 2054030187 nodomain value
129#HttpOnly_127.0.0.1 FALSE /silly/ FALSE 0 magic yessir
130127.0.0.1 FALSE /we/want/ FALSE 0 blexp yesyes
131127.0.0.1 FALSE /we/want/ FALSE 0 withspaces yes within and around
132127.0.0.1 FALSE /we/want/ FALSE 0 withspaces2 before equals
133127.0.0.1 FALSE /we/want/ FALSE 0 prespace yes before
134127.0.0.1 FALSE /we/want/ TRUE 0 securewithspace after
135</file>
136</verify>
137</testcase>