1. 22 Feb, 2016 11 commits
  2. 18 Feb, 2016 1 commit
    • Fix paths given to compiler.is_outdated. · c4ff03e5
      The check to see whether or not a source file is outdated was being passed the
      `input_path` and `output_path` variables, which are not the actual paths to
      files on disk. In particular, `input_path` is the path which will be searched
      for using the staticfiles finders, and `output_path` is the relative path
      within the staticfiles root. If the staticfiles root was not the same as the
      root directory of the project, this would result in the check always reporting
      that the file was outdated. In addition, if a source file required a finder to
      locate, the check would fail.
      
      Changing this to use `infile` and `outfile` instead means that the check
      operates on the same file paths that the compiler will. This therefore checks
      the files that were copied by the collector against the files which are
      outputted by the compiler, which is a much more correct idea of whether
      something is out of date.
      
      This was tested in conjunction with a custom LessCompiler that uses a helper to
      introspect dependencies. Before this change, that helper was seeing file paths
      that did not exist (since STATIC_ROOT is a few subdirectories deep in our
      codebase). Afterwards, it is able to successfully introspect all the source
      files to build the dependency tree.
      David Trowbridge committed
  3. 17 Feb, 2016 1 commit
    • Fix an UnboundLocalError if a compiler fails. · c0937f1a
      Depending on where an exception is raised inside a compiler's
      `execute_command`, the `stdout` variable may not be assigned. In this case, the
      finally handler would fail with an `UnboundLocalError`, hiding the true cause
      of the exception. This change adds a new variable, `stdout_name`, which is
      populated once we've actually created the file. After this, the `CompilerError`
      is successfully raised with the contents of the true error.
      David Trowbridge committed
  4. 16 Feb, 2016 1 commit
  5. 14 Feb, 2016 1 commit
  6. 10 Feb, 2016 1 commit
    • Allow compilers to override output_path. · 2899300f
      The current logic for compilers to manipulate output paths is pretty simple,
      using `os.path.splitext` and the compiler's `output_extension`. This precludes
      doing fancier things by just implementing one's own compiler class.
      
      This change moves the `output_file` method into the CompilerBase class, so that
      subclasses can override its behavior to suit their own needs.
      David Trowbridge committed
  7. 09 Feb, 2016 4 commits
    • Fix unit tests for glob updates. · b2be56f9
      The aforementioned change to `glob` surfaced a couple errors in the unit tests:
      
      1. `test_glob_literal` was still testing the old behavior of non-existing paths
         being filtered out.
      2. The post-process tests (`test_post_process_dry_run` and `test_post_process`)
         were now failing because post-process was being run without first collecting
         the media. This is a case where non-existing files were previously being
         filtered out silently but now cause an error. Running the collection stage
         before testing `post_process.
      David Trowbridge committed
    • Merge pull request #536 from davidt/setting_changed-compat · cb39e0d1
      Fix compatibility with Django < 1.8
      Timothée Peignier committed
    • Don't filter out "missing" files in the glob stage. · 5604b07c
      Commit bd6b9d89 dramatically changed the way that files are loaded, and had the
      side-effect of filtering out any files which were sourced by finders outside of
      the main `STATICFILES_DIRS`.
      
      In the case I'm trying to address, we have an extension framework (in Review
      Board and Djblets) which can load static media from third-party packages which
      are activated at runtime. This media is loaded by instantiating
      `StylesheetNode` and `JavascriptNode` from `pipeline.templatetags` in
      combination with a special finder. Because django-pipeline no longer uses
      finders before the compile stage, calling `storage.exists` (via
      `Package.sources` -> `glob`) silently filters these out.
      
      Inside `glob`, I agree that it's useful to test existence when trying to expand
      `*` or `?`, but when the path is just a normal filename, it should be safe to
      assume that the user knows what they're doing. This causes the paths to be
      emitted into the rendered template whether or not `staticfiles_storage` claims
      they exist, and anything which the configured staticfiles finders can't locate
      will surface as a 404 rather than being silently eaten.
      David Trowbridge committed
    • Fix compatibility with Django < 1.8 · 60262352
      The 1.6.1 release added a dependency on the `setting_changed` signal. In Django
      releases prior to 1.8, this signal is located in the `django.test.signals`
      module, and in 1.8, an alias was added in `django.core.signals`.
      
      This change adds a fallback import to restore compatibility with older versions
      for applications which cannot (yet) migrate to the newer Djangos. It has been
      tested against Django 1.6.11 and 1.8.9.
      David Trowbridge committed
  8. 08 Jan, 2016 1 commit
  9. 06 Jan, 2016 3 commits
  10. 05 Jan, 2016 1 commit
  11. 03 Jan, 2016 2 commits
  12. 02 Jan, 2016 10 commits
  13. 30 Dec, 2015 3 commits