mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #30578 - Made SelectDateWidget respect a custom date format when USE_L10N is disabled.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							a289e79679
						
					
				
				
					commit
					26d16c07fd
				
			| @@ -1070,18 +1070,15 @@ class SelectDateWidget(Widget): | |||||||
|         if y == m == d == '': |         if y == m == d == '': | ||||||
|             return None |             return None | ||||||
|         if y is not None and m is not None and d is not None: |         if y is not None and m is not None and d is not None: | ||||||
|             if settings.USE_L10N: |             input_format = get_format('DATE_INPUT_FORMATS')[0] | ||||||
|                 input_format = get_format('DATE_INPUT_FORMATS')[0] |             try: | ||||||
|                 try: |                 date_value = datetime.date(int(y), int(m), int(d)) | ||||||
|                     date_value = datetime.date(int(y), int(m), int(d)) |             except ValueError: | ||||||
|                 except ValueError: |                 # Return pseudo-ISO dates with zeros for any unselected values, | ||||||
|                     pass |                 # e.g. '2017-0-23'. | ||||||
|                 else: |                 return '%s-%s-%s' % (y or 0, m or 0, d or 0) | ||||||
|                     date_value = datetime_safe.new_date(date_value) |             date_value = datetime_safe.new_date(date_value) | ||||||
|                     return date_value.strftime(input_format) |             return date_value.strftime(input_format) | ||||||
|             # Return pseudo-ISO dates with zeros for any unselected values, |  | ||||||
|             # e.g. '2017-0-23'. |  | ||||||
|             return '%s-%s-%s' % (y or 0, m or 0, d or 0) |  | ||||||
|         return data.get(name) |         return data.get(name) | ||||||
|  |  | ||||||
|     def value_omitted_from_data(self, data, files, name): |     def value_omitted_from_data(self, data, files, name): | ||||||
|   | |||||||
| @@ -22,7 +22,7 @@ class DateFieldTest(SimpleTestCase): | |||||||
|         # accept the input from the "as_hidden" rendering as well. |         # accept the input from the "as_hidden" rendering as well. | ||||||
|         self.assertHTMLEqual( |         self.assertHTMLEqual( | ||||||
|             a['mydate'].as_hidden(), |             a['mydate'].as_hidden(), | ||||||
|             '<input type="hidden" name="mydate" value="2008-4-1" id="id_mydate">', |             '<input type="hidden" name="mydate" value="2008-04-01" id="id_mydate">', | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|         b = GetDate({'mydate': '2008-4-1'}) |         b = GetDate({'mydate': '2008-4-1'}) | ||||||
|   | |||||||
| @@ -524,6 +524,21 @@ class SelectDateWidgetTest(WidgetTest): | |||||||
|             '13-08-0001', |             '13-08-0001', | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|  |     @override_settings(USE_L10N=False, DATE_INPUT_FORMATS=['%d.%m.%Y']) | ||||||
|  |     def test_custom_input_format(self): | ||||||
|  |         w = SelectDateWidget(years=('0001', '1899', '2009', '2010')) | ||||||
|  |         for values, expected in ( | ||||||
|  |             (('0001', '8', '13'), '13.08.0001'), | ||||||
|  |             (('1899', '7', '11'), '11.07.1899'), | ||||||
|  |             (('2009', '3', '7'), '07.03.2009'), | ||||||
|  |         ): | ||||||
|  |             with self.subTest(values=values): | ||||||
|  |                 data = { | ||||||
|  |                     'field_%s' % field: value | ||||||
|  |                     for field, value in zip(('year', 'month', 'day'), values) | ||||||
|  |                 } | ||||||
|  |                 self.assertEqual(w.value_from_datadict(data, {}, 'field'), expected) | ||||||
|  |  | ||||||
|     def test_format_value(self): |     def test_format_value(self): | ||||||
|         valid_formats = [ |         valid_formats = [ | ||||||
|             '2000-1-1', '2000-10-15', '2000-01-01', |             '2000-1-1', '2000-10-15', '2000-01-01', | ||||||
| @@ -545,7 +560,7 @@ class SelectDateWidgetTest(WidgetTest): | |||||||
|  |  | ||||||
|     def test_value_from_datadict(self): |     def test_value_from_datadict(self): | ||||||
|         tests = [ |         tests = [ | ||||||
|             (('2000', '12', '1'), '2000-12-1'), |             (('2000', '12', '1'), '2000-12-01'), | ||||||
|             (('', '12', '1'), '0-12-1'), |             (('', '12', '1'), '0-12-1'), | ||||||
|             (('2000', '', '1'), '2000-0-1'), |             (('2000', '', '1'), '2000-0-1'), | ||||||
|             (('2000', '12', ''), '2000-12-0'), |             (('2000', '12', ''), '2000-12-0'), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user