{
  "id": "django__django-11848",
  "question": "django.utils.http.parse_http_date two digit year check is incorrect\nDescription\n\t \n\t\t(last modified by Ad Timmering)\n\t \nRFC 850 does not mention this, but in RFC 7231 (and there's something similar in RFC 2822), there's the following quote:\nRecipients of a timestamp value in rfc850-date format, which uses a\ntwo-digit year, MUST interpret a timestamp that appears to be more\nthan 50 years in the future as representing the most recent year in\nthe past that had the same last two digits.\nCurrent logic is hard coded to consider 0-69 to be in 2000-2069, and 70-99 to be 1970-1999, instead of comparing versus the current year.\n",
  "answer": "{\"task_id\": \"0d9757b7-0113-4121-b44c-e4bc11037e66\", \"workflow_run_id\": \"3136cdd9-2b99-4f91-8f11-125f5288db5b\", \"data\": {\"id\": \"3136cdd9-2b99-4f91-8f11-125f5288db5b\", \"workflow_id\": \"bc5a1a30-852f-4fd7-98f0-8fca2f23c564\", \"status\": \"succeeded\", \"outputs\": {\"ranked_patches\": \"```json\\n{\\n  \\\"ranked_patches\\\": [\\n    {\\n      \\\"patch_id\\\": 2,\\n      \\\"patch\\\": \\\"diff --git a/django/utils/http.py b/django/utils/http.py\\\\nindex 1234567..89abcde 100644\\\\n--- a/django/utils/http.py\\\\n+++ b/django/utils/http.py\\\\n@@ -45,8 +45,10 @@ def parse_http_date(date_string):\\\\n     except (ValueError, IndexError):\\\\n         raise\\\\n\\\\n+    current_year = datetime.datetime.now().year\\\\n     if 0 <= year <= 99:\\\\n-        if year <= 69:\\\\n-            year += 2000\\\\n-        else:\\\\n-            year += 1900\\\\n+        threshold_year = (current_year + 50) % 100\\\\n+        century = (current_year // 100) * 100\\\\n+        year += century if year <= threshold_year else century - 100\\\\n\\\\n     return datetime.datetime(year, month, day, hour, minute, second)\\\",\\n      \\\"rank\\\": 1,\\n      \\\"score\\\": 0.95,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.95,\\n        \\\"code_quality\\\": 0.95,\\n        \\\"risk_level\\\": 0.05,\\n        \\\"best_practices\\\": 0.95,\\n        \\\"test_coverage\\\": 0.9\\n      },\\n      \\\"reasoning\\\": \\\"This patch correctly implements the logic to determine the century based on the current year and a threshold, aligning well with RFC 7231. It is clear, concise, and minimizes the risk of introducing new bugs.\\\",\\n      \\\"recommendation\\\": \\\"Highly recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 1,\\n      \\\"patch\\\": \\\"diff --git a/django/utils/http.py b/django/utils/http.py\\\\nindex 1234567..89abcde 100644\\\\n--- a/django/utils/http.py\\\\n+++ b/django/utils/http.py\\\\n@@ -45,6 +45,8 @@ def parse_http_date(date_string):\\\\n     except (ValueError, IndexError):\\\\n         raise\\\\n\\\\n+    current_year = datetime.datetime.now().year\\\\n+    current_century = (current_year // 100) * 100\\\\n     if 0 <= year <= 99:\\\\n-        if year <= 69:\\\\n-            year += 2000\\\\n-        else:\\\\n-            year += 1900\\\\n+        year += current_century if year <= (current_year % 100 + 50) % 100 else current_century - 100\\\\n \\\\n     return datetime.datetime(year, month, day, hour, minute, second)\\\",\\n      \\\"rank\\\": 2,\\n      \\\"score\\\": 0.9,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.9,\\n        \\\"code_quality\\\": 0.9,\\n        \\\"risk_level\\\": 0.1,\\n        \\\"best_practices\\\": 0.9,\\n        \\\"test_coverage\\\": 0.85\\n      },\\n      \\\"reasoning\\\": \\\"This patch also correctly addresses the issue but uses a slightly more complex calculation for the threshold, which could be less intuitive. It still aligns with RFC 7231 and is a valid solution.\\\",\\n      \\\"recommendation\\\": \\\"Recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 3,\\n      \\\"patch\\\": \\\"diff --git a/django/utils/http.py b/django/utils/http.py\\\\nindex 1234567..89abcde 100644\\\\n--- a/django/utils/http.py\\\\n+++ b/django/utils/http.py\\\\n@@ -45,8 +45,10 @@ def parse_http_date(date_string):\\\\n     except (ValueError, IndexError):\\\\n         raise\\\\n\\\\n+    current_year = datetime.datetime.utcnow().year\\\\n     if 0 <= year <= 99:\\\\n-        if year <= 69:\\\\n-            year += 2000\\\\n-        else:\\\\n-            year += 1900\\\\n+        fifty_years_ago = (current_year - 50) % 100\\\\n+        current_century = current_year // 100 * 100\\\\n+        year += current_century if year > fifty_years_ago else current_century - 100\\\\n\\\\n     return datetime.datetime(year, month, day, hour, minute, second)\\\",\\n      \\\"rank\\\": 3,\\n      \\\"score\\\": 0.85,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.85,\\n        \\\"code_quality\\\": 0.85,\\n        \\\"risk_level\\\": 0.15,\\n        \\\"best_practices\\\": 0.85,\\n        \\\"test_coverage\\\": 0.8\\n      },\\n      \\\"reasoning\\\": \\\"This patch uses UTC time, which is unnecessary for this context and could introduce confusion. The logic is correct but less straightforward than the other patches.\\\",\\n      \\\"recommendation\\\": \\\"Acceptable but not preferred\\\"\\n    }\\n  ],\\n  \\\"evaluation_summary\\\": \\\"Patch 2 is the best choice due to its clear and concise implementation of the century calculation logic, aligning well with RFC 7231. Patch 1 is also correct but slightly more complex in its approach. Patch 3, while correct, uses UTC unnecessarily and is less intuitive.\\\"\\n}\\n```\", \"generated_tests\": \"{\\n  \\\"reproduction_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_original_issue\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_original_issue():\\\\n    # Test parsing a two-digit year that is more than 50 years in the future\\\\n    http_date = 'Tue, 19 Jan 52 08:52:00 GMT'  # Represents year 2052\\\\n    parsed_date = parse_http_date(http_date)\\\\n    assert parsed_date.year == 1952  # Expected year interpretation according to RFC 7231\\\",\\n      \\\"description\\\": \\\"This test reproduces the original issue by providing a two-digit year more than 50 years in the future\\\",\\n      \\\"expected_behavior\\\": \\\"The original logic would interpret the year as 2052. The patch should correct it to the most recent year in the past that had the same last two digits, which is 1952.\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_edge_cases\\\",\\n      \\\"test_code\\\": \\\"def test_edge_cases():\\\\n    # Test parsing edge cases of two-digit years close to the threshold\\\\n    http_date1 = 'Tue, 19 Jan 70 08:52:00 GMT'  # Represents year 1970\\\\n    parsed_date1 = parse_http_date(http_date1)\\\\n    assert parsed_date1.year == 1970  # Expected interpretation for 1970\\\\n    http_date2 = 'Tue, 19 Jan 69 08:52:00 GMT'  # Represents year 2069\\\\n    parsed_date2 = parse_http_date(http_date2)\\\\n    assert parsed_date2.year == 1969  # Expected interpretation for 2069 after patch\\\",\\n      \\\"description\\\": \\\"This test covers edge cases near the threshold for year interpretation\\\",\\n      \\\"expected_behavior\\\": \\\"The original logic might not handle edge cases correctly. The patch should adjust the two-digit year based on the current year to ensure correct interpretation.\\\"\\n    }\\n  ],\\n  \\\"validation_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation():\\\\n    # Test parsing a two-digit year with the patches applied\\\\n    http_date = 'Tue, 19 Jan 22 08:52:00 GMT'  # Represents year 2022\\\\n    parsed_date = parse_http_date(http_date)\\\\n    assert parsed_date.year == 2022  # Expected correct interpretation after patch\\\",\\n      \\\"description\\\": \\\"This test validates that the patches correctly fix the two-digit year interpretation issue\\\",\\n      \\\"expected_behavior\\\": \\\"After applying the patches, the function should correctly interpret the two-digit year according to RFC 7231\\\"\\n    }\\n  ],\\n  \\\"test_summary\\\": \\\"Generated test cases cover reproducing the original issue, testing edge cases, and validating the patches for correct functionality\\\"\\n}\"}, \"error\": \"\", \"elapsed_time\": 208.531371, \"total_tokens\": 13650, \"total_steps\": 9, \"created_at\": 1753287466, \"finished_at\": 1753287675}}"
}