Opened 6 months ago
Closed 6 months ago
#35593 closed Uncategorized (needsinfo)
collectstatic does not preserve source file timestamps
Reported by: | Kaarle Ritvanen | Owned by: | |
---|---|---|---|
Component: | contrib.staticfiles | Version: | 4.2 |
Severity: | Normal | Keywords: | |
Cc: | Triage Stage: | Unreviewed | |
Has patch: | no | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
The collectstatic
management command interacts badly with Linux package managers.
When collectstatic
copies files, the last modified timestamp of the destination file gets set to the time when the command was run. If the destination file already exists and the corresponding source file does not have a newer timestamp, copying is skipped.
When files are installed by pip
, the timestamps are set according to the installation time. However, this may not be the case with other package managers, such as rpm
or dpkg
. With native package mangers, the timestamps often reflect the build time of the package instead of the installation time. Therefore, collectstatic
may skip source files that were actually updated by the package manager if the source package was built before the destination file was created.
To ensure correct operation, the destination directory must currently be emptied if any of the source files comes from the Linux distro. The suggested solution is to copy the timestamp of the source file to the destination file instead of using the current time.
I'm not sure if the right approach would be to write a custom storage here and updating the logic of Storage.get_modified_time()
Can you provide some specific details on how to reproduce this? Maybe even a test case?