mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Removed IPAddressField per deprecation timeline; refs #20439.
This commit is contained in:
		| @@ -1894,13 +1894,13 @@ class BigIntegerField(IntegerField): | |||||||
| class IPAddressField(Field): | class IPAddressField(Field): | ||||||
|     empty_strings_allowed = False |     empty_strings_allowed = False | ||||||
|     description = _("IPv4 address") |     description = _("IPv4 address") | ||||||
|     system_check_deprecated_details = { |     system_check_removed_details = { | ||||||
|         'msg': ( |         'msg': ( | ||||||
|             'IPAddressField has been deprecated. Support for it (except in ' |             'IPAddressField has been removed except for support in ' | ||||||
|             'historical migrations) will be removed in Django 1.9.' |             'historical migrations.' | ||||||
|         ), |         ), | ||||||
|         'hint': 'Use GenericIPAddressField instead.', |         'hint': 'Use GenericIPAddressField instead.', | ||||||
|         'id': 'fields.W900', |         'id': 'fields.E900', | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     def __init__(self, *args, **kwargs): |     def __init__(self, *args, **kwargs): | ||||||
| @@ -1921,11 +1921,6 @@ class IPAddressField(Field): | |||||||
|     def get_internal_type(self): |     def get_internal_type(self): | ||||||
|         return "IPAddressField" |         return "IPAddressField" | ||||||
|  |  | ||||||
|     def formfield(self, **kwargs): |  | ||||||
|         defaults = {'form_class': forms.IPAddressField} |  | ||||||
|         defaults.update(kwargs) |  | ||||||
|         return super(IPAddressField, self).formfield(**defaults) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class GenericIPAddressField(Field): | class GenericIPAddressField(Field): | ||||||
|     empty_strings_allowed = False |     empty_strings_allowed = False | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ from django.utils import formats | |||||||
| from django.utils.encoding import smart_text, force_str, force_text | from django.utils.encoding import smart_text, force_str, force_text | ||||||
| from django.utils.ipv6 import clean_ipv6_address | from django.utils.ipv6 import clean_ipv6_address | ||||||
| from django.utils.dateparse import parse_duration | from django.utils.dateparse import parse_duration | ||||||
| from django.utils.deprecation import RemovedInDjango19Warning, RemovedInDjango20Warning, RenameMethodsBase | from django.utils.deprecation import RemovedInDjango20Warning, RenameMethodsBase | ||||||
| from django.utils.duration import duration_string | from django.utils.duration import duration_string | ||||||
| from django.utils import six | from django.utils import six | ||||||
| from django.utils.six.moves.urllib.parse import urlsplit, urlunsplit | from django.utils.six.moves.urllib.parse import urlsplit, urlunsplit | ||||||
| @@ -43,7 +43,7 @@ __all__ = ( | |||||||
|     'RegexField', 'EmailField', 'FileField', 'ImageField', 'URLField', |     'RegexField', 'EmailField', 'FileField', 'ImageField', 'URLField', | ||||||
|     'BooleanField', 'NullBooleanField', 'ChoiceField', 'MultipleChoiceField', |     'BooleanField', 'NullBooleanField', 'ChoiceField', 'MultipleChoiceField', | ||||||
|     'ComboField', 'MultiValueField', 'FloatField', 'DecimalField', |     'ComboField', 'MultiValueField', 'FloatField', 'DecimalField', | ||||||
|     'SplitDateTimeField', 'IPAddressField', 'GenericIPAddressField', 'FilePathField', |     'SplitDateTimeField', 'GenericIPAddressField', 'FilePathField', | ||||||
|     'SlugField', 'TypedChoiceField', 'TypedMultipleChoiceField', 'UUIDField', |     'SlugField', 'TypedChoiceField', 'TypedMultipleChoiceField', 'UUIDField', | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -1206,20 +1206,6 @@ class SplitDateTimeField(MultiValueField): | |||||||
|         return None |         return None | ||||||
|  |  | ||||||
|  |  | ||||||
| class IPAddressField(CharField): |  | ||||||
|     default_validators = [validators.validate_ipv4_address] |  | ||||||
|  |  | ||||||
|     def __init__(self, *args, **kwargs): |  | ||||||
|         warnings.warn("IPAddressField has been deprecated. Use GenericIPAddressField instead.", |  | ||||||
|                       RemovedInDjango19Warning) |  | ||||||
|         super(IPAddressField, self).__init__(*args, **kwargs) |  | ||||||
|  |  | ||||||
|     def to_python(self, value): |  | ||||||
|         if value in self.empty_values: |  | ||||||
|             return '' |  | ||||||
|         return value.strip() |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class GenericIPAddressField(CharField): | class GenericIPAddressField(CharField): | ||||||
|     def __init__(self, protocol='both', unpack_ipv4=False, *args, **kwargs): |     def __init__(self, protocol='both', unpack_ipv4=False, *args, **kwargs): | ||||||
|         self.unpack_ipv4 = unpack_ipv4 |         self.unpack_ipv4 = unpack_ipv4 | ||||||
|   | |||||||
| @@ -95,8 +95,11 @@ Fields | |||||||
| * **fields.E160**: The options ``auto_now``, ``auto_now_add``, and ``default`` | * **fields.E160**: The options ``auto_now``, ``auto_now_add``, and ``default`` | ||||||
|   are mutually exclusive. Only one of these options may be present. |   are mutually exclusive. Only one of these options may be present. | ||||||
| * **fields.W161**: Fixed default value provided. | * **fields.W161**: Fixed default value provided. | ||||||
|  | * **fields.E900**: ``IPAddressField`` has been removed except for support in | ||||||
|  |   historical migrations. | ||||||
| * **fields.W900**: ``IPAddressField`` has been deprecated. Support for it | * **fields.W900**: ``IPAddressField`` has been deprecated. Support for it | ||||||
|   (except in historical migrations) will be removed in Django 1.9. |   (except in historical migrations) will be removed in Django 1.9. *This check | ||||||
|  |   appeared in Django 1.7 and 1.8*. | ||||||
|  |  | ||||||
| File Fields | File Fields | ||||||
| ~~~~~~~~~~~ | ~~~~~~~~~~~ | ||||||
|   | |||||||
| @@ -719,22 +719,6 @@ For each field, we describe the default widget used if you don't specify | |||||||
|  |  | ||||||
|     These control the range of values permitted in the field. |     These control the range of values permitted in the field. | ||||||
|  |  | ||||||
| ``IPAddressField`` |  | ||||||
| ~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| .. class:: IPAddressField(**kwargs) |  | ||||||
|  |  | ||||||
|     .. deprecated:: 1.7 |  | ||||||
|         This field has been deprecated in favor of |  | ||||||
|         :class:`~django.forms.GenericIPAddressField`. |  | ||||||
|  |  | ||||||
|     * Default widget: :class:`TextInput` |  | ||||||
|     * Empty value: ``''`` (an empty string) |  | ||||||
|     * Normalizes to: A Unicode object. |  | ||||||
|     * Validates that the given value is a valid IPv4 address, using a regular |  | ||||||
|       expression. |  | ||||||
|     * Error message keys: ``required``, ``invalid`` |  | ||||||
|  |  | ||||||
| ``GenericIPAddressField`` | ``GenericIPAddressField`` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -892,18 +892,6 @@ An integer. Values from ``-2147483648`` to ``2147483647`` are safe in all | |||||||
| databases supported by Django. The default form widget for this field is a | databases supported by Django. The default form widget for this field is a | ||||||
| :class:`~django.forms.TextInput`. | :class:`~django.forms.TextInput`. | ||||||
|  |  | ||||||
| ``IPAddressField`` |  | ||||||
| ------------------ |  | ||||||
|  |  | ||||||
| .. class:: IPAddressField([**options]) |  | ||||||
|  |  | ||||||
| .. deprecated:: 1.7 |  | ||||||
|     This field has been deprecated in favor of |  | ||||||
|     :class:`~django.db.models.GenericIPAddressField`. |  | ||||||
|  |  | ||||||
| An IP address, in string format (e.g. "192.0.2.30"). The default form widget |  | ||||||
| for this field is a :class:`~django.forms.TextInput`. |  | ||||||
|  |  | ||||||
| ``GenericIPAddressField`` | ``GenericIPAddressField`` | ||||||
| ------------------------- | ------------------------- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -96,7 +96,7 @@ field classes did not correctly convert their arguments: | |||||||
|  |  | ||||||
| * :class:`~django.db.models.FilePathField` | * :class:`~django.db.models.FilePathField` | ||||||
| * :class:`~django.db.models.GenericIPAddressField` | * :class:`~django.db.models.GenericIPAddressField` | ||||||
| * :class:`~django.db.models.IPAddressField` | * ``IPAddressField`` | ||||||
|  |  | ||||||
| These three fields have been updated to convert their arguments to the | These three fields have been updated to convert their arguments to the | ||||||
| correct types before querying. | correct types before querying. | ||||||
|   | |||||||
| @@ -95,7 +95,7 @@ field classes did not correctly convert their arguments: | |||||||
|  |  | ||||||
| * :class:`~django.db.models.FilePathField` | * :class:`~django.db.models.FilePathField` | ||||||
| * :class:`~django.db.models.GenericIPAddressField` | * :class:`~django.db.models.GenericIPAddressField` | ||||||
| * :class:`~django.db.models.IPAddressField` | * ``IPAddressField`` | ||||||
|  |  | ||||||
| These three fields have been updated to convert their arguments to the | These three fields have been updated to convert their arguments to the | ||||||
| correct types before querying. | correct types before querying. | ||||||
|   | |||||||
| @@ -95,7 +95,7 @@ field classes did not correctly convert their arguments: | |||||||
|  |  | ||||||
| * :class:`~django.db.models.FilePathField` | * :class:`~django.db.models.FilePathField` | ||||||
| * :class:`~django.db.models.GenericIPAddressField` | * :class:`~django.db.models.GenericIPAddressField` | ||||||
| * :class:`~django.db.models.IPAddressField` | * ``IPAddressField`` | ||||||
|  |  | ||||||
| These three fields have been updated to convert their arguments to the | These three fields have been updated to convert their arguments to the | ||||||
| correct types before querying. | correct types before querying. | ||||||
|   | |||||||
| @@ -876,10 +876,8 @@ Miscellaneous | |||||||
|   :class:`~django.forms.ModelMultipleChoiceField`. |   :class:`~django.forms.ModelMultipleChoiceField`. | ||||||
|  |  | ||||||
| * Some :attr:`~django.forms.Field.error_messages` for | * Some :attr:`~django.forms.Field.error_messages` for | ||||||
|   :class:`~django.forms.IntegerField`, |   :class:`~django.forms.IntegerField`, :class:`~django.forms.EmailField`, | ||||||
|   :class:`~django.forms.EmailField`, |   ``IPAddressField``, :class:`~django.forms.GenericIPAddressField`, and | ||||||
|   :class:`~django.forms.IPAddressField`, |  | ||||||
|   :class:`~django.forms.GenericIPAddressField`, and |  | ||||||
|   :class:`~django.forms.SlugField` have been suppressed because they |   :class:`~django.forms.SlugField` have been suppressed because they | ||||||
|   duplicated error messages already provided by validators tied to the fields. |   duplicated error messages already provided by validators tied to the fields. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1591,8 +1591,8 @@ better handle the case of selectively showing inlines on a ``ModelAdmin``. | |||||||
| ``IPAddressField`` | ``IPAddressField`` | ||||||
| ~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| The :class:`django.db.models.IPAddressField` and | The ``django.db.models.IPAddressField`` and ``django.forms.IPAddressField`` | ||||||
| :class:`django.forms.IPAddressField` fields have been deprecated in favor of | fields have been deprecated in favor of | ||||||
| :class:`django.db.models.GenericIPAddressField` and | :class:`django.db.models.GenericIPAddressField` and | ||||||
| :class:`django.forms.GenericIPAddressField`. | :class:`django.forms.GenericIPAddressField`. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -29,7 +29,6 @@ class CaseTestModel(models.Model): | |||||||
|     float = models.FloatField(null=True, db_column='float_field') |     float = models.FloatField(null=True, db_column='float_field') | ||||||
|     if Image: |     if Image: | ||||||
|         image = models.ImageField(null=True) |         image = models.ImageField(null=True) | ||||||
|     ip_address = models.IPAddressField(null=True) |  | ||||||
|     generic_ip_address = models.GenericIPAddressField(null=True) |     generic_ip_address = models.GenericIPAddressField(null=True) | ||||||
|     null_boolean = models.NullBooleanField() |     null_boolean = models.NullBooleanField() | ||||||
|     positive_integer = models.PositiveIntegerField(null=True) |     positive_integer = models.PositiveIntegerField(null=True) | ||||||
|   | |||||||
| @@ -752,21 +752,6 @@ class CaseExpressionTests(TestCase): | |||||||
|             transform=lambda o: (o.integer, six.text_type(o.image)) |             transform=lambda o: (o.integer, six.text_type(o.image)) | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|     def test_update_ip_address(self): |  | ||||||
|         CaseTestModel.objects.update( |  | ||||||
|             ip_address=Case( |  | ||||||
|                 # fails on postgresql if output_field is not set explicitly |  | ||||||
|                 When(integer=1, then=Value('1.1.1.1')), |  | ||||||
|                 When(integer=2, then=Value('2.2.2.2')), |  | ||||||
|                 output_field=models.IPAddressField(), |  | ||||||
|             ), |  | ||||||
|         ) |  | ||||||
|         self.assertQuerysetEqual( |  | ||||||
|             CaseTestModel.objects.all().order_by('pk'), |  | ||||||
|             [(1, '1.1.1.1'), (2, '2.2.2.2'), (3, None), (2, '2.2.2.2'), (3, None), (3, None), (4, None)], |  | ||||||
|             transform=attrgetter('integer', 'ip_address') |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|     def test_update_generic_ip_address(self): |     def test_update_generic_ip_address(self): | ||||||
|         CaseTestModel.objects.update( |         CaseTestModel.objects.update( | ||||||
|             generic_ip_address=Case( |             generic_ip_address=Case( | ||||||
|   | |||||||
| @@ -5,12 +5,11 @@ from django.core.files.uploadedfile import SimpleUploadedFile | |||||||
| from django.forms import ( | from django.forms import ( | ||||||
|     BooleanField, CharField, ChoiceField, DateField, DateTimeField, |     BooleanField, CharField, ChoiceField, DateField, DateTimeField, | ||||||
|     DecimalField, EmailField, FileField, FloatField, Form, |     DecimalField, EmailField, FileField, FloatField, Form, | ||||||
|     GenericIPAddressField, IntegerField, IPAddressField, ModelChoiceField, |     GenericIPAddressField, IntegerField, ModelChoiceField, | ||||||
|     ModelMultipleChoiceField, MultipleChoiceField, RegexField, |     ModelMultipleChoiceField, MultipleChoiceField, RegexField, | ||||||
|     SplitDateTimeField, TimeField, URLField, utils, ValidationError, |     SplitDateTimeField, TimeField, URLField, utils, ValidationError, | ||||||
| ) | ) | ||||||
| from django.test import ignore_warnings, TestCase | from django.test import TestCase | ||||||
| from django.utils.deprecation import RemovedInDjango19Warning |  | ||||||
| from django.utils.safestring import mark_safe | from django.utils.safestring import mark_safe | ||||||
| from django.utils.encoding import python_2_unicode_compatible | from django.utils.encoding import python_2_unicode_compatible | ||||||
|  |  | ||||||
| @@ -197,16 +196,6 @@ class FormsErrorMessagesTestCase(TestCase, AssertFormErrorsMixin): | |||||||
|         self.assertFormErrors(['REQUIRED'], f.clean, '') |         self.assertFormErrors(['REQUIRED'], f.clean, '') | ||||||
|         self.assertFormErrors(['INVALID DATE', 'INVALID TIME'], f.clean, ['a', 'b']) |         self.assertFormErrors(['INVALID DATE', 'INVALID TIME'], f.clean, ['a', 'b']) | ||||||
|  |  | ||||||
|     @ignore_warnings(category=RemovedInDjango19Warning) |  | ||||||
|     def test_ipaddressfield(self): |  | ||||||
|         e = { |  | ||||||
|             'required': 'REQUIRED', |  | ||||||
|             'invalid': 'INVALID IP ADDRESS', |  | ||||||
|         } |  | ||||||
|         f = IPAddressField(error_messages=e) |  | ||||||
|         self.assertFormErrors(['REQUIRED'], f.clean, '') |  | ||||||
|         self.assertFormErrors(['INVALID IP ADDRESS'], f.clean, '127.0.0') |  | ||||||
|  |  | ||||||
|     def test_generic_ipaddressfield(self): |     def test_generic_ipaddressfield(self): | ||||||
|         e = { |         e = { | ||||||
|             'required': 'REQUIRED', |             'required': 'REQUIRED', | ||||||
|   | |||||||
| @@ -5,17 +5,16 @@ import datetime | |||||||
|  |  | ||||||
| from django.forms import ( | from django.forms import ( | ||||||
|     CharField, DateField, EmailField, FileField, Form, GenericIPAddressField, |     CharField, DateField, EmailField, FileField, Form, GenericIPAddressField, | ||||||
|     HiddenInput, ImageField, IPAddressField, MultipleChoiceField, |     HiddenInput, ImageField, MultipleChoiceField, MultiValueField, MultiWidget, | ||||||
|     MultiValueField, MultiWidget, PasswordInput, SelectMultiple, SlugField, |     PasswordInput, SelectMultiple, SlugField, SplitDateTimeField, | ||||||
|     SplitDateTimeField, SplitDateTimeWidget, TextInput, URLField, |     SplitDateTimeWidget, TextInput, URLField, | ||||||
| ) | ) | ||||||
| from django.forms.extras import SelectDateWidget | from django.forms.extras import SelectDateWidget | ||||||
| from django.forms.utils import ErrorList | from django.forms.utils import ErrorList | ||||||
| from django.test import TestCase, ignore_warnings, override_settings | from django.test import TestCase, override_settings | ||||||
| from django.utils import six | from django.utils import six | ||||||
| from django.utils import translation | from django.utils import translation | ||||||
| from django.utils.dates import MONTHS_AP | from django.utils.dates import MONTHS_AP | ||||||
| from django.utils.deprecation import RemovedInDjango19Warning |  | ||||||
| from django.utils.encoding import force_text, smart_text, python_2_unicode_compatible | from django.utils.encoding import force_text, smart_text, python_2_unicode_compatible | ||||||
|  |  | ||||||
| from .test_error_messages import AssertFormErrorsMixin | from .test_error_messages import AssertFormErrorsMixin | ||||||
| @@ -483,26 +482,6 @@ class FormsExtraTestCase(TestCase, AssertFormErrorsMixin): | |||||||
|  |  | ||||||
|         self.assertEqual(f.cleaned_data['field1'], 'some text,JP,2007-04-25 06:24:00') |         self.assertEqual(f.cleaned_data['field1'], 'some text,JP,2007-04-25 06:24:00') | ||||||
|  |  | ||||||
|     @ignore_warnings(category=RemovedInDjango19Warning) |  | ||||||
|     def test_ipaddress(self): |  | ||||||
|         f = IPAddressField() |  | ||||||
|         self.assertFormErrors(['This field is required.'], f.clean, '') |  | ||||||
|         self.assertFormErrors(['This field is required.'], f.clean, None) |  | ||||||
|         self.assertEqual(f.clean(' 127.0.0.1'), '127.0.0.1') |  | ||||||
|         self.assertFormErrors(['Enter a valid IPv4 address.'], f.clean, 'foo') |  | ||||||
|         self.assertFormErrors(['Enter a valid IPv4 address.'], f.clean, '127.0.0.') |  | ||||||
|         self.assertFormErrors(['Enter a valid IPv4 address.'], f.clean, '1.2.3.4.5') |  | ||||||
|         self.assertFormErrors(['Enter a valid IPv4 address.'], f.clean, '256.125.1.5') |  | ||||||
|  |  | ||||||
|         f = IPAddressField(required=False) |  | ||||||
|         self.assertEqual(f.clean(''), '') |  | ||||||
|         self.assertEqual(f.clean(None), '') |  | ||||||
|         self.assertEqual(f.clean(' 127.0.0.1'), '127.0.0.1') |  | ||||||
|         self.assertFormErrors(['Enter a valid IPv4 address.'], f.clean, 'foo') |  | ||||||
|         self.assertFormErrors(['Enter a valid IPv4 address.'], f.clean, '127.0.0.') |  | ||||||
|         self.assertFormErrors(['Enter a valid IPv4 address.'], f.clean, '1.2.3.4.5') |  | ||||||
|         self.assertFormErrors(['Enter a valid IPv4 address.'], f.clean, '256.125.1.5') |  | ||||||
|  |  | ||||||
|     def test_generic_ipaddress_invalid_arguments(self): |     def test_generic_ipaddress_invalid_arguments(self): | ||||||
|         self.assertRaises(ValueError, GenericIPAddressField, protocol="hamster") |         self.assertRaises(ValueError, GenericIPAddressField, protocol="hamster") | ||||||
|         self.assertRaises(ValueError, GenericIPAddressField, protocol="ipv4", unpack_ipv4=True) |         self.assertRaises(ValueError, GenericIPAddressField, protocol="ipv4", unpack_ipv4=True) | ||||||
|   | |||||||
| @@ -59,7 +59,6 @@ class ColumnTypes(models.Model): | |||||||
|     file_path_field = models.FilePathField() |     file_path_field = models.FilePathField() | ||||||
|     float_field = models.FloatField() |     float_field = models.FloatField() | ||||||
|     int_field = models.IntegerField() |     int_field = models.IntegerField() | ||||||
|     ip_address_field = models.IPAddressField() |  | ||||||
|     gen_ip_adress_field = models.GenericIPAddressField(protocol="ipv4") |     gen_ip_adress_field = models.GenericIPAddressField(protocol="ipv4") | ||||||
|     pos_int_field = models.PositiveIntegerField() |     pos_int_field = models.PositiveIntegerField() | ||||||
|     pos_small_int_field = models.PositiveSmallIntegerField() |     pos_small_int_field = models.PositiveSmallIntegerField() | ||||||
|   | |||||||
| @@ -61,11 +61,9 @@ class InspectDBTestCase(TestCase): | |||||||
|             assertFieldType('file_field', "models.CharField(max_length=100)") |             assertFieldType('file_field', "models.CharField(max_length=100)") | ||||||
|             assertFieldType('file_path_field', "models.CharField(max_length=100)") |             assertFieldType('file_path_field', "models.CharField(max_length=100)") | ||||||
|         if connection.features.can_introspect_ip_address_field: |         if connection.features.can_introspect_ip_address_field: | ||||||
|             assertFieldType('ip_address_field', "models.GenericIPAddressField()") |  | ||||||
|             assertFieldType('gen_ip_adress_field', "models.GenericIPAddressField()") |             assertFieldType('gen_ip_adress_field', "models.GenericIPAddressField()") | ||||||
|         elif (connection.features.can_introspect_max_length and |         elif (connection.features.can_introspect_max_length and | ||||||
|                 not connection.features.interprets_empty_strings_as_nulls): |                 not connection.features.interprets_empty_strings_as_nulls): | ||||||
|             assertFieldType('ip_address_field', "models.CharField(max_length=15)") |  | ||||||
|             assertFieldType('gen_ip_adress_field', "models.CharField(max_length=39)") |             assertFieldType('gen_ip_adress_field', "models.CharField(max_length=39)") | ||||||
|         if (connection.features.can_introspect_max_length and |         if (connection.features.can_introspect_max_length and | ||||||
|                 not connection.features.interprets_empty_strings_as_nulls): |                 not connection.features.interprets_empty_strings_as_nulls): | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								tests/invalid_models_tests/test_deprecated_fields.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								tests/invalid_models_tests/test_deprecated_fields.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | from django.core import checks | ||||||
|  | from django.db import models | ||||||
|  |  | ||||||
|  | from .base import IsolatedModelsTestCase | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class DeprecatedFieldssTests(IsolatedModelsTestCase): | ||||||
|  |     def test_IPAddressField_deprecated(self): | ||||||
|  |         class IPAddressModel(models.Model): | ||||||
|  |             ip = models.IPAddressField() | ||||||
|  |  | ||||||
|  |         model = IPAddressModel() | ||||||
|  |         self.assertEqual( | ||||||
|  |             model.check(), | ||||||
|  |             [checks.Error( | ||||||
|  |                 'IPAddressField has been removed except for support in ' | ||||||
|  |                 'historical migrations.', | ||||||
|  |                 hint='Use GenericIPAddressField instead.', | ||||||
|  |                 obj=IPAddressModel._meta.get_field('ip'), | ||||||
|  |                 id='fields.E900', | ||||||
|  |             )], | ||||||
|  |         ) | ||||||
							
								
								
									
										20
									
								
								tests/migrations/deprecated_field_migrations/0001_initial.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								tests/migrations/deprecated_field_migrations/0001_initial.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | # -*- coding: utf-8 -*- | ||||||
|  | from __future__ import unicode_literals | ||||||
|  |  | ||||||
|  | from django.db import models, migrations | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Migration(migrations.Migration): | ||||||
|  |  | ||||||
|  |     dependencies = [ | ||||||
|  |     ] | ||||||
|  |  | ||||||
|  |     operations = [ | ||||||
|  |         migrations.CreateModel( | ||||||
|  |             name='IPAddressField', | ||||||
|  |             fields=[ | ||||||
|  |                 ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), | ||||||
|  |                 ('ip', models.IPAddressField(null=True, blank=True)), | ||||||
|  |             ], | ||||||
|  |         ), | ||||||
|  |     ] | ||||||
| @@ -0,0 +1,18 @@ | |||||||
|  | # -*- coding: utf-8 -*- | ||||||
|  | from __future__ import unicode_literals | ||||||
|  |  | ||||||
|  | from django.db import migrations | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Migration(migrations.Migration): | ||||||
|  |  | ||||||
|  |     dependencies = [ | ||||||
|  |         ('migrations', '0001_initial'), | ||||||
|  |     ] | ||||||
|  |  | ||||||
|  |     operations = [ | ||||||
|  |         migrations.RemoveField( | ||||||
|  |             model_name='ipaddressfield', | ||||||
|  |             name='ip', | ||||||
|  |         ), | ||||||
|  |     ] | ||||||
							
								
								
									
										22
									
								
								tests/migrations/test_deprecated_fields.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								tests/migrations/test_deprecated_fields.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | from django.core.management import call_command | ||||||
|  | from django.test import override_settings | ||||||
|  |  | ||||||
|  | from .test_base import MigrationTestBase | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Tests(MigrationTestBase): | ||||||
|  |     """ | ||||||
|  |     Deprecated model fields should still be usable in historic migrations. | ||||||
|  |     """ | ||||||
|  |     @override_settings(MIGRATION_MODULES={"migrations": "migrations.deprecated_field_migrations"}) | ||||||
|  |     def test_migrate(self): | ||||||
|  |         # Make sure no tables are created | ||||||
|  |         self.assertTableNotExists("migrations_ipaddressfield") | ||||||
|  |         # Run migration | ||||||
|  |         call_command("migrate", verbosity=0) | ||||||
|  |         # Make sure the right tables exist | ||||||
|  |         self.assertTableExists("migrations_ipaddressfield") | ||||||
|  |         # Unmigrate everything | ||||||
|  |         call_command("migrate", "migrations", "zero", verbosity=0) | ||||||
|  |         # Make sure it's all gone | ||||||
|  |         self.assertTableNotExists("migrations_ipaddressfield") | ||||||
| @@ -168,16 +168,15 @@ class VerboseNameField(models.Model): | |||||||
|     # Don't want to depend on Pillow in this test |     # Don't want to depend on Pillow in this test | ||||||
|     #field_image = models.ImageField("verbose field") |     #field_image = models.ImageField("verbose field") | ||||||
|     field12 = models.IntegerField("verbose field12") |     field12 = models.IntegerField("verbose field12") | ||||||
|     field13 = models.IPAddressField("verbose field13") |     field13 = models.GenericIPAddressField("verbose field13", protocol="ipv4") | ||||||
|     field14 = models.GenericIPAddressField("verbose field14", protocol="ipv4") |     field14 = models.NullBooleanField("verbose field14") | ||||||
|     field15 = models.NullBooleanField("verbose field15") |     field15 = models.PositiveIntegerField("verbose field15") | ||||||
|     field16 = models.PositiveIntegerField("verbose field16") |     field16 = models.PositiveSmallIntegerField("verbose field16") | ||||||
|     field17 = models.PositiveSmallIntegerField("verbose field17") |     field17 = models.SlugField("verbose field17") | ||||||
|     field18 = models.SlugField("verbose field18") |     field18 = models.SmallIntegerField("verbose field18") | ||||||
|     field19 = models.SmallIntegerField("verbose field19") |     field19 = models.TextField("verbose field19") | ||||||
|     field20 = models.TextField("verbose field20") |     field20 = models.TimeField("verbose field20") | ||||||
|     field21 = models.TimeField("verbose field21") |     field21 = models.URLField("verbose field21") | ||||||
|     field22 = models.URLField("verbose field22") |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class GenericIPAddress(models.Model): | class GenericIPAddress(models.Model): | ||||||
| @@ -323,7 +322,6 @@ class AllFieldsModel(models.Model): | |||||||
|     file_path = models.FilePathField() |     file_path = models.FilePathField() | ||||||
|     floatf = models.FloatField() |     floatf = models.FloatField() | ||||||
|     integer = models.IntegerField() |     integer = models.IntegerField() | ||||||
|     ip_address = models.IPAddressField() |  | ||||||
|     generic_ip = models.GenericIPAddressField() |     generic_ip = models.GenericIPAddressField() | ||||||
|     null_boolean = models.NullBooleanField() |     null_boolean = models.NullBooleanField() | ||||||
|     positive_integer = models.PositiveIntegerField() |     positive_integer = models.PositiveIntegerField() | ||||||
|   | |||||||
| @@ -75,7 +75,7 @@ class BasicFieldTests(test.TestCase): | |||||||
|  |  | ||||||
|     def test_field_verbose_name(self): |     def test_field_verbose_name(self): | ||||||
|         m = VerboseNameField |         m = VerboseNameField | ||||||
|         for i in range(1, 23): |         for i in range(1, 22): | ||||||
|             self.assertEqual(m._meta.get_field('field%d' % i).verbose_name, |             self.assertEqual(m._meta.get_field('field%d' % i).verbose_name, | ||||||
|                              'verbose field%d' % i) |                              'verbose field%d' % i) | ||||||
|  |  | ||||||
| @@ -819,22 +819,6 @@ class PromiseTest(test.TestCase): | |||||||
|             IPAddressField().get_prep_value(lazy_func()), |             IPAddressField().get_prep_value(lazy_func()), | ||||||
|             six.text_type) |             six.text_type) | ||||||
|  |  | ||||||
|     def test_IPAddressField_deprecated(self): |  | ||||||
|         class IPAddressModel(models.Model): |  | ||||||
|             ip = IPAddressField() |  | ||||||
|  |  | ||||||
|         model = IPAddressModel() |  | ||||||
|         self.assertEqual( |  | ||||||
|             model.check(), |  | ||||||
|             [checks.Warning( |  | ||||||
|                 'IPAddressField has been deprecated. Support for it ' |  | ||||||
|                 '(except in historical migrations) will be removed in Django 1.9.', |  | ||||||
|                 hint='Use GenericIPAddressField instead.', |  | ||||||
|                 obj=IPAddressModel._meta.get_field('ip'), |  | ||||||
|                 id='fields.W900', |  | ||||||
|             )], |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|     def test_GenericIPAddressField(self): |     def test_GenericIPAddressField(self): | ||||||
|         lazy_func = lazy(lambda: '127.0.0.1', six.text_type) |         lazy_func = lazy(lambda: '127.0.0.1', six.text_type) | ||||||
|         self.assertIsInstance( |         self.assertIsInstance( | ||||||
|   | |||||||
| @@ -65,10 +65,6 @@ class BigIntegerData(models.Model): | |||||||
| #    data = models.ImageField(null=True) | #    data = models.ImageField(null=True) | ||||||
|  |  | ||||||
|  |  | ||||||
| class IPAddressData(models.Model): |  | ||||||
|     data = models.IPAddressField(null=True) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class GenericIPAddressData(models.Model): | class GenericIPAddressData(models.Model): | ||||||
|     data = models.GenericIPAddressField(null=True) |     data = models.GenericIPAddressField(null=True) | ||||||
|  |  | ||||||
| @@ -245,10 +241,6 @@ class IntegerPKData(models.Model): | |||||||
| #    data = models.ImageField(primary_key=True) | #    data = models.ImageField(primary_key=True) | ||||||
|  |  | ||||||
|  |  | ||||||
| class IPAddressPKData(models.Model): |  | ||||||
|     data = models.IPAddressField(primary_key=True) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class GenericIPAddressPKData(models.Model): | class GenericIPAddressPKData(models.Model): | ||||||
|     data = models.GenericIPAddressField(primary_key=True) |     data = models.GenericIPAddressField(primary_key=True) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -28,13 +28,13 @@ from django.utils import six | |||||||
| from django.utils.functional import curry | from django.utils.functional import curry | ||||||
|  |  | ||||||
| from .models import (BinaryData, BooleanData, CharData, DateData, DateTimeData, EmailData, | from .models import (BinaryData, BooleanData, CharData, DateData, DateTimeData, EmailData, | ||||||
|     FileData, FilePathData, DecimalData, FloatData, IntegerData, IPAddressData, |     FileData, FilePathData, DecimalData, FloatData, IntegerData, | ||||||
|     GenericIPAddressData, NullBooleanData, PositiveIntegerData, |     GenericIPAddressData, NullBooleanData, PositiveIntegerData, | ||||||
|     PositiveSmallIntegerData, SlugData, SmallData, TextData, TimeData, |     PositiveSmallIntegerData, SlugData, SmallData, TextData, TimeData, | ||||||
|     GenericData, Anchor, UniqueAnchor, FKData, M2MData, O2OData, |     GenericData, Anchor, UniqueAnchor, FKData, M2MData, O2OData, | ||||||
|     FKSelfData, M2MSelfData, FKDataToField, FKDataToO2O, M2MIntermediateData, |     FKSelfData, M2MSelfData, FKDataToField, FKDataToO2O, M2MIntermediateData, | ||||||
|     Intermediate, BooleanPKData, CharPKData, EmailPKData, FilePathPKData, |     Intermediate, BooleanPKData, CharPKData, EmailPKData, FilePathPKData, | ||||||
|     DecimalPKData, FloatPKData, IntegerPKData, IPAddressPKData, |     DecimalPKData, FloatPKData, IntegerPKData, | ||||||
|     GenericIPAddressPKData, PositiveIntegerPKData, |     GenericIPAddressPKData, PositiveIntegerPKData, | ||||||
|     PositiveSmallIntegerPKData, SlugPKData, SmallPKData, |     PositiveSmallIntegerPKData, SlugPKData, SmallPKData, | ||||||
|     AutoNowDateTimeData, ModifyingSaveData, InheritAbstractModel, BaseModel, |     AutoNowDateTimeData, ModifyingSaveData, InheritAbstractModel, BaseModel, | ||||||
| @@ -241,8 +241,6 @@ test_data = [ | |||||||
|     (data_obj, 82, IntegerData, 0), |     (data_obj, 82, IntegerData, 0), | ||||||
|     (data_obj, 83, IntegerData, None), |     (data_obj, 83, IntegerData, None), | ||||||
|     #(XX, ImageData |     #(XX, ImageData | ||||||
|     (data_obj, 90, IPAddressData, "127.0.0.1"), |  | ||||||
|     (data_obj, 91, IPAddressData, None), |  | ||||||
|     (data_obj, 95, GenericIPAddressData, "fe80:1424:2223:6cff:fe8a:2e8a:2151:abcd"), |     (data_obj, 95, GenericIPAddressData, "fe80:1424:2223:6cff:fe8a:2e8a:2151:abcd"), | ||||||
|     (data_obj, 96, GenericIPAddressData, None), |     (data_obj, 96, GenericIPAddressData, None), | ||||||
|     (data_obj, 100, NullBooleanData, True), |     (data_obj, 100, NullBooleanData, True), | ||||||
| @@ -341,7 +339,6 @@ The end."""), | |||||||
|     (pk_obj, 681, IntegerPKData, -123456789), |     (pk_obj, 681, IntegerPKData, -123456789), | ||||||
|     (pk_obj, 682, IntegerPKData, 0), |     (pk_obj, 682, IntegerPKData, 0), | ||||||
|     # (XX, ImagePKData |     # (XX, ImagePKData | ||||||
|     (pk_obj, 690, IPAddressPKData, "127.0.0.1"), |  | ||||||
|     (pk_obj, 695, GenericIPAddressPKData, "fe80:1424:2223:6cff:fe8a:2e8a:2151:abcd"), |     (pk_obj, 695, GenericIPAddressPKData, "fe80:1424:2223:6cff:fe8a:2e8a:2151:abcd"), | ||||||
|     # (pk_obj, 700, NullBooleanPKData, True), |     # (pk_obj, 700, NullBooleanPKData, True), | ||||||
|     # (pk_obj, 701, NullBooleanPKData, False), |     # (pk_obj, 701, NullBooleanPKData, False), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user