diff --git a/mercurial/hgweb/wsgicgi.py b/mercurial/hgweb/wsgicgi.py --- a/mercurial/hgweb/wsgicgi.py +++ b/mercurial/hgweb/wsgicgi.py @@ -9,10 +9,8 @@ # http://www.python.org/dev/peps/pep-0333/#the-server-gateway-side -import os - from ..pycompat import getattr -from .. import pycompat +from .. import encoding, pycompat from ..utils import procutil @@ -23,7 +21,10 @@ def launch(application): procutil.setbinary(procutil.stdin) procutil.setbinary(procutil.stdout) - environ = dict(os.environ.items()) # re-exports + environ = { + k.decode('iso8859-1'): v.decode('iso8859-1') + for k, v in encoding.environ.items() + } # re-exports environ.setdefault('PATH_INFO', '') if environ.get('SERVER_SOFTWARE', '').startswith('Microsoft-IIS'): # IIS includes script_name in PATH_INFO diff --git a/tests/test-wsgicgi.t b/tests/test-wsgicgi.t new file mode 100644 --- /dev/null +++ b/tests/test-wsgicgi.t @@ -0,0 +1,18 @@ + $ hg init test + $ cat >hgweb.cgi < #!$PYTHON + > from mercurial import demandimport; demandimport.enable() + > from mercurial.hgweb import hgweb + > from mercurial.hgweb import wsgicgi + > application = hgweb(b"test", b"Empty test repository") + > wsgicgi.launch(application) + > HGWEB + $ chmod 755 hgweb.cgi + +Check that non-ASCII bytes roundtrip correctly. + + $ . "$TESTDIR/cgienv" + $ PATH_INFO="/rev/$(python -c 'import sys; sys.stdout.buffer.write(b"\xe2\x80\x94")')"; export PATH_INFO + $ QUERY_STRING="style=raw"; export QUERY_STRING + $ "$PYTHON" ./hgweb.cgi | grep error + error: unknown revision '\xe2\x80\x94' (esc)