mirror of
https://github.com/python/cpython.git
synced 2025-09-26 18:29:57 +00:00
Fixed #7552: fixed distutils.command.upload failure on very long passwords
This commit is contained in:
parent
603ae9e371
commit
2421d56e02
3 changed files with 33 additions and 8 deletions
|
@ -6,7 +6,7 @@ import os
|
||||||
import socket
|
import socket
|
||||||
import platform
|
import platform
|
||||||
from urllib2 import urlopen, Request, HTTPError
|
from urllib2 import urlopen, Request, HTTPError
|
||||||
import base64
|
from base64 import standard_b64encode
|
||||||
import urlparse
|
import urlparse
|
||||||
import cStringIO as StringIO
|
import cStringIO as StringIO
|
||||||
from ConfigParser import ConfigParser
|
from ConfigParser import ConfigParser
|
||||||
|
@ -129,8 +129,8 @@ class upload(PyPIRCCommand):
|
||||||
open(filename+".asc").read())
|
open(filename+".asc").read())
|
||||||
|
|
||||||
# set up the authentication
|
# set up the authentication
|
||||||
auth = "Basic " + base64.encodestring(self.username + ":" +
|
auth = "Basic " + standard_b64encode(self.username + ":" +
|
||||||
self.password).strip()
|
self.password)
|
||||||
|
|
||||||
# Build up the MIME payload for the POST data
|
# Build up the MIME payload for the POST data
|
||||||
boundary = '--------------GHSKFJDLGDS7543FJKLFHRE75642756743254'
|
boundary = '--------------GHSKFJDLGDS7543FJKLFHRE75642756743254'
|
||||||
|
|
|
@ -10,6 +10,25 @@ from distutils.core import Distribution
|
||||||
from distutils.tests import support
|
from distutils.tests import support
|
||||||
from distutils.tests.test_config import PYPIRC, PyPIRCCommandTestCase
|
from distutils.tests.test_config import PYPIRC, PyPIRCCommandTestCase
|
||||||
|
|
||||||
|
PYPIRC_LONG_PASSWORD = """\
|
||||||
|
[distutils]
|
||||||
|
|
||||||
|
index-servers =
|
||||||
|
server1
|
||||||
|
server2
|
||||||
|
|
||||||
|
[server1]
|
||||||
|
username:me
|
||||||
|
password:aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
|
||||||
|
|
||||||
|
[server2]
|
||||||
|
username:meagain
|
||||||
|
password: secret
|
||||||
|
realm:acme
|
||||||
|
repository:http://another.pypi/
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
PYPIRC_NOPASSWORD = """\
|
PYPIRC_NOPASSWORD = """\
|
||||||
[distutils]
|
[distutils]
|
||||||
|
|
||||||
|
@ -85,7 +104,7 @@ class uploadTestCase(PyPIRCCommandTestCase):
|
||||||
self.write_file(path)
|
self.write_file(path)
|
||||||
command, pyversion, filename = 'xxx', '2.6', path
|
command, pyversion, filename = 'xxx', '2.6', path
|
||||||
dist_files = [(command, pyversion, filename)]
|
dist_files = [(command, pyversion, filename)]
|
||||||
self.write_file(self.rc, PYPIRC)
|
self.write_file(self.rc, PYPIRC_LONG_PASSWORD)
|
||||||
|
|
||||||
# lets run it
|
# lets run it
|
||||||
pkg_dir, dist = self.create_dist(dist_files=dist_files)
|
pkg_dir, dist = self.create_dist(dist_files=dist_files)
|
||||||
|
@ -101,6 +120,8 @@ class uploadTestCase(PyPIRCCommandTestCase):
|
||||||
self.assertEquals(self.last_open.req.get_full_url(),
|
self.assertEquals(self.last_open.req.get_full_url(),
|
||||||
'http://pypi.python.org/pypi')
|
'http://pypi.python.org/pypi')
|
||||||
self.assertTrue('xxx' in self.last_open.req.data)
|
self.assertTrue('xxx' in self.last_open.req.data)
|
||||||
|
auth = self.last_open.req.headers['Authorization']
|
||||||
|
self.assertFalse('\n' in auth)
|
||||||
|
|
||||||
def test_suite():
|
def test_suite():
|
||||||
return unittest.makeSuite(uploadTestCase)
|
return unittest.makeSuite(uploadTestCase)
|
||||||
|
|
|
@ -24,6 +24,10 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #7552: Removed line feed in the base64 Authorization header in
|
||||||
|
the Distutils upload command to avoid an error when PyPI reads it.
|
||||||
|
This occurs on long passwords. Initial patch by JP St. Pierre.
|
||||||
|
|
||||||
- Issue #7231: urllib2 cannot handle https with proxy requiring auth.
|
- Issue #7231: urllib2 cannot handle https with proxy requiring auth.
|
||||||
Patch by Tatsuhiro Tsujikawa.
|
Patch by Tatsuhiro Tsujikawa.
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue