From 499384b6d1a0082d538470d57ade37591e9251d6 Mon Sep 17 00:00:00 2001 From: Carlton Gibson Date: Thu, 4 Nov 2021 10:20:04 +0100 Subject: [PATCH] [4.0.x] Fixed #33237 -- Fixed detecting source maps in ManifestStaticFilesStorage for multiline files. Switched regex to multiline mode in order to match per-line, rather than against the whole file. Thanks to Joseph Abrahams for the report. Regression in 781b44240a06f0c868254f40f36ce46c927f56d1. Backport of 4816dc942860caf076c7c85ea9dbfa8bfab212ff from main --- django/contrib/staticfiles/storage.py | 2 +- tests/staticfiles_tests/project/documents/cached/source_map.js | 1 + tests/staticfiles_tests/test_storage.py | 2 +- 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/django/contrib/staticfiles/storage.py b/django/contrib/staticfiles/storage.py index 7cf43ed6ab8..bb66304a7e9 100644 --- a/django/contrib/staticfiles/storage.py +++ b/django/contrib/staticfiles/storage.py @@ -54,7 +54,7 @@ class HashedFilesMixin: )), ('*.js', ( ( - r'(?P)^(//# (?-i:sourceMappingURL)=(?P.*))$', + r'(?m)(?P)^(//# (?-i:sourceMappingURL)=(?P.*))$', '//# sourceMappingURL=%(url)s', ), ( diff --git a/tests/staticfiles_tests/project/documents/cached/source_map.js b/tests/staticfiles_tests/project/documents/cached/source_map.js index b37c5e57019..9d417868a08 100644 --- a/tests/staticfiles_tests/project/documents/cached/source_map.js +++ b/tests/staticfiles_tests/project/documents/cached/source_map.js @@ -1 +1,2 @@ //# sourceMappingURL=source_map.js.map +let a_variable = 1; diff --git a/tests/staticfiles_tests/test_storage.py b/tests/staticfiles_tests/test_storage.py index 0a34f643947..93335480be6 100644 --- a/tests/staticfiles_tests/test_storage.py +++ b/tests/staticfiles_tests/test_storage.py @@ -260,7 +260,7 @@ class TestHashedFiles: def test_js_source_map(self): relpath = self.hashed_file_path('cached/source_map.js') - self.assertEqual(relpath, 'cached/source_map.9371cbb02a26.js') + self.assertEqual(relpath, 'cached/source_map.cd45b8534a87.js') with storage.staticfiles_storage.open(relpath) as relfile: content = relfile.read() self.assertNotIn(b'//# sourceMappingURL=source_map.js.map', content)