Commit 6d2d1caa authored by Tarek Ziadé's avatar Tarek Ziadé

Fixed #7552: fixed distutils.command.upload failure on very long passwords

parent 6f9d7dc8
...@@ -6,7 +6,7 @@ import os ...@@ -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): ...@@ -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 ...@@ -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): ...@@ -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): ...@@ -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)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment