test31 5.6 KB

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