mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	[py3] Removed uses of sys.maxint under Python 3.
Also fixed #18706: improved exceptions raised by int_to_base36.
This commit is contained in:
		| @@ -167,8 +167,9 @@ def base36_to_int(s): | |||||||
|     if len(s) > 13: |     if len(s) > 13: | ||||||
|         raise ValueError("Base36 input too large") |         raise ValueError("Base36 input too large") | ||||||
|     value = int(s, 36) |     value = int(s, 36) | ||||||
|     # ... then do a final check that the value will fit into an int. |     # ... then do a final check that the value will fit into an int to avoid | ||||||
|     if value > sys.maxint: |     # returning a long (#15067). The long type was removed in Python 3. | ||||||
|  |     if not six.PY3 and value > sys.maxint: | ||||||
|         raise ValueError("Base36 input too large") |         raise ValueError("Base36 input too large") | ||||||
|     return value |     return value | ||||||
|  |  | ||||||
| @@ -178,8 +179,13 @@ def int_to_base36(i): | |||||||
|     """ |     """ | ||||||
|     digits = "0123456789abcdefghijklmnopqrstuvwxyz" |     digits = "0123456789abcdefghijklmnopqrstuvwxyz" | ||||||
|     factor = 0 |     factor = 0 | ||||||
|     if not 0 <= i <= sys.maxint: |     if i < 0: | ||||||
|         raise ValueError("Base36 conversion input too large or incorrect type.") |         raise ValueError("Negative base36 conversion input.") | ||||||
|  |     if not six.PY3: | ||||||
|  |         if not isinstance(i, six.integer_types): | ||||||
|  |             raise TypeError("Non-integer base36 conversion input.") | ||||||
|  |         if i > sys.maxint: | ||||||
|  |             raise ValueError("Base36 conversion input too large.") | ||||||
|     # Find starting factor |     # Find starting factor | ||||||
|     while True: |     while True: | ||||||
|         factor += 1 |         factor += 1 | ||||||
|   | |||||||
| @@ -504,11 +504,13 @@ escaping HTML. | |||||||
|  |  | ||||||
| .. function:: base36_to_int(s) | .. function:: base36_to_int(s) | ||||||
|  |  | ||||||
|     Converts a base 36 string to an integer. |     Converts a base 36 string to an integer. On Python 2 the output is | ||||||
|  |     guaranteed to be an :class:`int` and not a :class:`long`. | ||||||
|  |  | ||||||
| .. function:: int_to_base36(i) | .. function:: int_to_base36(i) | ||||||
|  |  | ||||||
|     Converts a positive integer less than sys.maxint to a base 36 string. |     Converts a positive integer to a base 36 string. On Python 2 ``i`` must be | ||||||
|  |     smaller than :attr:`sys.maxint`. | ||||||
|  |  | ||||||
| ``django.utils.safestring`` | ``django.utils.safestring`` | ||||||
| =========================== | =========================== | ||||||
|   | |||||||
| @@ -244,6 +244,9 @@ Miscellaneous | |||||||
|  |  | ||||||
| * GeoDjango dropped support for GDAL < 1.5 | * GeoDjango dropped support for GDAL < 1.5 | ||||||
|  |  | ||||||
|  | * :func:`~django.utils.http.int_to_base36` properly raises a :exc:`TypeError` | ||||||
|  |   instead of :exc:`ValueError` for non-integer inputs. | ||||||
|  |  | ||||||
| Features deprecated in 1.5 | Features deprecated in 1.5 | ||||||
| ========================== | ========================== | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,10 +1,11 @@ | |||||||
| import sys | import sys | ||||||
|  |  | ||||||
| from django.utils import http |  | ||||||
| from django.utils import unittest |  | ||||||
| from django.utils.datastructures import MultiValueDict |  | ||||||
| from django.http import HttpResponse, utils | from django.http import HttpResponse, utils | ||||||
| from django.test import RequestFactory | from django.test import RequestFactory | ||||||
|  | from django.utils.datastructures import MultiValueDict | ||||||
|  | from django.utils import http | ||||||
|  | from django.utils import six | ||||||
|  | from django.utils import unittest | ||||||
|  |  | ||||||
| class TestUtilsHttp(unittest.TestCase): | class TestUtilsHttp(unittest.TestCase): | ||||||
|  |  | ||||||
| @@ -110,22 +111,23 @@ class TestUtilsHttp(unittest.TestCase): | |||||||
|  |  | ||||||
|     def test_base36(self): |     def test_base36(self): | ||||||
|         # reciprocity works |         # reciprocity works | ||||||
|         for n in [0, 1, 1000, 1000000, sys.maxint]: |         for n in [0, 1, 1000, 1000000]: | ||||||
|             self.assertEqual(n, http.base36_to_int(http.int_to_base36(n))) |             self.assertEqual(n, http.base36_to_int(http.int_to_base36(n))) | ||||||
|  |         if not six.PY3: | ||||||
|  |             self.assertEqual(sys.maxint, http.base36_to_int(http.int_to_base36(sys.maxint))) | ||||||
|  |  | ||||||
|         # bad input |         # bad input | ||||||
|         for n in [-1, sys.maxint+1, '1', 'foo', {1:2}, (1,2,3)]: |         self.assertRaises(ValueError, http.int_to_base36, -1) | ||||||
|             self.assertRaises(ValueError, http.int_to_base36, n) |         if not six.PY3: | ||||||
|  |             self.assertRaises(ValueError, http.int_to_base36, sys.maxint + 1) | ||||||
|  |         for n in ['1', 'foo', {1: 2}, (1, 2, 3), 3.141]: | ||||||
|  |             self.assertRaises(TypeError, http.int_to_base36, n) | ||||||
|  |  | ||||||
|         for n in ['#', ' ']: |         for n in ['#', ' ']: | ||||||
|             self.assertRaises(ValueError, http.base36_to_int, n) |             self.assertRaises(ValueError, http.base36_to_int, n) | ||||||
|  |         for n in [123, {1: 2}, (1, 2, 3), 3.141]: | ||||||
|         for n in [123, {1:2}, (1,2,3)]: |  | ||||||
|             self.assertRaises(TypeError, http.base36_to_int, n) |             self.assertRaises(TypeError, http.base36_to_int, n) | ||||||
|  |  | ||||||
|         # non-integer input |  | ||||||
|         self.assertRaises(TypeError, http.int_to_base36, 3.141) |  | ||||||
|          |  | ||||||
|         # more explicit output testing |         # more explicit output testing | ||||||
|         for n, b36 in [(0, '0'), (1, '1'), (42, '16'), (818469960, 'django')]: |         for n, b36 in [(0, '0'), (1, '1'), (42, '16'), (818469960, 'django')]: | ||||||
|             self.assertEqual(http.int_to_base36(n), b36) |             self.assertEqual(http.int_to_base36(n), b36) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user