Expect a 404 for /show-version which no longer exists
[privoxy.git] / regression-tests.action
index c7d81e3..c55d7c5 100644 (file)
@@ -1,5 +1,5 @@
 #############################################################################
-# $Id: regression-tests.action,v 1.14 2008/07/31 04:47:33 ler762 Exp $
+# $Id: regression-tests.action,v 1.69 2017/01/23 13:06:31 fabiankeil Exp $
 #############################################################################
 #
 # This is a configuration file for Privoxy-Regression-Test
@@ -10,7 +10,7 @@
 #
 #############################################################################
 #
-# Copyright (c) 2007-2008 Fabian Keil <fk@fabiankeil.de>
+# Copyright (c) 2007-2017 Fabian Keil <fk@fabiankeil.de>
 #
 # Permission to use, copy, modify, and distribute this software for any
 # purpose with or without fee is hereby granted, provided that the above
 #############################################################################
 
 {{settings}}
-for-privoxy-version=3.0.9
+for-privoxy-version=3.0.27
 
 # Some dependencies Privoxy-Regression-Test should know about:
 #
-# Level 9 needs  = config line user-manual\s+(/|[A-Za-z]:)
+# Level  9 needs = config line user-manual\s+(\.?\.?/|[A-Za-z]:)
+# Level 12 needs = feature status FEATURE_CGI_EDIT_ACTIONS Yes
 # Level 12 needs = config line enable-edit-actions\s+1
+# Level 13 needs = feature status FEATURE_CONNECTION_KEEP_ALIVE Yes
+# Level 13 needs = config line keep-alive-timeout\s+(2[1-9]+|[3-9]\d+|1\d{2,})
+# Level 14 needs = feature status FEATURE_CONNECTION_KEEP_ALIVE No
+# Level 15 needs = config line connection-sharing\s+0
+# Level 16 needs = feature status FEATURE_CONNECTION_KEEP_ALIVE Yes
+# Level 16 needs = config line connection-sharing\s+1
+# Level 17 needs = feature status FEATURE_64_BIT_TIME_T Yes
+# Level 18 needs = feature status FEATURE_GRACEFUL_TERMINATION No
+# Level 19 needs = feature status FEATURE_GRACEFUL_TERMINATION Yes
+# Level 20 needs = feature status FEATURE_TOGGLE Yes
+# Level 21 needs = feature status FEATURE_TOGGLE No
+# Level 22 needs = config line enable-proxy-authentication-forwarding\s+0
+# Level 23 needs = config line enable-proxy-authentication-forwarding\s+1
+# Level 24 needs = feature status FEATURE_CLIENT_TAGS Yes
 
 #######################################################
 # Enable taggers to activate the tests on demand
@@ -55,14 +70,14 @@ TAG:^User-Agent: Privoxy-Regression-Test
 # Test accept-language{}.
 #######################################################
 
+{+hide-accept-language{en-gb}}
 # Set Header    = Accept-Language: de-de
 # Expect Header = Accept-Language: en-gb
-{+hide-accept-language{en-gb}}
 TAG:^hide-accept-language\{en-gb\}$
 
+{+hide-accept-language{block}}
 # Set Header    = Accept-Language: de-de
 # Expect Header = REMOVAL
-{+hide-accept-language{block}}
 TAG:^hide-accept-language\{block\}$
 
 #######################################################
@@ -72,44 +87,68 @@ TAG:^hide-accept-language\{block\}$
 # 2) conditional-forge
 # 3) forge
 # 4) block
-# 5) a parameter that looks like a valid fake referrer 
+# 5) a parameter that looks like a valid fake referrer
 # 6) a parameter that looks like an invalid fake referrer
 #######################################################
 
-# Set Header    = Referer: http://www.example.org/foo 
+{+hide-referrer{conditional-block}}
+# Set Header    = Referer: http://www.example.org/foo
 # Expect Header = REMOVAL
 #
 # Set Header    = Referer: http://p.p/foo
 # Expect Header = NO CHANGE
-{+hide-referrer{conditional-block}}
+#
+# Set Header    = Referer: p.p/
+# Expect Header = REMOVAL
+#
+# Set Header    = Referer: p
+# Expect Header = REMOVAL
+#
+# Set Header    = Referer: http://
+# Expect Header = REMOVAL
+#
+# Set Header    = Referer: https://p.p/
+# Expect Header = REMOVAL
 TAG:^hide-referrer\{conditional-block\}$
 
-# Set Header    = Referer: http://www.example.org/foo 
+{+hide-referrer{conditional-forge}}
+# Set Header    = Referer: http://www.example.org/foo
 # Expect Header = Referer: http://p.p/
 #
 # Set Header    = Referer: http://p.p/foo
 # Expect Header = NO CHANGE
-{+hide-referrer{conditional-forge}}
+#
+# Set Header    = Referer: p.p/
+# Expect Header = Referer: http://p.p/
+#
+# Set Header    = Referer: p
+# Expect Header = Referer: http://p.p/
+#
+# Set Header    = Referer: http://
+# Expect Header = Referer: http://p.p/
+#
+# Set Header    = Referer: https://p.p/
+# Expect Header = Referer: http://p.p/
 TAG:^hide-referrer\{conditional-forge\}$
 
-# Set Header    = Referer: http://www.example.org/foo 
-# Expect Header = Referer: http://p.p/
 {+hide-referrer{forge}}
+# Set Header    = Referer: http://www.example.org/foo
+# Expect Header = Referer: http://p.p/
 TAG:^hide-referrer\{forge\}$
 
-# Set Header    = Referer: http://www.example.org/foo 
-# Expect Header = REMOVAL
 {+hide-referrer{block}}
+# Set Header    = Referer: http://www.example.org/foo
+# Expect Header = REMOVAL
 TAG:^hide-referrer\{block\}$
 
-# Set Header    = Referer: http://www.example.org/foo 
-# Expect Header = Referer: invalid
 {+hide-referrer{invalid}}
+# Set Header    = Referer: http://www.example.org/foo
+# Expect Header = Referer: invalid
 TAG:^hide-referrer\{invalid\}$
 
+{+hide-referrer{http://www.privoxy.org/}}
 # Set Header    = Referer: http://www.example.org/asdf
 # Expect Header = Referer: http://www.privoxy.org/
-{+hide-referrer{http://www.privoxy.org/}}
 TAG:^hide-referrer\{http://www.privoxy.org/\}$
 
 #{+hide-referrer{}}
@@ -119,20 +158,20 @@ TAG:^hide-referrer\{http://www.privoxy.org/\}$
 # Test hide-user-agent{}.
 #######################################################
 
+{+hide-user-agent{Mozilla/5.0 (X11; U; FreeBSD alpha; en-GB; rv:1.8.1.6) Gecko/20070913 Firefox/2.0.0.6}}
 # Set Header    = User-Agent: Mozilla/5.0 (X11; U; NetBSD i386; de-CH; rv:1.8.1.6) Gecko/20070806 Firefox/2.0.0.6
 # Expect Header = User-Agent: Mozilla/5.0 (X11; U; FreeBSD alpha; en-GB; rv:1.8.1.6) Gecko/20070913 Firefox/2.0.0.6
-{+hide-user-agent{Mozilla/5.0 (X11; U; FreeBSD alpha; en-GB; rv:1.8.1.6) Gecko/20070913 Firefox/2.0.0.6}}
 TAG:^hide-user-agent\{Mozilla/5\.0 \(X11; U; FreeBSD alpha; en-GB; rv:1\.8\.1\.6\) Gecko/20070913 Firefox/2\.0\.0\.6\}$
 
+{+hide-user-agent{block}}
 # XXX: Check the code that is tested here.
 # Set Header = ua-blah: blah
 # Expect Header = REMOVAL
-{+hide-user-agent{block}}
 TAG:^hide-user-agent{block}$
 
+{-hide-user-agent{}}
 # Set Header = ua-blah: blah
 # Expect Header = NO CHANGE
-{-hide-user-agent{}}
 TAG:^-hide-user-agent{block}$
 
 
@@ -140,16 +179,16 @@ TAG:^-hide-user-agent{block}$
 # Test add-header{}.
 #######################################################
 
+{+add-header{X-Custom-Header: yes, please}}
 # Set Header    = X-Whatever: foo
 # Expect Header = X-Custom-Header: yes, please
-
-{+add-header{X-Custom-Header: yes, please}}
 TAG:^add-header\{X-Custom-Header: yes, please\}$
 
 #######################################################
 # Test client-header-filter{hide-tor-exit-notation}.
 #######################################################
 
+{+client-header-filter{hide-tor-exit-notation} -hide-referer}
 # Set Header    = Referer: http://p.p.zwiebelsuppe.exit/
 # Expect Header = Referer: http://p.p/
 #
@@ -170,14 +209,13 @@ TAG:^add-header\{X-Custom-Header: yes, please\}$
 #
 # Set Header    = Referer: http://config.privoxy.org.ad356ef8e87a89e6c898b74500d58607ac691178.exit/foo/baaz.html
 # Expect Header = Referer: http://config.privoxy.org/foo/baaz.html
-
-{+client-header-filter{hide-tor-exit-notation} -hide-referer}
 TAG:^client-header-filter\{hide-tor-exit-notation\}$
 
 #######################################################
 # Test crunch-client-header{}.
 #######################################################
 
+{+crunch-client-header{text/html}}
 # Set Header    = Content-Type: text/html
 # Expect Header = REMOVAL
 #
@@ -186,94 +224,148 @@ TAG:^client-header-filter\{hide-tor-exit-notation\}$
 #
 # Set Header    = Content-Type: text/plain
 # Expect Header = NO CHANGE
-
-{+crunch-client-header{text/html}}
 TAG:^crunch-client-header\{text/plain\}$
 
-
 #######################################################
 # Test crunch-if-none-match.
 #######################################################
 
+{+crunch-if-none-match -hide-if-modified-since}
 # Set Header    = If-None-Match: 8987afd239d2093kd2309kd
 # Expect Header = REMOVAL
-
+#
 # Set Header    = If-None-Match: 82c3cb50c984ef11b1fed749949b2a16
 # Expect Header = REMOVAL
-
+#
 # Set Header    = If-Modified-Since: Thu, 04 Oct 2007 09:56:35 GMT
 # Expect Header = NO CHANGE
-
-{+crunch-if-none-match -hide-if-modified-since}
 TAG:^crunch-if-none-match$
 
 #######################################################
 # Test hide-if-modified-since
 #######################################################
 
+{+hide-if-modified-since{block} -crunch-if-none-match}
 # Set Header    = If-Modified-Since: Thu, 04 Oct 2007 09:56:35 GMT
 # Expect Header = REMOVAL
 #
 # Set Header    = If-None-Match: 82c3cb50c984ef11b1fed749949b2a16
 # Expect Header = NO CHANGE
-
-{+hide-if-modified-since{block} -crunch-if-none-match}
 TAG:^hide-if-modified-since\{block\}$
 
+{+hide-if-modified-since{-60} -crunch-if-none-match}
 # Set Header    = If-Modified-Since: Gee, this date is invalid
 # Expect Header = REMOVAL
+#
 # Set Header    = If-Modified-Since: Thu, 04 Oct 2007 09:56:35 GMT
 # Expect Header = SOME CHANGE
-
-{+hide-if-modified-since{-60} -crunch-if-none-match}
+# Set Header    = If-Modified-Since: Thu, 04-Oct-07 09:56:35 GMT
+# Expect Header = SOME CHANGE
+# Set Header    = If-Modified-Since: Thursday, 04-Oct-2007 09:56:35 GMT
+# Expect Header = SOME CHANGE
+# Set Header    = If-Modified-Since: Thu, 04-Oct-2007 09:56:35 GMT
+# Expect Header = SOME CHANGE
+# Set Header    = If-Modified-Since: Thursday Oct 04 09:56:35 2007 GMT
+# Expect Header = SOME CHANGE
+#
+# Set Header    = If-Modified-Since: Thu, 1 Jan 1970 00:00:00 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+# Set Header    = If-Modified-Since: Thu, 01-Jan-70 00:00:00 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+# Set Header    = If-Modified-Since: Thursday, 01-Jan-1970 00:00:00 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+# Set Header    = If-Modified-Since: Thu, 01-Jan-1970 00:00:00 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+# Set Header    = If-Modified-Since: Thursday Jan 01 00:00:00 1970 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+#
+# Set Header    = If-Modified-Since: Thu, 1 Jan 123456789 00:00:00 GMT
+# Expect Header = REMOVAL
+# Set Header    = If-Modified-Since: Thu, 01-Jan-123456789 00:00:00 GMT
+# Expect Header = REMOVAL
+# Set Header    = If-Modified-Since: Thursday, 01-Jan-123456789 00:00:00 GMT
+# Expect Header = REMOVAL
+# Set Header    = If-Modified-Since: Thu, 01-Jan-123456789 00:00:00 GMT
+# Expect Header = REMOVAL
+# Set Header    = If-Modified-Since: Thursday Jan 01 00:00:00 123456789 GMT
+# Expect Header = REMOVAL
+#
+# Set Header    = If-Modified-Since: Mon, 1 Jan 2525 00:00:00 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+# Set Header    = If-Modified-Since: Mon, 01-Jan-25 00:00:00 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+# Set Header    = If-Modified-Since: Monday, 01-Jan-2525 00:00:00 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+# Set Header    = If-Modified-Since: Mon, 01-Jan-2525 00:00:00 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+# Set Header    = If-Modified-Since: Monday Jan 01 00:00:00 2525 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
+#
+# Set Header    = If-Modified-Since: Thu, 1 Jan 1970 02:00:00 GMT
+# Expect Header = SOME CHANGE
+# Set Header    = If-Modified-Since: Thu, 01-Jan-70 02:00:00 GMT
+# Expect Header = SOME CHANGE
+# Set Header    = If-Modified-Since: Thursday, 01-Jan-1970 02:00:00 GMT
+# Expect Header = SOME CHANGE
+# Set Header    = If-Modified-Since: Thu, 01-Jan-1970 02:00:00 GMT
+# Expect Header = SOME CHANGE
+# Set Header    = If-Modified-Since: Thursday Jan 01 02:00:00 1970 GMT
+# Expect Header = SOME CHANGE
 TAG:^hide-if-modified-since\{-60\}$
 
+{+hide-if-modified-since{+60} -crunch-if-none-match}
 # Set Header    = If-Modified-Since: Gee, this date is invalid
 # Expect Header = REMOVAL
 # Set Header    = If-Modified-Since: Thu, 04 Oct 2007 09:56:35 GMT
 # Expect Header = SOME CHANGE
-
-{+hide-if-modified-since{+60} -crunch-if-none-match}
+# Set Header    = If-Modified-Since: Wed, 31 Dec 1969 23:59:59 GMT
+# Expect Header = SOME CHANGE
+# Level = 17
 TAG:^hide-if-modified-since\{\+60\}$
 
+{+hide-if-modified-since{60} -crunch-if-none-match}
 # Set Header    = If-Modified-Since: Gee, this date is invalid
 # Expect Header = REMOVAL
 # Set Header    = If-Modified-Since: Thu, 04 Oct 2007 09:56:35 GMT
 # Expect Header = SOME CHANGE
-
-{+hide-if-modified-since{60} -crunch-if-none-match}
 TAG:^hide-if-modified-since\{60\}$
 
+{+hide-if-modified-since{+0} -crunch-if-none-match}
 # Set Header    = If-Modified-Since: Gee, this date is invalid
 # Expect Header = REMOVAL
 # Set Header    = If-Modified-Since: Thu, 04 Oct 2007 09:56:35 GMT
 # Expect Header = NO CHANGE
-
-{+hide-if-modified-since{+0} -crunch-if-none-match}
 TAG:^hide-if-modified-since\{\+0\}$
 
+{+hide-if-modified-since{-0} -crunch-if-none-match}
 # Set Header    = If-Modified-Since: Gee, this date is invalid
 # Expect Header = REMOVAL
 # Set Header    = If-Modified-Since: Thu, 04 Oct 2007 09:56:35 GMT
 # Expect Header = NO CHANGE
-
-{+hide-if-modified-since{-0} -crunch-if-none-match}
 TAG:^hide-if-modified-since\{-0\}$
 
+{+hide-if-modified-since{0} -crunch-if-none-match}
 # Set Header    = If-Modified-Since: Gee, this date is invalid
 # Expect Header = REMOVAL
 # Set Header    = If-Modified-Since: Thu, 04 Oct 2007 09:56:35 GMT
 # Expect Header = NO CHANGE
-
-{+hide-if-modified-since{0} -crunch-if-none-match}
 TAG:^hide-if-modified-since\{0\}$
 
+{+hide-if-modified-since{NaN} -crunch-if-none-match}
 # Set Header    = If-Modified-Since: Gee, this date is invalid
 # Expect Header = REMOVAL
 # Set Header    = If-Modified-Since: Thu, 04 Oct 2007 09:56:35 GMT
 # Expect Header = NO CHANGE
-
-{+hide-if-modified-since{NaN} -crunch-if-none-match}
 TAG:^hide-if-modified-since\{NaN\}$
 
 
@@ -281,17 +373,18 @@ TAG:^hide-if-modified-since\{NaN\}$
 # Test crunch-outgoing-cookies
 #######################################################
 
-# Set Header    = If-Modified-Since: Gee, this date is invalid
-# Expect Header = NO CHANGE
-#
-# Set Header    = Cookie: PREF=ID=6cf0abd34262:TM=117335617:LM=1617:S=jZypyJ7LPiwFi1_
-# Expect Header = REMOVAL
 {\
  +crunch-outgoing-cookies \
  -crunch-incoming-cookies \
+ -limit-cookie-lifetime   \
  -session-cookies-only    \
  -hide-if-modified-since  \
 }
+# Set Header    = If-Modified-Since: Gee, this date is invalid
+# Expect Header = NO CHANGE
+#
+# Set Header    = Cookie: PREF=ID=6cf0abd34262:TM=117335617:LM=1617:S=jZypyJ7LPiwFi1_
+# Expect Header = REMOVAL
 TAG:^crunch-outgoing-cookies$
 
 #######################################################
@@ -301,59 +394,70 @@ TAG:^crunch-outgoing-cookies$
 # affect client headers.
 #######################################################
 
-# Set Header    = Cookie: NSC_gffe-iuuq-mc-wtfswfs=8efb330d3660;expires=Thu, 04-Oct-07 19:11:34 GMT;path=/
-# Expect Header = NO CHANGE
-#
-# Set Header    = Cookie: PREF=ID=6cf0abd34262:TM=117335617:LM=1617:S=jZypyJ7LPiwFi1_
-# Expect Header = NO CHANGE
 {\
  -crunch-outgoing-cookies \
  -crunch-incoming-cookies \
+ -limit-cookie-lifetime   \
  +session-cookies-only    \
  -hide-if-modified-since  \
 }
+# Set Header    = Cookie: NSC_gffe-iuuq-mc-wtfswfs=8efb330d3660;expires=Thu, 04-Oct-07 19:11:34 GMT;path=/
+# Expect Header = NO CHANGE
+#
+# Set Header    = Cookie: PREF=ID=6cf0abd34262:TM=117335617:LM=1617:S=jZypyJ7LPiwFi1_
+# Expect Header = NO CHANGE
 TAG:^session-cookies-only$
 
 #######################################################
-# Test hide-forwarded-for-headers
+# Test change-x-forwarded-for
 #######################################################
 
-# Set Header    = X-Forwarded-For: 10.0.0.1
-# Expect Header = REMOVAL
 {\
+hide-forwarded-for-headers    \
-change-x-forwarded-for \
 }
-TAG:^hide-forwarded-for-headers$
-
 # Set Header    = X-Forwarded-For: 10.0.0.1
 # Expect Header = NO CHANGE
+TAG:^-change-x-forwarded-for$
+
 {\
-hide-forwarded-for-headers    \
+change-x-forwarded-for{block} \
 }
-TAG:^-hide-forwarded-for-headers$
+# Set Header    = X-Forwarded-For: 10.0.0.1
+# Expect Header = REMOVAL
+TAG:^change-x-forwarded-for\{block\}$
+
+{\
+ +change-x-forwarded-for{add} \
+}
+# Set Header    = X-Forwarded-For: 10.0.0.1
+# Expect Header = SOME CHANGE
+TAG:^change-x-forwarded-for\{add\}$
 
 #######################################################
 # Test hide-from-header
 #######################################################
 
-# Set Header    = From: schneewitchen@example.org
-# Expect Header = REMOVAL
 {\
  +hide-from-header{block}\
 }
+# Set Header    = From: schneewitchen@example.org
+# Expect Header = REMOVAL
 TAG:^hide-from-header\{block\}$
 
-# Set Header    = From: schneewitchen@example.org
-# Expect Header = From: siebenzwerge@example.org
 {\
  +hide-from-header{siebenzwerge@example.org}\
 }
+# Set Header    = From: schneewitchen@example.org
+# Expect Header = From: siebenzwerge@example.org
 TAG:^hide-from-header\{siebenzwerge@example.org\}$
 
 #######################################################
 # Test prevent-compression
 #######################################################
 
+{\
+ +prevent-compression\
+}
 # Set Header    = Accept-Encoding: gzip, deflate
 # Expect Header = REMOVAL
 #
@@ -362,9 +466,6 @@ TAG:^hide-from-header\{siebenzwerge@example.org\}$
 #
 # Set Header    = Accept-Encoding: deflate
 # Expect Header = REMOVAL
-{\
- +prevent-compression\
-}
 TAG:^prevent-compression$
 
 #######################################################
@@ -372,80 +473,180 @@ TAG:^prevent-compression$
 # range requests.
 #######################################################
 
+{\
+ -client-header-tagger{range-requests} \
+ +deanimate-gifs{last} \
+ -filter \
+}
 # Set Header    = Range: bytes=1234-5678
 # Expect Header = REMOVAL
+# Set Header    = Range: bytes=1-5
+# Expect Header = REMOVAL
 # Set Header    = If-Range: bytes=1234-5678
 # Expect Header = REMOVAL
 # Set Header    = Request-Range: bytes=1234-5678
 # Expect Header = REMOVAL
-{\
- +deanimate-gifs{last} \
- -filter \
-}
+# Set Header    = Range: foo
+# Expect Header = REMOVAL
+# Set Header    = If-Range: foo
+# Expect Header = REMOVAL
+# Set Header    = Request-Range: foo
+# Expect Header = REMOVAL
+# Set Header    = Range: bytes=0-5678
+# Expect Header = NO CHANGE
+# Set Header    = Range: bytes=0-
+# Expect Header = NO CHANGE
+# Set Header    = If-Range: bytes=0-5678
+# Expect Header = NO CHANGE
+# Set Header    = If-Range: bytes=0-
+# Expect Header = NO CHANGE
+# Set Header    = Request-Range: bytes=0-5678
+# Expect Header = NO CHANGE
+# Set Header    = Request-Range: bytes=0-
+# Expect Header = NO CHANGE
 TAG:^deanimate-gifs\{last\}$
 
+{\
+ -client-header-tagger{range-requests} \
+ -deanimate-gifs \
+ +filter{banners-by-size} \
+}
 # Set Header    = Range: bytes=1234-5678
 # Expect Header = REMOVAL
+# Set Header    = Range: bytes=1-5
+# Expect Header = REMOVAL
+# Set Header    = If-Range: bytes=1234-5678
+# Expect Header = REMOVAL
+# Set Header    = Request-Range: bytes=1234-5678
+# Expect Header = REMOVAL
+# Set Header    = Range: bytes=1-5
+# Expect Header = REMOVAL
 # Set Header    = If-Range: bytes=1234-5678
 # Expect Header = REMOVAL
 # Set Header    = Request-Range: bytes=1234-5678
 # Expect Header = REMOVAL
+# Set Header    = Range: foo
+# Expect Header = REMOVAL
+# Set Header    = If-Range: foo
+# Expect Header = REMOVAL
+# Set Header    = Request-Range: foo
+# Expect Header = REMOVAL
+# Set Header    = Range: bytes=0-5678
+# Expect Header = NO CHANGE
+# Set Header    = Range: bytes=0-
+# Expect Header = NO CHANGE
+# Set Header    = If-Range: bytes=0-5678
+# Expect Header = NO CHANGE
+# Set Header    = If-Range: bytes=0-
+# Expect Header = NO CHANGE
+# Set Header    = Request-Range: bytes=0-5678
+# Expect Header = NO CHANGE
+# Set Header    = Request-Range: bytes=0-
+# Expect Header = NO CHANGE
+TAG:^filter\{banners-by-size\}$
+
 {\
+ -client-header-tagger{range-requests} \
  -deanimate-gifs \
+filter{banners-by-size} \
-filter \
 }
-TAG:^filter\{banners-by-size\}$
-
 # Set Header    = Range: bytes=1234-5678
 # Expect Header = NO CHANGE
 # Set Header    = If-Range: bytes=1234-5678
 # Expect Header = NO CHANGE
 # Set Header    = Request-Range: bytes=1234-5678
 # Expect Header = NO CHANGE
-{\
- -deanimate-gifs \
- -filter \
-}
 TAG:^no-content-filter$
 
+{}
+# Set Header    = Connection: keep-alive
+# Expect Header = NO CHANGE
+# Level = 13
+# Set Header    = Connection:
+# Expect Header = REMOVAL
+# Level = 13
+TAG:^Connection: keep-alive$
+
+{}
 # Set Header    = Connection: keep-alive
 # Expect Header = Connection: close
+# Level = 14
 # Set Header    = Connection:
 # Expect Header = Connection: close
-{}
+# Level = 14
 TAG:^Connection: close$
 
+{}
+# Set Header    = Connection: close
+# Expect Header = NO CHANGE
+# Level = 15
+TAG:^connection-sharing disabled$
+
+{}
+# Set Header    = Connection: close
+# Expect Header = REMOVAL
+# Level = 16
+# Set Header    = Connection: keep-alive
+# Expect Header = NO CHANGE
+# Level = 16
+TAG:^connection-sharing enabled$
+
+{}
 # XXX: Removing a header by not specifying a value is
 # an inherited curl feature and could be viewed as a
 # bug as far as Privoxy-Regression-Test is concerned.
 #
 # Set Header    = Host:
 # Expect Header = Host: p.p
-{}
 TAG:^No Host header$
 
+{}
 # Set Header    = Host: whatever.example.org
 # Expect Header = NO CHANGE
-{}
 TAG:^Host header other than the target host$
 
-# XXX: check the RFC to use a real value
-# Set Header = Keep-Alive: Yes
+{}
+# Set Header = Keep-Alive: 20
+# Expect Header = NO CHANGE
+# Level = 13
+# Set Header = Keep-Alive: timeout=20, max=3
+# Expect Header = NO CHANGE
+# Level = 13
+# Set Header = Keep-Alive: blah=fasel, timeout=20, max=3
+# Expect Header = NO CHANGE
+# Level = 13
+# Set Header = Keep-Alive: timeuot=20, max=3
+# Expect Header = REMOVAL
+# Level = 13
+# Set Header = Keep-Alive: twenty seconds please
 # Expect Header = REMOVAL
+# Level = 13
+TAG:^Parse Keep-Alive header$
+
 {}
+# Set Header = Keep-Alive: 20
+# Expect Header = REMOVAL
+# Level = 14
+# Set Header = Keep-Alive: timeout=20, max=3
+# Expect Header = REMOVAL
+# Level = 14
+# Set Header = Keep-Alive: blah=fasel, timeout=20, max=3
+# Expect Header = REMOVAL
+# Level = 14
 TAG:^Keep-Alive header removal$
 
+{}
 # XXX: check the RFC to use a real value
 # Set Header = proxy-connection: keep-alive
 # Expect Header = REMOVAL
-{}
 TAG:^Proxy-Connection removal$
 
+{}
 # Set Header = Proxy-Connection: keep-alive
 # Expect Header = REMOVAL
-{}
 TAG:^Proxy-Connection removal$
 
+{}
 # These are somewhat redundant when testing with
 # GET requests, but I want to remember then when
 # TRACE requests are supported.
@@ -458,25 +659,39 @@ TAG:^Proxy-Connection removal$
 # Expect Header = NO CHANGE
 # Set Header = Max-Forwards: 3
 # Expect Header = NO CHANGE
-{}
 TAG:^Max-Forwards header without TRACE method$
 
+{}
+# Set Header = Proxy-Authorization: blafaseldieda
+# Expect Header = REMOVAL
+# Level = 22
+TAG:^Proxy-Authorization header removal$
+
+{}
+# Set Header = Proxy-Authorization: blafaseldieda
+# Expect Header = Proxy-Authorization: blafaseldieda
+# Level = 23
+TAG:^Proxy-Authorization header forwarding$
+
 ################################################################
 #
 # Fairly dumb tests for Privoxy CGI pages.
 #
 # These are mainly useful for checking for memory leaks
 # with Valgrind or whether or not the user manual is installed
-# correctly and are unlikely to actually detect any
+# correctly.
 #
 # Note that if "Expect Status Code" is missing, 200 is implied.
 #
 ################################################################
 
 # Fetch Test = http://p.p/
-# Will fail if compiled with FEATURE_GRACEFUL_TERMINATION
 # Fetch Test = http://p.p/die
 # Expect Status Code = 404
+# Level = 18
+# Fetch Test = http://p.p/die
+# Expect Status Code = 200
+# Level = 19
 # Fetch Test = http://p.p/show-status
 # Fetch Test = http://config.privoxy.org/show-status?file=actions&index=0
 # Fetch Test = http://config.privoxy.org/show-status?file=filter&index=0
@@ -490,6 +705,7 @@ TAG:^Max-Forwards header without TRACE method$
 # Fetch Test = http://config.privoxy.org/show-status?file=invalid
 # Fetch Test = http://config.privoxy.org/show-status?file=trust
 # Fetch Test = http://p.p/show-version
+# Expect Status Code = 404
 # Fetch Test = http://p.p/show-request
 # Fetch Test = http://p.p/show-url-info
 # Fetch Test = http://p.p/show-url-info?url=www.privoxy.org%2F
@@ -501,36 +717,73 @@ TAG:^Max-Forwards header without TRACE method$
 # Fetch Test = http://p.p/show-url-info?url=FTp:%2F%2Fwww.privoxy.org%2F
 # Fetch Test = http://p.p/show-url-info?url=
 # Fetch Test = http://p.p/show-url-info?url=%2F
+# Depends on FEATURE_TOGGLE
 # Fetch Test = http://p.p/toggle
+# Level = 20
+# Fetch Test = http://p.p/toggle
+# Expect Status Code = 404
+# Level = 21
 # Fetch Test = http://p.p/edit-actions
+# Level = 12
 # Fetch Test = http://p.p/eaa
+# Level = 12
 # Fetch Test = http://p.p/eau
+# Level = 12
 # Fetch Test = http://p.p/ear
+# Level = 12
 # Fetch Test = http://p.p/eal
+# Level = 12
 # Fetch Test = http://p.p/eafu
+# Level = 12
 # Fetch Test = http://p.p/eas
+# Level = 12
 # Fetch Test = http://p.p/easa
+# Level = 12
 # Fetch Test = http://p.p/easr
+# Level = 12
 # Fetch Test = http://p.p/eass
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-for-url
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-list
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-submit
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-url
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-url-form
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-add-url
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-add-url-form
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-remove-url
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-remove-url-form
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-section-add
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-section-remove
+# Level = 12
 # Fetch Test = http://p.p/edit-actions-section-swap
+# Level = 12
 # Fetch Test = http://p.p/error-favicon.ico
 # Fetch Test = http://p.p/favicon.ico
 # Fetch Test = http://p.p/robots.txt
 # Fetch Test = http://p.p/send-banner
+# Trusted CGI Request = http://p.p/send-stylesheet
 # Fetch Test = http://p.p/send-stylesheet
+# Expect Status Code = 403
 # Fetch Test = http://p.p/t
 # Fetch Test = http://p.p/url-info-osd.xml
+# Fetch Test = http://p.p/client-tags
+# Level = 24
+# Trusted CGI Request = http://p.p/toggle-client-tag
+# Expect Status Code = 302
+# Level = 24
+# Fetch Test = http://p.p/toggle-client-tag
+# Expect Status Code = 403
+# Level = 24
 
 # Trusted CGI Request = http://p.p/edit-actions
 # Expect Status Code = 302
@@ -538,26 +791,47 @@ TAG:^Max-Forwards header without TRACE method$
 # Fetch Test = http://p.p/does-not-exist
 # Expect Status Code = 404
 # Trusted CGI Request = http://p.p/eaa
+# Level = 12
 # Trusted CGI Request = http://p.p/eau
+# Level = 12
 # Trusted CGI Request = http://p.p/ear
+# Level = 12
 # Trusted CGI Request = http://p.p/eal
+# Level = 12
 # Trusted CGI Request = http://p.p/eafu
+# Level = 12
 # Trusted CGI Request = http://p.p/eas
+# Level = 12
 # Trusted CGI Request = http://p.p/easa
+# Level = 12
 # Trusted CGI Request = http://p.p/easr
+# Level = 12
 # Trusted CGI Request = http://p.p/eass
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-for-url
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-list
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-submit
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-url
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-url-form
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-add-url
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-add-url-form
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-remove-url
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-remove-url-form
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-section-add
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-section-remove
+# Level = 12
 # Trusted CGI Request = http://p.p/edit-actions-section-swap
+# Level = 12
 # Trusted CGI Request = http://p.p/send-stylesheet
 
 # The following tests depend on Privoxy being configured to deliver the user manual
@@ -603,8 +877,6 @@ TAG:^Max-Forwards header without TRACE method$
 # Level = 9
 # Fetch Test = http://p.p/user-manual/templates.html
 # Level = 9
-# Fetch Test = http://p.p/user-manual/upgradersnote.html
-# Level = 9
 # Fetch Test = http://p.p/user-manual/whatsnew.html
 # Level = 9
 
@@ -647,6 +919,7 @@ TAG:^Max-Forwards header without TRACE method$
 # Method Test = MERGE
 # Method Test = BASELINE-CONTROL
 # Method Test = MKACTIVITY
+# Method Test = PATCH
 # Method Test = PRIVOXY-REGRESSION-TEST-IN-THE-HOUSE
 # Expect Status Code = 400
 
@@ -658,44 +931,54 @@ p.p:1-/
 config.privoxy.org:3,79-81/
 p.p:3,22,79-81/
 
+{+forward-override{forward-socks5 127.0.0.1:12345 .}}
 # Fetch Test = http://oh-dear-this-hostname-is-so-very-long-that-it-can-not-possibly-be-forwarded-through-socks5-as-a-result-we-therefore-expect-privoxy-to-return-an-error-response-instead-of-forwarding-the-request-because-as-already-mentioned-this-host-is-really-very-long.example
 # Expect Status Code = 503
-{+forward-override{forward-socks5 127.0.0.1:12345 .}}
 oh-dear-this-hostname-is-so-very-long-that-it-can-not-possibly-be-forwarded-through-socks5-as-a-result-we-therefore-expect-privoxy-to-return-an-error-response-instead-of-forwarding-the-request-because-as-already-mentioned-this-host-is-really-very-long.example/
 
-# Fetch Test = http://oh-dear-this-hostname-is-short-enough-but-there-is-no-socks-server-listening.example
-# Expect Status Code = 503
 {+forward-override{forward-socks5 127.0.0.1:12345 .}}
-oh-dear-this-hostname-is-short-enough-but-there-is-no-socks-server-listening.example
+# Fetch Test = http://oh-dear-this-hostname-is-short-enough-but-there-is-no-socks5-server-listening.example
+# Expect Status Code = 503
+oh-dear-this-hostname-is-short-enough-but-there-is-no-socks5-server-listening.example
+
+{+forward-override{forward-socks4 127.0.0.1:12345 .}}
+# Fetch Test = http://oh-dear-this-hostname-is-short-enough-but-there-is-no-socks4-server-listening.example
+# Expect Status Code = 503
+oh-dear-this-hostname-is-short-enough-but-there-is-no-socks4-server-listening.example
+
+{+forward-override{forward-socks4a 127.0.0.1:12345 .}}
+# Fetch Test = http://oh-dear-this-hostname-is-short-enough-but-there-is-no-socks4a-server-listening.example
+# Expect Status Code = 503
+oh-dear-this-hostname-is-short-enough-but-there-is-no-socks4a-server-listening.example
 
+{+forward-override{forward-socks5 127.0.0.1:-1 127.0.0.1:12345}}
 # This one currently triggers the same error condition as the
 # test above (socks5 server unreachable), but once Privoxy
 # starts to properly reject invalid ports it should become useful.
-
+#
 # Fetch Test = http://invalid-forward5-gateway-port.example
 # Expect Status Code = 503
-{+forward-override{forward-socks5 127.0.0.1:-1 127.0.0.1:12345}}
 invalid-forward5-gateway-port.example
 
+{+forward-override{forward-socks5 :12345 127.0.0.1:12345}}
 # Fetch Test = http://forward5-null-gateway-host.example
 # Expect Status Code = 503
-{+forward-override{forward-socks5 :12345 127.0.0.1:12345}}
 forward5-null-gateway-host.example
 
+{+limit-connect{443}}
 # Fetch Test = http://www.forbidden-connect.example:444/
 # Method = CONNECT
 # Expect Status Code = 403
-{+limit-connect{443}}
 www.forbidden-connect.example/
 
+{+block{This request failed to make it to the target destination which means the test succeeded.}}
 # Fetch Test = http://www.blocked-request.example/blocked-request
 # Expect Status Code = 403
-{+block{This request failed to make it to the target destination which means the test succeeded.}}
 www.blocked-request.example/blocked-request
 
+{+block}
 # Fetch Test = http://www.blocked-request.example/blocked-request-with-no-reason-specified
 # Expect Status Code = 403
-{+block}
 www.blocked-request.example/blocked-request-with-no-reason-specified
 
 # Some domain pattern tests
@@ -705,6 +988,12 @@ www.blocked-request.example/blocked-request-with-no-reason-specified
 # Blocked URL = http://domain-pattern-test.example.org/
 domain-pattern-test.example.
 
+{+block{Hostname patterns without trailing dots cover hostnames with trailing dots as well.}}
+# Blocked URL = http://trailing-dot.example.org./
+# Blocked URL = http://trailing-dot.example.org./foo
+trailing-dot.example.org
+
+{}
 # Just in case there is no white-space fuzzer in the house ...
 #
 # Set Header = X-LWS-Test: no superfluous white space here
@@ -731,5 +1020,47 @@ domain-pattern-test.example.
 # Expect Header = X-LWS-Test: "This  is  quoted" this is not "but   this  is  again"
 # Set Header = X-LWS-Test:  "This  is  quoted" this   is  not "this  is  "  but  "  this again   is  not
 # Expect Header = X-LWS-Test: "This  is  quoted" this is not "this  is  " but " this again is not
-{}
 TAG:^LWS Tests$
+
+{+fast-redirects{check-decoded-url}}
+# Redirected URL = http://redirect.example.net/blafasel&url=http://redirected1.example.net/
+# Redirect Destination = http://redirected1.example.net/
+# Redirected URL = http://redirect.example.net/blafasel&url=http%3A%2F%2Fredirected2.example.net%2F&parameter=not-part-of-the-redirected-url
+# Redirect Destination = http://redirected2.example.net/
+# Redirected URL = http://redirect.example.net/blafasel&url=http%3A%2F%2Fredirected3.example.net%2F&parameter=not-part-of-the-redirected-url
+# Redirect Destination = http://redirected3.example.net/
+# Redirected URL = http://redirect.example.net/blafasel&url=http%3A%2F%2Fredirected4.example.net%2F%26parameter=part-of-the-redirected-url
+# Redirect Destination = http://redirected4.example.net/&parameter=part-of-the-redirected-url
+# Redirected URL = http://redirect.example.net/blafasel&url1=http%3A%2F%2Fredirected5.example.net%2F%26parameter1=part-of-the-redirected-url&url2=http%3A%2F%2Fredirected5.example.net%2F%26parameter2=part-of-the-redirected-url2
+# Redirect Destination = http://redirected5.example.net/&parameter2=part-of-the-redirected-url2
+# Redirected URL = http://redirect.example.net/blafasel&url1=http%3A%2F%2Fredirected6.example.net%2F%26parameter1=part-of-the-redirected-url&url2=http%3A%2F%2Fredirected6.example.net%2F%26parameter2=part-of-the-redirected-url2&parameter3=not-part-of-the-redirected-url2
+# Redirect Destination = http://redirected6.example.net/&parameter2=part-of-the-redirected-url2
+# Redirected URL = http://redirect.example.net/blafasel?x=http%3A%2F%2Fredirected7.example.net%2F%26parameter1=part-of-the-redirected-url1&parameter2=not-part-of-the-redirected-url1
+# Redirect Destination = http://redirected7.example.net/&parameter1=part-of-the-redirected-url1
+# Redirected URL = http://redirect.example.net/blafasel?x=http%3A%2F%2Fredirected8.example.net%2F%26parameter1=part-of-the-redirected-url1&parameter2=not-part-of-the-redirected-url1&parameter3=not-part-of-the-redirected-url1
+# Redirect Destination = http://redirected8.example.net/&parameter1=part-of-the-redirected-url1
+# Redirected URL = http://redirect.example.net/blafasel?a?b?c?d?e?f?g?h?i?j?k?l?m?n?o?p?q?r?s&t&u&v&w&x&y&z&1&2&3&4&5&6&7&8&9&10&11&12&13&14&15&16x=http%3A%2F%2Fredirected8.example.net%2F%26parameter1=part-of-the-redirected-url1&parameter2=not-part-of-the-redirected-url1&parameter3=not-part-of-the-redirected-url1
+# Redirect Destination = http://redirected8.example.net/&parameter1=part-of-the-redirected-url1
+# Redirected URL = http://redirect.example.net/blafasel???????????????????????????????=http%3A%2F%2Fredirected8.example.net%2F%26parameter1=part-of-the-redirected-url1&parameter2=not-part-of-the-redirected-url1&parameter3=not-part-of-the-redirected-url1
+# Redirect Destination = http://redirected8.example.net/&parameter1=part-of-the-redirected-url1
+# Redirected URL = http://redirect.example.net/blafasel&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&=http%3A%2F%2Fredirected8.example.net%2F%26parameter1=part-of-the-redirected-url1&parameter2=not-part-of-the-redirected-url1&parameter3=not-part-of-the-redirected-url1
+# Redirect Destination = http://redirected8.example.net/&parameter1=part-of-the-redirected-url1
+redirect.example.net/
+# Redirected URL = http://redirect.example.net/blafaselhttp://redirect1.example.net/http://redirect2.example.net/
+# Redirect Destination = http://redirect2.example.net/
+# Redirected URL = http://redirect.example.net/blafasel%3A%2F%2Fredirect1.example.net/http://redirect2.example.net/
+# Redirect Destination = http://redirect2.example.net/
+# Redirected URL = http://redirect.example.net/blafaselhttp://redirect1.example.net/http%3A%2F%2Fredirect2.example.net/
+# Redirect Destination = http://redirect2.example.net/
+# These tests verify that Privoxy behaves as intended,
+# given that the encoded redirect URLs are invalid,
+# there are no correct redirect URLs.
+# Redirected URL = http://redirect.example.net/%%%%%%%%%%%%%%%%%%%%%%blafaselhttp://redirect1.example.net/http%3A%2F%2Fredirect2.example.net/%%%%%%%%%%%%%%
+# Redirect Destination = http://redirect2.example.net/%%%%%%%%%%%%%%
+# Redirected URL = http://redirect.example.net/%%%%%%%%%%%%%%%%%%%%%%blafaselhttp://redirect1.example.net/http%3A%2F%2Fredirect2.example.net/%1%2%%3%4%5%6%7%8%9%0%0%%
+# Redirect Destination = http://redirect2.example.net/%1%2%%3%4%5%6%7%8%9%0%0%%
+
+{+fast-redirects{simple-check}}
+# Redirected URL = http://redirect2.example.net/blafasel?x=http://redirected.example.net/&parameter1=part-of-the-redirected-url1&parameter2=part-of-the-redirected-url1
+# Redirect Destination = http://redirected.example.net/&parameter1=part-of-the-redirected-url1&parameter2=part-of-the-redirected-url1
+redirect2.example.net/