Sophie

Sophie

distrib > Mageia > 7 > armv7hl > media > core-updates > by-pkgid > caead09f71a057684f628a1f930dd384 > files > 7

privoxy-3.0.32-1.mga7.armv7hl.rpm

#############################################################################
#
# This is a configuration file for Privoxy-Regression-Test
# (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 this file in your Privoxy configuration both Privoxy and
# Privoxy-Regression-Test should be good to go.
#
#############################################################################
#
# Copyright (c) 2007-2021 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
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#
#############################################################################

{{settings}}
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+(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 = 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
# and suppress hiding the User-Agent for
# Privoxy-Regression-Test to save log space.
#######################################################
{\
 +client-header-tagger{user-agent} \
 +client-header-tagger{privoxy-control} \
 +client-header-filter{privoxy-control} \
}
config.privoxy.org/
p.p/
127.0.0.1/

{-hide-user-agent}
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
TAG:^hide-accept-language\{en-gb\}$

{+hide-accept-language{block}}
# Set Header    = Accept-Language: de-de
# Expect Header = REMOVAL
TAG:^hide-accept-language\{block\}$

#######################################################
# Sections for hide-referrer{} to test:
#
# 1) conditional-block
# 2) conditional-forge
# 3) forge
# 4) block
# 5) a parameter that looks like a valid fake referrer
# 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
#
# Set Header    = Referer: http://p.p/foo
# Expect Header = NO CHANGE
#
# 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://www.privoxy.org/
# Expect Header = REMOVAL
#
# Set Header    = Referer: http://www.privoxy.org/
# Expect Header = REMOVAL
TAG:^hide-referrer\{conditional-block\}$

{+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
#
# 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://www.privoxy.org/
# Expect Header = Referer: http://p.p/
#
# Set Header    = Referer: http://www.privoxy.org/
# Expect Header = Referer: http://p.p/
TAG:^hide-referrer\{conditional-forge\}$

{+hide-referrer{forge}}
# Set Header    = Referer: http://www.example.org/foo
# Expect Header = Referer: http://p.p/
TAG:^hide-referrer\{forge\}$

{+hide-referrer{block}}
# Set Header    = Referer: http://www.example.org/foo
# Expect Header = REMOVAL
TAG:^hide-referrer\{block\}$

{+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/
TAG:^hide-referrer\{http://www.privoxy.org/\}$

#{+hide-referrer{}}
#TAG:^hide-referrer\{\}$

#######################################################
# 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
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
TAG:^hide-user-agent{block}$

{-hide-user-agent{}}
# Set Header = ua-blah: blah
# Expect Header = NO CHANGE
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
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/
#
# Set Header    = Referer: http://p.p.zwiebelsuppe.exit/foo/bar/baaz/
# Expect Header = Referer: http://p.p/foo/bar/baaz/
#
# Set Header    = Referer: http://p.p/
# Expect Header = NO CHANGE
#
# Set Header    = Referer: http://config.privoxy.org.zwiebelsuppe.exit/foo/bar/baaz.html
# Expect Header = Referer: http://config.privoxy.org/foo/bar/baaz.html
#
# Set Header    = Host: p.p.zwiebelsuppe.exit
# Expect Header = Host: p.p
#
# Set Header    = Host: p.p
# Expect Header = NO CHANGE
#
# Set Header    = Referer: http://config.privoxy.org.ad356ef8e87a89e6c898b74500d58607ac691178.exit/foo/baaz.html
# Expect Header = Referer: http://config.privoxy.org/foo/baaz.html
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
#
# Set Header    = Content-Type: text/html; charset=4711
# Expect Header = REMOVAL
#
# Set Header    = Content-Type: text/plain
# Expect Header = NO CHANGE
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
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
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
# 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
# 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
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
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
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
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
TAG:^hide-if-modified-since\{NaN\}$


#######################################################
# Test crunch-outgoing-cookies
#######################################################

{\
 +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$

#######################################################
# Test session-cookies-only
#
# XXX: pretty useless as session-cookies-only doesn't
# affect client headers.
#######################################################

{\
 -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
#######################################################

{\
 -change-x-forwarded-for \
}
# Set Header    = X-Forwarded-For: 10.0.0.1
# Expect Header = NO CHANGE
TAG:^-change-x-forwarded-for$

{\
 +change-x-forwarded-for{block} \
}
# 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
#######################################################

{\
 +hide-from-header{block}\
}
# Set Header    = From: schneewitchen@example.org
# Expect Header = REMOVAL
TAG:^hide-from-header\{block\}$

{\
 +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
#
# Set Header    = Accept-Encoding: gzip
# Expect Header = REMOVAL
#
# Set Header    = Accept-Encoding: deflate
# Expect Header = REMOVAL
TAG:^prevent-compression$

#######################################################
# Test content filters which could cause problems with
# 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
# 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 \
}
# 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
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
# 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.
#
# Set Header = Max-Forwards: 0
# Expect Header = NO CHANGE
# Set Header = Max-Forwards: 1
# Expect Header = NO CHANGE
# Set Header = Max-Forwards: -1
# 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.
#
# Note that if "Expect Status Code" is missing, 200 is implied.
#
################################################################

# Fetch Test = http://p.p/
# Fetch Test = http://p.p/die
# Expect Status Code = 404
# Level = 18
# Fetch Test = http://p.p/die
# Expect Status Code = 403
# 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
# XXX: for the invalid ones we probably shouldn't return status code 200.
# Fetch Test = http://config.privoxy.org/show-status?file=actions&index=100
# Fetch Test = http://config.privoxy.org/show-status?file=actions&index=NaN
# Fetch Test = http://config.privoxy.org/show-status?file=actions
# Fetch Test = http://config.privoxy.org/show-status?file=filter&index=100
# Fetch Test = http://config.privoxy.org/show-status?file=filter&index=NaN
# Fetch Test = http://config.privoxy.org/show-status?file=filter
# 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
# Fetch Test = http://p.p/show-url-info?url=http:%2F%2Fwww.privoxy.org%2F
# Fetch Test = http://p.p/show-url-info?url=HTTp:%2F%2Fwww.privoxy.org%2F
# Fetch Test = http://p.p/show-url-info?url=https:%2F%2Fwww.privoxy.org%2F
# Fetch Test = http://p.p/show-url-info?url=HtTps:%2F%2Fwww.privoxy.org%2F
# Fetch Test = http://p.p/show-url-info?url=ftp:%2F%2Fwww.privoxy.org%2F
# 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 = 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
# Level = 12 # Depends on the CGI editor being enabled
# 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

# Fetch Test = http://p.p/user-manual
# Expect Status Code = 302
# Level = 9
# Fetch Test = http://p.p/user-manual/
# Level = 9
# Fetch Test = http://p.p/user-manual/actions-file.html
# Level = 9
# Fetch Test = http://p.p/user-manual/appendix.html
# Level = 9
# Fetch Test = http://p.p/user-manual/config.html
# Level = 9
# Fetch Test = http://p.p/user-manual/configuration.html
# Level = 9
# Fetch Test = http://p.p/user-manual/contact.html
# Level = 9
# Fetch Test = http://p.p/user-manual/copyright.html
# Level = 9
# Fetch Test = http://p.p/user-manual/files-in-use.jpg
# Level = 9
# Fetch Test = http://p.p/user-manual/filter-file.html
# Level = 9
# Fetch Test = http://p.p/user-manual/index.html
# Level = 9
# Fetch Test = http://p.p/user-manual/installation.html
# Level = 9
# Fetch Test = http://p.p/user-manual/introduction.html
# Level = 9
# Fetch Test = http://p.p/user-manual/p_doc.css
# Level = 9
# Fetch Test = http://p.p/user-manual/proxy2.jpg
# Level = 9
# Fetch Test = http://p.p/user-manual/proxy_setup.jpg
# Level = 9
# Fetch Test = http://p.p/user-manual/quickstart.html
# Level = 9
# Fetch Test = http://p.p/user-manual/seealso.html
# Level = 9
# Fetch Test = http://p.p/user-manual/startup.html
# Level = 9
# Fetch Test = http://p.p/user-manual/templates.html
# Level = 9
# Fetch Test = http://p.p/user-manual/whatsnew.html
# Level = 9


# Method Test = OPTIONS
# Method Test = GET
# Method Test = get
# Method Test = gEt
# Method Test = HEAD
# Method Test = POST
# Method Test = PUT
# Method Test = DELETE
# Method Test = OPTIONS
# Method Test = TRACE
# Method Test = CONNECT
# Level = 25
# Method Test = PROPFIND
# Method Test = PROPPATCH
# Method Test = MOVE
# Method Test = COPY
# Method Test = MKCOL
# Method Test = LOCK
# Method Test = UNLOCK
# Method Test = BCOPY
# Method Test = BMOVE
# Method Test = BDELETE
# Method Test = BPROPFIND
# Method Test = BPROPPATCH
# Method Test = SUBSCRIBE
# Method Test = UNSUBSCRIBE
# Method Test = NOTIFY
# Method Test = POLL
# Method Test = VERSION-CONTROL
# Method Test = REPORT
# Method Test = CHECKOUT
# Method Test = CHECKIN
# Method Test = UNCHECKOUT
# Method Test = MKWORKSPACE
# Method Test = UPDATE
# Method Test = LABEL
# 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

{+block{Forbidden Port. You are not supposed to see this.}}
config.privoxy.org:1-/
p.p:1-/

{-block}
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
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
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
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
forward5-null-gateway-host.example

{+limit-connect{443}}
# Fetch Test = http://www.forbidden-connect.example:444/
# Method = CONNECT
# Expect Status Code = 403
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
www.blocked-request.example/blocked-request

{+block}
# Fetch Test = http://www.blocked-request.example/blocked-request-with-no-reason-specified
# Expect Status Code = 403
www.blocked-request.example/blocked-request-with-no-reason-specified

# Some domain pattern tests
#
{+block{domain pattern test}}
# Blocked URL = http://domain-pattern-test.example/
# 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
# Expect Header = NO CHANGE
# Set Header = X-LWS-Test:  superfluous   white space  in  the   house
# Expect Header = X-LWS-Test: superfluous white space in the house
# Set Header = X-LWS-Test   :  superfluous   white   space   in   the    house
# Expect Header = X-LWS-Test: superfluous white space in the house
# Set Header = X-LWS-Test:  :superfluous white space in the house
# Expect Header = X-LWS-Test: :superfluous white space in the house
# Set Header = X-LWS-Test: :no superfluous white space here
# Expect Header = NO CHANGE
# Set Header = X-LWS-Test:	superfluous 		white 			tabs in the house
# Expect Header = X-LWS-Test: superfluous white tabs in the house
# Set Header = X-LWS-Test	:	superfluous 		white 			tabs in the house
# Expect Header = X-LWS-Test: superfluous white tabs in the house
# Set Header = X-LWS-Test: "leave  quoted  lws alone"
# Expect Header = X-LWS-Test: "leave  quoted  lws alone"
# Set Header = X-LWS-Test:  "leave  quoted  lws alone"  thxbye
# Expect Header = X-LWS-Test: "leave  quoted  lws alone" thxbye
# Set Header = X-LWS-Test: " Do I Look like	quoted  text? Me    thinks  not.
# Expect Header = X-LWS-Test: " Do I Look like quoted text? Me thinks not.
# Set Header = X-LWS-Test: "This  is  quoted" this  is  not "but   this  is  again"
# 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/

{+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$