mirror of https://github.com/django/django.git
Fixed #19715 -- Simplified findstatic output when verbosity set to 0
This commit is contained in:
parent
56e553129f
commit
393c268e72
1
AUTHORS
1
AUTHORS
|
@ -464,6 +464,7 @@ answer newbie questions, and generally made Django that much better:
|
||||||
Mike Richardson
|
Mike Richardson
|
||||||
Matt Riggott
|
Matt Riggott
|
||||||
Alex Robbins <alexander.j.robbins@gmail.com>
|
Alex Robbins <alexander.j.robbins@gmail.com>
|
||||||
|
Matt Robenolt <m@robenolt.com>
|
||||||
Henrique Romano <onaiort@gmail.com>
|
Henrique Romano <onaiort@gmail.com>
|
||||||
Armin Ronacher
|
Armin Ronacher
|
||||||
Daniel Roseman <http://roseman.org.uk/>
|
Daniel Roseman <http://roseman.org.uk/>
|
||||||
|
|
|
@ -3,7 +3,7 @@ from __future__ import unicode_literals
|
||||||
import os
|
import os
|
||||||
from optparse import make_option
|
from optparse import make_option
|
||||||
from django.core.management.base import LabelCommand
|
from django.core.management.base import LabelCommand
|
||||||
from django.utils.encoding import smart_text
|
from django.utils.encoding import force_text
|
||||||
|
|
||||||
from django.contrib.staticfiles import finders
|
from django.contrib.staticfiles import finders
|
||||||
|
|
||||||
|
@ -19,13 +19,16 @@ class Command(LabelCommand):
|
||||||
def handle_label(self, path, **options):
|
def handle_label(self, path, **options):
|
||||||
verbosity = int(options.get('verbosity', 1))
|
verbosity = int(options.get('verbosity', 1))
|
||||||
result = finders.find(path, all=options['all'])
|
result = finders.find(path, all=options['all'])
|
||||||
path = smart_text(path)
|
path = force_text(path)
|
||||||
if result:
|
if result:
|
||||||
if not isinstance(result, (list, tuple)):
|
if not isinstance(result, (list, tuple)):
|
||||||
result = [result]
|
result = [result]
|
||||||
output = '\n '.join(
|
result = (force_text(os.path.realpath(path)) for path in result)
|
||||||
(smart_text(os.path.realpath(path)) for path in result))
|
if verbosity >= 1:
|
||||||
self.stdout.write("Found '%s' here:\n %s" % (path, output))
|
output = '\n '.join(result)
|
||||||
|
return "Found '%s' here:\n %s" % (path, output)
|
||||||
|
else:
|
||||||
|
return '\n'.join(result)
|
||||||
else:
|
else:
|
||||||
if verbosity >= 1:
|
if verbosity >= 1:
|
||||||
self.stderr.write("No matching file found for '%s'." % path)
|
self.stderr.write("No matching file found for '%s'." % path)
|
||||||
|
|
|
@ -112,19 +112,29 @@ Searches for one or more relative paths with the enabled finders.
|
||||||
For example::
|
For example::
|
||||||
|
|
||||||
$ python manage.py findstatic css/base.css admin/js/core.js
|
$ python manage.py findstatic css/base.css admin/js/core.js
|
||||||
/home/special.polls.com/core/static/css/base.css
|
Found 'css/base.css' here:
|
||||||
/home/polls.com/core/static/css/base.css
|
/home/special.polls.com/core/static/css/base.css
|
||||||
/home/polls.com/src/django/contrib/admin/media/js/core.js
|
/home/polls.com/core/static/css/base.css
|
||||||
|
Found 'admin/js/core.js' here:
|
||||||
|
/home/polls.com/src/django/contrib/admin/media/js/core.js
|
||||||
|
|
||||||
By default, all matching locations are found. To only return the first match
|
By default, all matching locations are found. To only return the first match
|
||||||
for each relative path, use the ``--first`` option::
|
for each relative path, use the ``--first`` option::
|
||||||
|
|
||||||
$ python manage.py findstatic css/base.css --first
|
$ python manage.py findstatic css/base.css --first
|
||||||
/home/special.polls.com/core/static/css/base.css
|
Found 'css/base.css' here:
|
||||||
|
/home/special.polls.com/core/static/css/base.css
|
||||||
|
|
||||||
This is a debugging aid; it'll show you exactly which static file will be
|
This is a debugging aid; it'll show you exactly which static file will be
|
||||||
collected for a given path.
|
collected for a given path.
|
||||||
|
|
||||||
|
By setting the :djadminopt:`--verbosity` flag to 0, you can suppress the extra
|
||||||
|
output and just get the path names::
|
||||||
|
|
||||||
|
$ python manage.py findstatic css/base.css --verbosity 0
|
||||||
|
/home/special.polls.com/core/static/css/base.css
|
||||||
|
/home/polls.com/core/static/css/base.css
|
||||||
|
|
||||||
.. _staticfiles-runserver:
|
.. _staticfiles-runserver:
|
||||||
|
|
||||||
runserver
|
runserver
|
||||||
|
|
|
@ -195,21 +195,33 @@ class TestFindStatic(CollectionTestCase, TestDefaults):
|
||||||
call_command('findstatic', filepath, all=False, verbosity=0, stdout=out)
|
call_command('findstatic', filepath, all=False, verbosity=0, stdout=out)
|
||||||
out.seek(0)
|
out.seek(0)
|
||||||
lines = [l.strip() for l in out.readlines()]
|
lines = [l.strip() for l in out.readlines()]
|
||||||
with codecs.open(force_text(lines[1].strip()), "r", "utf-8") as f:
|
with codecs.open(force_text(lines[0].strip()), "r", "utf-8") as f:
|
||||||
return f.read()
|
return f.read()
|
||||||
|
|
||||||
def test_all_files(self):
|
def test_all_files(self):
|
||||||
"""
|
"""
|
||||||
Test that findstatic returns all candidate files if run without --first.
|
Test that findstatic returns all candidate files if run without --first and -v1.
|
||||||
"""
|
"""
|
||||||
out = six.StringIO()
|
out = six.StringIO()
|
||||||
call_command('findstatic', 'test/file.txt', verbosity=0, stdout=out)
|
call_command('findstatic', 'test/file.txt', verbosity=1, stdout=out)
|
||||||
out.seek(0)
|
out.seek(0)
|
||||||
lines = [l.strip() for l in out.readlines()]
|
lines = [l.strip() for l in out.readlines()]
|
||||||
self.assertEqual(len(lines), 3) # three because there is also the "Found <file> here" line
|
self.assertEqual(len(lines), 3) # three because there is also the "Found <file> here" line
|
||||||
self.assertIn('project', force_text(lines[1]))
|
self.assertIn('project', force_text(lines[1]))
|
||||||
self.assertIn('apps', force_text(lines[2]))
|
self.assertIn('apps', force_text(lines[2]))
|
||||||
|
|
||||||
|
def test_all_files_less_verbose(self):
|
||||||
|
"""
|
||||||
|
Test that findstatic returns all candidate files if run without --first and -v0.
|
||||||
|
"""
|
||||||
|
out = six.StringIO()
|
||||||
|
call_command('findstatic', 'test/file.txt', verbosity=0, stdout=out)
|
||||||
|
out.seek(0)
|
||||||
|
lines = [l.strip() for l in out.readlines()]
|
||||||
|
self.assertEqual(len(lines), 2)
|
||||||
|
self.assertIn('project', force_text(lines[0]))
|
||||||
|
self.assertIn('apps', force_text(lines[1]))
|
||||||
|
|
||||||
|
|
||||||
class TestCollection(CollectionTestCase, TestDefaults):
|
class TestCollection(CollectionTestCase, TestDefaults):
|
||||||
"""
|
"""
|
||||||
|
|
Loading…
Reference in New Issue