X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=regression-tests.action;h=9f812637e2b13bb3674ab559a13f01f96c13eee5;hp=9874484e333f131768e3d856565c7679a3e0d2b6;hb=873efe14859c0fb3f53a905eb346c36cf5fe7eda;hpb=ad0818041ac3bca5022d71054fcab05c1f5e2fe3 diff --git a/regression-tests.action b/regression-tests.action index 9874484e..9f812637 100644 --- a/regression-tests.action +++ b/regression-tests.action @@ -1,16 +1,15 @@ ############################################################################# -# $Id: regression-tests.action,v 1.43 2012/04/06 15:17:41 fabiankeil Exp $ -############################################################################# # # This is a configuration file for Privoxy-Regression-Test -# (included in the source tarball's tools directory). +# (included in the source tarball's tools directory and available at +# https://www.privoxy.org/gitweb/?p=privoxy.git;a=blob;f=tools/privoxy-regression-test.pl;hb=HEAD). # -# After referencing it in your Privoxy configuration both Privoxy and +# After referencing this file in your Privoxy configuration both Privoxy and # Privoxy-Regression-Test should be good to go. # ############################################################################# # -# Copyright (c) 2007-2012 Fabian Keil +# Copyright (c) 2007-2020 Fabian Keil # # Permission to use, copy, modify, and distribute this software for any # purpose with or without fee is hereby granted, provided that the above @@ -26,26 +25,30 @@ # ############################################################################# -# While the syntax used is understood by Privoxy 3.0.14 and later, -# some of the +fast-redirects{} tests require at least 3.0.20 to work. {{settings}} -for-privoxy-version=3.0.20 +for-privoxy-version=3.0.29 # Some dependencies Privoxy-Regression-Test should know about: # # 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+[1-9]+ +# 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_PTHREAD Yes +# 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 20 needs = config line enable-remote-toggle\s+1 +# Level 21 needs = config line enable-remote-toggle\s+0 +# 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 +# Level 25 needs = feature status FEATURE_HTTPS_INSPECTION No +# Level 26 needs = feature status FEATURE_PCRE_HOST_PATTERNS Yes ####################################################### # Enable taggers to activate the tests on demand @@ -68,14 +71,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\}$ ####################################################### @@ -89,6 +92,7 @@ TAG:^hide-accept-language\{block\}$ # 6) a parameter that looks like an invalid fake referrer ####################################################### +{+hide-referrer{conditional-block}} # Set Header = Referer: http://www.example.org/foo # Expect Header = REMOVAL # @@ -104,11 +108,14 @@ TAG:^hide-accept-language\{block\}$ # Set Header = Referer: http:// # Expect Header = REMOVAL # -# Set Header = Referer: https://p.p/ +# Set Header = Referer: https://www.privoxy.org/ +# Expect Header = REMOVAL +# +# Set Header = Referer: http://www.privoxy.org/ # Expect Header = REMOVAL -{+hide-referrer{conditional-block}} TAG:^hide-referrer\{conditional-block\}$ +{+hide-referrer{conditional-forge}} # Set Header = Referer: http://www.example.org/foo # Expect Header = Referer: http://p.p/ # @@ -124,29 +131,31 @@ TAG:^hide-referrer\{conditional-block\}$ # Set Header = Referer: http:// # Expect Header = Referer: http://p.p/ # -# Set Header = Referer: https://p.p/ +# Set Header = Referer: https://www.privoxy.org/ +# Expect Header = Referer: http://p.p/ +# +# Set Header = Referer: http://www.privoxy.org/ # Expect Header = Referer: http://p.p/ -{+hide-referrer{conditional-forge}} TAG:^hide-referrer\{conditional-forge\}$ +{+hide-referrer{forge}} # Set Header = Referer: http://www.example.org/foo # Expect Header = Referer: http://p.p/ -{+hide-referrer{forge}} TAG:^hide-referrer\{forge\}$ +{+hide-referrer{block}} # Set Header = Referer: http://www.example.org/foo # Expect Header = REMOVAL -{+hide-referrer{block}} TAG:^hide-referrer\{block\}$ +{+hide-referrer{invalid}} # Set Header = Referer: http://www.example.org/foo # Expect Header = Referer: invalid -{+hide-referrer{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{}} @@ -156,20 +165,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}$ @@ -177,16 +186,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/ # @@ -207,14 +216,35 @@ 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 client-header-filter{no-brotli-accepted}. +####################################################### + +{+client-header-filter{no-brotli-accepted}} +# Set Header = Accept-Encoding: gzip, deflate, br +# Expect Header = Accept-Encoding: gzip, deflate +# +# Set Header = Accept-Encoding: gzip, br, deflate +# Expect Header = Accept-Encoding: gzip, deflate +# +# Set Header = Accept-Encoding: br, gzip, deflate +# Expect Header = Accept-Encoding: gzip, deflate +# +# Set Header = Accept-Encoding: br +# Expect Header = Accept-Encoding: +# +# Set Header = Accept-Encoding: gzip, deflate +# Expect Header = NO CHANGE +# +TAG:^client-header-filter\{no-brotli-accepted\}$ + ####################################################### # Test crunch-client-header{}. ####################################################### +{+crunch-client-header{text/html}} # Set Header = Content-Type: text/html # Expect Header = REMOVAL # @@ -223,106 +253,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 +# 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 - -{+hide-if-modified-since{-60} -crunch-if-none-match} +# 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 # Set Header = If-Modified-Since: Wed, 31 Dec 1969 23:59:59 GMT # Expect Header = SOME CHANGE - -{+hide-if-modified-since{+60} -crunch-if-none-match} +# 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\}$ @@ -330,17 +402,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$ ####################################################### @@ -350,66 +423,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 change-x-forwarded-for ####################################################### -# Set Header = X-Forwarded-For: 10.0.0.1 -# Expect Header = NO CHANGE {\ -change-x-forwarded-for \ } +# Set Header = X-Forwarded-For: 10.0.0.1 +# Expect Header = NO CHANGE TAG:^-change-x-forwarded-for$ -# Set Header = X-Forwarded-For: 10.0.0.1 -# Expect Header = REMOVAL {\ +change-x-forwarded-for{block} \ } +# Set Header = X-Forwarded-For: 10.0.0.1 +# Expect Header = REMOVAL TAG:^change-x-forwarded-for\{block\}$ -# Set Header = X-Forwarded-For: 10.0.0.1 -# Expect Header = SOME CHANGE {\ +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 # @@ -418,9 +495,6 @@ TAG:^hide-from-header\{siebenzwerge@example.org\}$ # # Set Header = Accept-Encoding: deflate # Expect Header = REMOVAL -{\ - +prevent-compression\ -} TAG:^prevent-compression$ ####################################################### @@ -428,6 +502,11 @@ 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 @@ -436,6 +515,12 @@ TAG:^prevent-compression$ # 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- @@ -448,13 +533,13 @@ TAG:^prevent-compression$ # 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{last} \ - -filter \ + -deanimate-gifs \ + +filter{banners-by-size} \ } -TAG:^deanimate-gifs\{last\}$ - # Set Header = Range: bytes=1234-5678 # Expect Header = REMOVAL # Set Header = Range: bytes=1-5 @@ -463,6 +548,18 @@ TAG:^deanimate-gifs\{last\}$ # 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- @@ -475,96 +572,124 @@ TAG:^deanimate-gifs\{last\}$ # 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 -{\ - -client-header-tagger{range-requests} \ - -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$ +{} +# XXX: This test is expected to fail when using "https://p.p/" +# as CGI prefix with https inspection enabled but can't +# yet be automatically skipped. By design connections aren't +# shared when using "https://" so Privoxy does not remove the +# header. # 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$ +{} +# XXX: This test is expected to fail when using "https://p.p/" +# as CGI prefix with https inspection enabled but can't +# yet be automatically skipped. The reason for the test +# failure is that Privoxy-Regression-Test only modifies +# the Host header for the CONNECT request, not for the +# actual request that follows. Changing that would not +# fix the test though as a modified Host header in the +# actual request would result in Privoxy attempting to +# connect to it. # Set Header = Host: whatever.example.org # Expect Header = NO CHANGE -{} TAG:^Host header other than the target host$ +{} # Set Header = Keep-Alive: 20 # Expect Header = NO CHANGE # Level = 13 -{} -TAG:^Pass Keep-Alive header$ +# 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. @@ -577,16 +702,27 @@ 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. # @@ -612,6 +748,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 @@ -627,37 +764,91 @@ TAG:^Max-Forwards header without TRACE method$ # Fetch Test = http://p.p/toggle # Level = 20 # Fetch Test = http://p.p/toggle -# Expect Status Code = 404 +# Expect Status Code = 403 # Level = 21 # Fetch Test = http://p.p/edit-actions +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/eaa +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/eau +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/ear +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/eal +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/eafu +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/eas +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/easa +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/easr +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/eass +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-for-url +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-list +# Level = 12 # Fetch Test = http://p.p/edit-actions-submit +# Expect Status Code = 403 +# Level = 12 +# Expect Status Code = 403 # Fetch Test = http://p.p/edit-actions-url +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-url-form +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-add-url +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-add-url-form +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-remove-url +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-remove-url-form +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-section-add +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-section-remove +# Expect Status Code = 403 +# Level = 12 # Fetch Test = http://p.p/edit-actions-section-swap +# Expect Status Code = 403 +# 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 @@ -665,26 +856,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 @@ -745,6 +957,7 @@ TAG:^Max-Forwards header without TRACE method$ # Method Test = OPTIONS # Method Test = TRACE # Method Test = CONNECT +# Level = 25 # Method Test = PROPFIND # Method Test = PROPPATCH # Method Test = MOVE @@ -772,6 +985,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 @@ -783,54 +997,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/ +{+forward-override{forward-socks5 127.0.0.1:12345 .}} # Fetch Test = http://oh-dear-this-hostname-is-short-enough-but-there-is-no-socks5-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-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 -{+forward-override{forward-socks4 127.0.0.1:12345 .}} 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 -{+forward-override{forward-socks4a 127.0.0.1:12345 .}} 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 @@ -845,6 +1059,7 @@ domain-pattern-test.example. # 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 @@ -871,7 +1086,6 @@ trailing-dot.example.org # 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}} @@ -917,3 +1131,14 @@ redirect.example.net/ # Redirect Destination = http://redirected.example.net/¶meter1=part-of-the-redirected-url1¶meter2=part-of-the-redirected-url1 redirect2.example.net/ +{+delay-response{1}} +# Fetch Test = http://config.privoxy.org/show-url-info?url=http%3A%2F%2Fwww.example.com%2Fprivoxy-test-delay-response +config.privoxy.org/show-url-info\?url=http%3A%2F%2Fwww\.example\.com%2Fprivoxy-test-delay-response + +{+block{Block with pcre host pattern}} +# Blocked URL = http://aaa.example.org/ +# Level = 26 +PCRE-HOST-PATTERN:^a{3}\.example\.org$ +# Blocked URL = http://bbb.example.org/ +# Level = 26 +PCRE-HOST-PATTERN:^(bbb|ccc|ddd)\.example\.org$