2015-07-01 13:43:25 +02:00
|
|
|
import os
|
|
|
|
|
|
|
|
from django.conf import settings
|
|
|
|
from django.contrib.staticfiles import finders, storage
|
|
|
|
from django.core.exceptions import ImproperlyConfigured
|
|
|
|
from django.test import SimpleTestCase, override_settings
|
2024-06-28 13:39:55 +02:00
|
|
|
from django.utils.deprecation import RemovedInDjango61Warning
|
2015-07-01 13:43:25 +02:00
|
|
|
|
|
|
|
from .cases import StaticFilesTestCase
|
|
|
|
from .settings import TEST_ROOT
|
|
|
|
|
2024-06-08 20:36:58 +02:00
|
|
|
DEPRECATION_MSG = (
|
|
|
|
"Passing the `all` argument to find() is deprecated. Use `find_all` instead."
|
|
|
|
)
|
|
|
|
|
2015-07-01 13:43:25 +02:00
|
|
|
|
2017-01-19 02:39:46 -05:00
|
|
|
class TestFinders:
|
2015-07-01 13:43:25 +02:00
|
|
|
"""
|
|
|
|
Base finder test mixin.
|
|
|
|
|
|
|
|
On Windows, sometimes the case of the path we ask the finders for and the
|
|
|
|
path(s) they find can differ. Compare them using os.path.normcase() to
|
|
|
|
avoid false negatives.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2015-07-01 13:43:25 +02:00
|
|
|
def test_find_first(self):
|
|
|
|
src, dst = self.find_first
|
|
|
|
found = self.finder.find(src)
|
|
|
|
self.assertEqual(os.path.normcase(found), os.path.normcase(dst))
|
|
|
|
|
|
|
|
def test_find_all(self):
|
|
|
|
src, dst = self.find_all
|
2024-06-08 20:36:58 +02:00
|
|
|
found = self.finder.find(src, find_all=True)
|
2015-07-01 13:43:25 +02:00
|
|
|
found = [os.path.normcase(f) for f in found]
|
|
|
|
dst = [os.path.normcase(d) for d in dst]
|
|
|
|
self.assertEqual(found, dst)
|
|
|
|
|
2024-06-08 20:36:58 +02:00
|
|
|
def test_find_all_deprecated_param(self):
|
|
|
|
src, dst = self.find_all
|
2024-08-09 12:35:28 -04:00
|
|
|
with self.assertWarnsMessage(RemovedInDjango61Warning, DEPRECATION_MSG) as ctx:
|
2024-06-08 20:36:58 +02:00
|
|
|
found = self.finder.find(src, all=True)
|
|
|
|
found = [os.path.normcase(f) for f in found]
|
|
|
|
dst = [os.path.normcase(d) for d in dst]
|
|
|
|
self.assertEqual(found, dst)
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertEqual(ctx.filename, __file__)
|
2024-06-08 20:36:58 +02:00
|
|
|
|
|
|
|
def test_find_all_conflicting_params(self):
|
|
|
|
src, dst = self.find_all
|
|
|
|
msg = (
|
|
|
|
f"{self.finder.__class__.__qualname__}.find() got multiple values for "
|
|
|
|
"argument 'find_all'"
|
|
|
|
)
|
|
|
|
with (
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertWarnsMessage(RemovedInDjango61Warning, DEPRECATION_MSG) as ctx,
|
2024-06-08 20:36:58 +02:00
|
|
|
self.assertRaisesMessage(TypeError, msg),
|
|
|
|
):
|
|
|
|
self.finder.find(src, find_all=True, all=True)
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertEqual(ctx.filename, __file__)
|
2024-06-08 20:36:58 +02:00
|
|
|
|
|
|
|
def test_find_all_unexpected_params(self):
|
|
|
|
src, dst = self.find_all
|
|
|
|
msg = (
|
|
|
|
f"{self.finder.__class__.__qualname__}.find() got an unexpected keyword "
|
|
|
|
"argument 'wrong'"
|
|
|
|
)
|
|
|
|
with (
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertWarnsMessage(RemovedInDjango61Warning, DEPRECATION_MSG) as ctx,
|
2024-06-08 20:36:58 +02:00
|
|
|
self.assertRaisesMessage(TypeError, msg),
|
|
|
|
):
|
|
|
|
self.finder.find(src, all=True, wrong=1)
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertEqual(ctx.filename, __file__)
|
2024-06-08 20:36:58 +02:00
|
|
|
|
|
|
|
with self.assertRaisesMessage(TypeError, msg):
|
|
|
|
self.finder.find(src, find_all=True, wrong=1)
|
|
|
|
|
|
|
|
with self.assertRaisesMessage(TypeError, msg):
|
|
|
|
self.finder.find(src, wrong=1)
|
|
|
|
|
2015-07-01 13:43:25 +02:00
|
|
|
|
2016-03-26 16:17:06 +01:00
|
|
|
class TestFileSystemFinder(TestFinders, StaticFilesTestCase):
|
2015-07-01 13:43:25 +02:00
|
|
|
"""
|
|
|
|
Test FileSystemFinder.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2015-07-01 13:43:25 +02:00
|
|
|
def setUp(self):
|
2017-01-21 18:43:44 +05:30
|
|
|
super().setUp()
|
2015-07-01 13:43:25 +02:00
|
|
|
self.finder = finders.FileSystemFinder()
|
2022-02-03 20:24:19 +01:00
|
|
|
test_file_path = os.path.join(
|
|
|
|
TEST_ROOT, "project", "documents", "test", "file.txt"
|
|
|
|
)
|
|
|
|
self.find_first = (os.path.join("test", "file.txt"), test_file_path)
|
|
|
|
self.find_all = (os.path.join("test", "file.txt"), [test_file_path])
|
2015-07-01 13:43:25 +02:00
|
|
|
|
|
|
|
|
2016-03-26 16:17:06 +01:00
|
|
|
class TestAppDirectoriesFinder(TestFinders, StaticFilesTestCase):
|
2015-07-01 13:43:25 +02:00
|
|
|
"""
|
|
|
|
Test AppDirectoriesFinder.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2015-07-01 13:43:25 +02:00
|
|
|
def setUp(self):
|
2017-01-21 18:43:44 +05:30
|
|
|
super().setUp()
|
2015-07-01 13:43:25 +02:00
|
|
|
self.finder = finders.AppDirectoriesFinder()
|
2022-02-03 20:24:19 +01:00
|
|
|
test_file_path = os.path.join(
|
|
|
|
TEST_ROOT, "apps", "test", "static", "test", "file1.txt"
|
|
|
|
)
|
|
|
|
self.find_first = (os.path.join("test", "file1.txt"), test_file_path)
|
|
|
|
self.find_all = (os.path.join("test", "file1.txt"), [test_file_path])
|
2015-07-01 13:43:25 +02:00
|
|
|
|
|
|
|
|
2016-03-26 16:17:06 +01:00
|
|
|
class TestDefaultStorageFinder(TestFinders, StaticFilesTestCase):
|
2015-07-01 13:43:25 +02:00
|
|
|
"""
|
|
|
|
Test DefaultStorageFinder.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2015-07-01 13:43:25 +02:00
|
|
|
def setUp(self):
|
2017-01-21 18:43:44 +05:30
|
|
|
super().setUp()
|
2015-07-01 13:43:25 +02:00
|
|
|
self.finder = finders.DefaultStorageFinder(
|
2022-02-03 20:24:19 +01:00
|
|
|
storage=storage.StaticFilesStorage(location=settings.MEDIA_ROOT)
|
|
|
|
)
|
|
|
|
test_file_path = os.path.join(settings.MEDIA_ROOT, "media-file.txt")
|
|
|
|
self.find_first = ("media-file.txt", test_file_path)
|
|
|
|
self.find_all = ("media-file.txt", [test_file_path])
|
2015-07-01 13:43:25 +02:00
|
|
|
|
|
|
|
|
|
|
|
@override_settings(
|
2022-02-03 20:24:19 +01:00
|
|
|
STATICFILES_FINDERS=["django.contrib.staticfiles.finders.FileSystemFinder"],
|
|
|
|
STATICFILES_DIRS=[os.path.join(TEST_ROOT, "project", "documents")],
|
2015-07-01 13:43:25 +02:00
|
|
|
)
|
|
|
|
class TestMiscFinder(SimpleTestCase):
|
|
|
|
"""
|
|
|
|
A few misc finder tests.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2015-07-01 13:43:25 +02:00
|
|
|
def test_get_finder(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
self.assertIsInstance(
|
|
|
|
finders.get_finder("django.contrib.staticfiles.finders.FileSystemFinder"),
|
|
|
|
finders.FileSystemFinder,
|
|
|
|
)
|
2015-07-01 13:43:25 +02:00
|
|
|
|
|
|
|
def test_get_finder_bad_classname(self):
|
|
|
|
with self.assertRaises(ImportError):
|
2022-02-03 20:24:19 +01:00
|
|
|
finders.get_finder("django.contrib.staticfiles.finders.FooBarFinder")
|
2015-07-01 13:43:25 +02:00
|
|
|
|
|
|
|
def test_get_finder_bad_module(self):
|
|
|
|
with self.assertRaises(ImportError):
|
2022-02-03 20:24:19 +01:00
|
|
|
finders.get_finder("foo.bar.FooBarFinder")
|
2015-07-01 13:43:25 +02:00
|
|
|
|
|
|
|
def test_cache(self):
|
|
|
|
finders.get_finder.cache_clear()
|
|
|
|
for n in range(10):
|
2022-02-03 20:24:19 +01:00
|
|
|
finders.get_finder("django.contrib.staticfiles.finders.FileSystemFinder")
|
2015-07-01 13:43:25 +02:00
|
|
|
cache_info = finders.get_finder.cache_info()
|
|
|
|
self.assertEqual(cache_info.hits, 9)
|
|
|
|
self.assertEqual(cache_info.currsize, 1)
|
|
|
|
|
|
|
|
def test_searched_locations(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
finders.find("spam")
|
2015-07-01 13:43:25 +02:00
|
|
|
self.assertEqual(
|
|
|
|
finders.searched_locations,
|
2022-02-03 20:24:19 +01:00
|
|
|
[os.path.join(TEST_ROOT, "project", "documents")],
|
2015-07-01 13:43:25 +02:00
|
|
|
)
|
|
|
|
|
2024-06-08 20:36:58 +02:00
|
|
|
def test_searched_locations_find_all(self):
|
|
|
|
finders.find("spam", find_all=True)
|
|
|
|
self.assertEqual(
|
|
|
|
finders.searched_locations,
|
|
|
|
[os.path.join(TEST_ROOT, "project", "documents")],
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_searched_locations_deprecated_all(self):
|
2024-08-09 12:35:28 -04:00
|
|
|
with self.assertWarnsMessage(RemovedInDjango61Warning, DEPRECATION_MSG) as ctx:
|
2024-06-08 20:36:58 +02:00
|
|
|
finders.find("spam", all=True)
|
|
|
|
self.assertEqual(
|
|
|
|
finders.searched_locations,
|
|
|
|
[os.path.join(TEST_ROOT, "project", "documents")],
|
|
|
|
)
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertEqual(ctx.filename, __file__)
|
2024-06-08 20:36:58 +02:00
|
|
|
|
|
|
|
def test_searched_locations_conflicting_params(self):
|
|
|
|
msg = "find() got multiple values for argument 'find_all'"
|
|
|
|
with (
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertWarnsMessage(RemovedInDjango61Warning, DEPRECATION_MSG) as ctx,
|
2024-06-08 20:36:58 +02:00
|
|
|
self.assertRaisesMessage(TypeError, msg),
|
|
|
|
):
|
|
|
|
finders.find("spam", find_all=True, all=True)
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertEqual(ctx.filename, __file__)
|
2024-06-08 20:36:58 +02:00
|
|
|
|
|
|
|
def test_searched_locations_unexpected_params(self):
|
|
|
|
msg = "find() got an unexpected keyword argument 'wrong'"
|
|
|
|
with (
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertWarnsMessage(RemovedInDjango61Warning, DEPRECATION_MSG) as ctx,
|
2024-06-08 20:36:58 +02:00
|
|
|
self.assertRaisesMessage(TypeError, msg),
|
|
|
|
):
|
|
|
|
finders.find("spam", all=True, wrong=1)
|
2024-08-09 12:35:28 -04:00
|
|
|
self.assertEqual(ctx.filename, __file__)
|
2024-06-08 20:36:58 +02:00
|
|
|
|
|
|
|
with self.assertRaisesMessage(TypeError, msg):
|
|
|
|
finders.find("spam", find_all=True, wrong=1)
|
|
|
|
|
|
|
|
with self.assertRaisesMessage(TypeError, msg):
|
|
|
|
finders.find("spam", wrong=1)
|
|
|
|
|
2022-02-03 20:24:19 +01:00
|
|
|
@override_settings(MEDIA_ROOT="")
|
2015-07-01 13:43:25 +02:00
|
|
|
def test_location_empty(self):
|
2017-05-28 21:37:21 +02:00
|
|
|
msg = (
|
|
|
|
"The storage backend of the staticfiles finder "
|
|
|
|
"<class 'django.contrib.staticfiles.finders.DefaultStorageFinder'> "
|
|
|
|
"doesn't have a valid location."
|
|
|
|
)
|
|
|
|
with self.assertRaisesMessage(ImproperlyConfigured, msg):
|
2016-01-17 14:56:39 +03:30
|
|
|
finders.DefaultStorageFinder()
|