aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Finucane <stephen@that.guru>2018-07-13 15:59:55 +0100
committerPaul Ganssle <paul@ganssle.io>2018-08-19 17:12:49 -0400
commit47874756915a9a757f81d87f32ef5bfa2a333a26 (patch)
tree3620db212d191f59530ea2fed67a54b4577db528
parentcf50418d36c80b35e0f791a96f0a828705ebf25f (diff)
downloadexternal_python_setuptools-47874756915a9a757f81d87f32ef5bfa2a333a26.tar.gz
external_python_setuptools-47874756915a9a757f81d87f32ef5bfa2a333a26.tar.bz2
external_python_setuptools-47874756915a9a757f81d87f32ef5bfa2a333a26.zip
egg_info: Touch 'egg-info' directory
'tox' determines whether a package should be rebuilt by comparing the timestamp of the package's 'egg-info' directory and its 'setup.py' or 'setup.cfg' files [1][2]. Unfortunately this checks the 'egg-info' directory itself, which is not updated, unlike the contents of that directory. This means that 'tox' will always rebuild the package once one of the two setup files has been updated. While this is clearly a bug in 'tox' that should be fixed separately, there is merit in using this as a heuristic so enable it. [1] https://github.com/tox-dev/tox/blob/3.1.0/src/tox/venv.py#L253-L257 [2] https://github.com/tox-dev/tox/blob/3.1.0/src/tox/venv.py#L221-L244 Signed-off-by: Stephen Finucane <stephen@that.guru>
-rw-r--r--changelog.d/1427.change.rst1
-rw-r--r--setuptools/command/egg_info.py1
-rw-r--r--setuptools/tests/test_egg_info.py17
3 files changed, 19 insertions, 0 deletions
diff --git a/changelog.d/1427.change.rst b/changelog.d/1427.change.rst
new file mode 100644
index 00000000..86260235
--- /dev/null
+++ b/changelog.d/1427.change.rst
@@ -0,0 +1 @@
+Set timestamp of ``.egg-info`` directory whenever ``egg_info`` command is run.
diff --git a/setuptools/command/egg_info.py b/setuptools/command/egg_info.py
index 5fd6c888..a3cd35dc 100644
--- a/setuptools/command/egg_info.py
+++ b/setuptools/command/egg_info.py
@@ -281,6 +281,7 @@ class egg_info(InfoCommon, Command):
def run(self):
self.mkpath(self.egg_info)
+ os.utime(self.egg_info, None)
installer = self.distribution.fetch_build_egg
for ep in iter_entry_points('egg_info.writers'):
ep.require(installer=installer)
diff --git a/setuptools/tests/test_egg_info.py b/setuptools/tests/test_egg_info.py
index 1a100266..c7a08295 100644
--- a/setuptools/tests/test_egg_info.py
+++ b/setuptools/tests/test_egg_info.py
@@ -1,9 +1,11 @@
+import datetime
import sys
import ast
import os
import glob
import re
import stat
+import time
from setuptools.command.egg_info import egg_info, manifest_maker
from setuptools.dist import Distribution
@@ -146,6 +148,21 @@ class TestEggInfo:
]
assert sorted(actual) == expected
+ def test_rebuilt(self, tmpdir_cwd, env):
+ """Ensure timestamps are updated when the command is re-run."""
+ self._create_project()
+
+ self._run_egg_info_command(tmpdir_cwd, env)
+ timestamp_a = os.path.getmtime('foo.egg-info')
+
+ # arbitrary sleep just to handle *really* fast systems
+ time.sleep(.001)
+
+ self._run_egg_info_command(tmpdir_cwd, env)
+ timestamp_b = os.path.getmtime('foo.egg-info')
+
+ assert timestamp_a != timestamp_b
+
def test_manifest_template_is_read(self, tmpdir_cwd, env):
self._create_project()
build_files({