123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190 |
- <testcase>
- <info>
- <keywords>
- HTTP
- HTTP GET
- cookies
- cookiejar
- </keywords>
- </info>
- # Server-side
- #
- # The cookies set come in two versions. This is because when curl is built
- # with Hyper, the API provides the headers already "sanitized" so we cannot
- # compare with the exact server contents unless it too sends the data
- # "clean".
- <reply>
- <data>
- HTTP/1.1 200 OK
- Date: Tue, 09 Nov 2010 14:49:00 GMT
- Server: test-server/fake
- Content-Length: 4
- Content-Type: text/html
- Funny-head: yesyes
- Set-Cookie: blankdomain=sure; domain=; path=/
- %if !hyper
- Set-Cookie: foobar=name; domain=anything.com; path=/ ; secure
- Set-Cookie:ismatch=this ; domain=test31.curl; path=/silly/
- Set-Cookie: overwrite=this ; domain=test31.curl; path=/overwrite/
- Set-Cookie: overwrite=this2 ; domain=test31.curl; path=/overwrite
- Set-Cookie: sec1value=secure1 ; domain=test31.curl; path=/secure1/ ; secure
- Set-Cookie: sec2value=secure2 ; domain=test31.curl; path=/secure2/ ; secure=
- Set-Cookie: sec3value=secure3 ; domain=test31.curl; path=/secure3/ ; secure=
- Set-Cookie: sec4value=secure4 ; secure=; domain=test31.curl; path=/secure4/ ;
- Set-Cookie: sec5value=secure5 ; secure; domain=test31.curl; path=/secure5/ ;
- Set-Cookie: sec6value=secure6 ; secure ; domain=test31.curl; path=/secure6/ ;
- Set-Cookie: sec7value=secure7 ; secure ; domain=test31.curl; path=/secure7/ ;
- Set-Cookie: sec8value=secure8 ; secure= ; domain=test31.curl; path=/secure8/ ;
- Set-Cookie: secure=very1 ; secure=; domain=test31.curl; path=/secure9/;
- Set-Cookie: httpo1=value1 ; domain=test31.curl; path=/p1/; httponly
- Set-Cookie: httpo2=value2 ; domain=test31.curl; path=/p2/; httponly=
- Set-Cookie: httpo3=value3 ; httponly; domain=test31.curl; path=/p3/;
- Set-Cookie: httpo4=value4 ; httponly=; domain=test31.curl; path=/p4/;
- Set-Cookie: httponly=myvalue1 ; domain=test31.curl; path=/p4/; httponly
- Set-Cookie: httpandsec=myvalue2 ; domain=test31.curl; path=/p4/; httponly; secure
- Set-Cookie: httpandsec2=myvalue3; domain=test31.curl; path=/p4/; httponly=; secure
- Set-Cookie: httpandsec3=myvalue4 ; domain=test31.curl; path=/p4/; httponly; secure=
- Set-Cookie: httpandsec4=myvalue5 ; domain=test31.curl; path=/p4/; httponly=; secure=
- Set-Cookie: httpandsec5=myvalue6 ; domain=test31.curl; path=/p4/; secure; httponly=
- Set-Cookie: httpandsec6=myvalue7 ; domain=test31.curl; path=/p4/; secure=; httponly=
- Set-Cookie: httpandsec7=myvalue8 ; domain=test31.curl; path=/p4/; secure; httponly
- Set-Cookie: httpandsec8=myvalue9; domain=test31.curl; path=/p4/; secure=; httponly
- Set-Cookie: partmatch=present; domain=test31.curl ; path=/;
- Set-Cookie:eat=this; domain=moo.foo.moo;
- Set-Cookie: eat=this-too; domain=.foo.moo;
- Set-Cookie: nodomainnovalue
- %if large-time
- Set-Cookie: nodomain=value; expires=Fri Feb 13 11:56:27 GMT 2525
- Set-Cookie: novalue; domain=reallysilly
- Set-Cookie: test=yes; domain=foo.com; expires=Sat Feb 2 11:56:27 GMT 2525
- Set-Cookie: test2=yes; domain=se; expires=Sat Feb 2 11:56:27 GMT 2525
- %else
- Set-Cookie: nodomain=value; expires=Fri Feb 13 11:56:27 GMT 2037
- Set-Cookie: novalue; domain=reallysilly
- Set-Cookie: test=yes; domain=foo.com; expires=Sat Feb 2 11:56:27 GMT 2030
- Set-Cookie: test2=yes; domain=se; expires=Sat Feb 2 11:56:27 GMT 2030
- %endif
- Set-Cookie: magic=yessir; path=/silly/; HttpOnly
- Set-Cookie: blexp=yesyes; domain=test31.curl; domain=test31.curl; expiry=totally bad;
- Set-Cookie: partialip=nono; domain=.0.0.1;
- Set-Cookie: withspaces= yes within and around ;
- Set-Cookie: withspaces2 =before equals;
- Set-Cookie: prespace= yes before;
- Set-Cookie: securewithspace=after ; secure =
- %else
- Set-Cookie: foobar=name; domain=anything.com; path=/ ; secure
- Set-Cookie: ismatch=this ; domain=test31.curl; path=/silly/
- Set-Cookie: overwrite=this ; domain=test31.curl; path=/overwrite/
- Set-Cookie: overwrite=this2 ; domain=test31.curl; path=/overwrite
- Set-Cookie: sec1value=secure1 ; domain=test31.curl; path=/secure1/ ; secure
- Set-Cookie: sec2value=secure2 ; domain=test31.curl; path=/secure2/ ; secure=
- Set-Cookie: sec3value=secure3 ; domain=test31.curl; path=/secure3/ ; secure=
- Set-Cookie: sec4value=secure4 ; secure=; domain=test31.curl; path=/secure4/ ;
- Set-Cookie: sec5value=secure5 ; secure; domain=test31.curl; path=/secure5/ ;
- Set-Cookie: sec6value=secure6 ; secure ; domain=test31.curl; path=/secure6/ ;
- Set-Cookie: sec7value=secure7 ; secure ; domain=test31.curl; path=/secure7/ ;
- Set-Cookie: sec8value=secure8 ; secure= ; domain=test31.curl; path=/secure8/ ;
- Set-Cookie: secure=very1 ; secure=; domain=test31.curl; path=/secure9/;
- Set-Cookie: httpo1=value1 ; domain=test31.curl; path=/p1/; httponly
- Set-Cookie: httpo2=value2 ; domain=test31.curl; path=/p2/; httponly=
- Set-Cookie: httpo3=value3 ; httponly; domain=test31.curl; path=/p3/;
- Set-Cookie: httpo4=value4 ; httponly=; domain=test31.curl; path=/p4/;
- Set-Cookie: httponly=myvalue1 ; domain=test31.curl; path=/p4/; httponly
- Set-Cookie: httpandsec=myvalue2 ; domain=test31.curl; path=/p4/; httponly; secure
- Set-Cookie: httpandsec2=myvalue3; domain=test31.curl; path=/p4/; httponly=; secure
- Set-Cookie: httpandsec3=myvalue4 ; domain=test31.curl; path=/p4/; httponly; secure=
- Set-Cookie: httpandsec4=myvalue5 ; domain=test31.curl; path=/p4/; httponly=; secure=
- Set-Cookie: httpandsec5=myvalue6 ; domain=test31.curl; path=/p4/; secure; httponly=
- Set-Cookie: httpandsec6=myvalue7 ; domain=test31.curl; path=/p4/; secure=; httponly=
- Set-Cookie: httpandsec7=myvalue8 ; domain=test31.curl; path=/p4/; secure; httponly
- Set-Cookie: httpandsec8=myvalue9; domain=test31.curl; path=/p4/; secure=; httponly
- Set-Cookie: partmatch=present; domain=test31.curl ; path=/;
- Set-Cookie: eat=this; domain=moo.foo.moo;
- Set-Cookie: eat=this-too; domain=.foo.moo;
- Set-Cookie: nodomainnovalue
- %if large-time
- Set-Cookie: nodomain=value; expires=Fri Feb 13 11:56:27 GMT 2525
- Set-Cookie: novalue; domain=reallysilly
- Set-Cookie: test=yes; domain=foo.com; expires=Sat Feb 2 11:56:27 GMT 2525
- Set-Cookie: test2=yes; domain=se; expires=Sat Feb 2 11:56:27 GMT 2525
- %else
- Set-Cookie: nodomain=value; expires=Fri Feb 13 11:56:27 GMT 2037
- Set-Cookie: novalue; domain=reallysilly
- Set-Cookie: test=yes; domain=foo.com; expires=Sat Feb 2 11:56:27 GMT 2030
- Set-Cookie: test2=yes; domain=se; expires=Sat Feb 2 11:56:27 GMT 2030
- %endif
- Set-Cookie: magic=yessir; path=/silly/; HttpOnly
- Set-Cookie: blexp=yesyes; domain=test31.curl; domain=test31.curl; expiry=totally bad;
- Set-Cookie: partialip=nono; domain=.0.0.1;
- Set-Cookie: withspaces= yes within and around ;
- Set-Cookie: withspaces2 =before equals;
- Set-Cookie: prespace= yes before;
- Set-Cookie: securewithspace=after ; secure =
- %endif
- boo
- </data>
- </reply>
- # Client-side
- <client>
- <server>
- http
- </server>
- <name>
- HTTP with weirdly formatted cookies and cookiejar storage
- </name>
- # Explicitly set the time zone to a known good one, in case the user is
- # using one of the 'right' zones that take into account leap seconds
- # which causes the cookie expiry times to be different.
- <setenv>
- TZ=GMT
- </setenv>
- <command>
- http://test31.curl:%HTTPPORT/we/want/%TESTNUMBER -b none -c %LOGDIR/jar%TESTNUMBER.txt --resolve test31.curl:%HTTPPORT:127.0.0.1
- </command>
- <precheck>
- perl -e "print 'Test requires default test server host' if ( '%HOSTIP' ne '127.0.0.1' );"
- </precheck>
- <features>
- cookies
- </features>
- </client>
- # Verify data after the test has been "shot"
- <verify>
- <protocol>
- GET /we/want/%TESTNUMBER HTTP/1.1
- Host: test31.curl:%HTTPPORT
- User-Agent: curl/%VERSION
- Accept: */*
- </protocol>
- <file name="%LOGDIR/jar%TESTNUMBER.txt" mode="text">
- # Netscape HTTP Cookie File
- # https://curl.se/docs/http-cookies.html
- # This file was generated by libcurl! Edit at your own risk.
- test31.curl FALSE /we/want/ FALSE 0 prespace yes before
- test31.curl FALSE /we/want/ FALSE 0 withspaces2 before equals
- test31.curl FALSE /we/want/ FALSE 0 withspaces yes within and around
- .test31.curl TRUE /we/want/ FALSE 0 blexp yesyes
- #HttpOnly_test31.curl FALSE /silly/ FALSE 0 magic yessir
- %if large-time
- test31.curl FALSE /we/want/ FALSE 17517902187 nodomain value
- %else
- test31.curl FALSE /we/want/ FALSE 2118138987 nodomain value
- %endif
- .test31.curl TRUE / FALSE 0 partmatch present
- #HttpOnly_.test31.curl TRUE /p4/ FALSE 0 httponly myvalue1
- #HttpOnly_.test31.curl TRUE /p4/ FALSE 0 httpo4 value4
- #HttpOnly_.test31.curl TRUE /p3/ FALSE 0 httpo3 value3
- #HttpOnly_.test31.curl TRUE /p2/ FALSE 0 httpo2 value2
- #HttpOnly_.test31.curl TRUE /p1/ FALSE 0 httpo1 value1
- .test31.curl TRUE /overwrite FALSE 0 overwrite this2
- .test31.curl TRUE /silly/ FALSE 0 ismatch this
- test31.curl FALSE / FALSE 0 blankdomain sure
- </file>
- </verify>
- </testcase>
|