Merge branch '6264-cwl-runner' closes #6264
[arvados.git] / sdk / python / gittaggers.py
index ea7898146c5cb9bf059c260d5d6f3acdc5fd79cd..9223443813aee12fc0bee6781267bf6a367d7dfe 100644 (file)
@@ -2,39 +2,19 @@ from setuptools.command.egg_info import egg_info
 import subprocess
 import time
 
-class GitTagger(egg_info):
-    """Tag the build with git commit info.
-
-    Exact choice and format is determined by subclass's tags_to_add
-    method.
+class EggInfoFromGit(egg_info):
+    """Tag the build with git commit timestamp.
 
     If a build tag has already been set (e.g., "egg_info -b", building
     from source package), leave it alone.
     """
-    def git_commit_info(self):
+    def git_timestamp_tag(self):
         gitinfo = subprocess.check_output(
             ['git', 'log', '--first-parent', '--max-count=1',
-             '--format=format:%ct %h', '.']).split()
-        assert len(gitinfo) == 2
-        return {
-            'commit_utc': time.strftime(
-                '%Y%m%d%H%M%S', time.gmtime(int(gitinfo[0]))),
-            'commit_sha1': gitinfo[1],
-        }
+             '--format=format:%ct', '.']).strip()
+        return time.strftime('.%Y%m%d%H%M%S', time.gmtime(int(gitinfo)))
 
     def tags(self):
         if self.tag_build is None:
-            self.tag_build = self.tags_to_add()
+            self.tag_build = self.git_timestamp_tag()
         return egg_info.tags(self)
-
-
-class TagBuildWithCommitDateAndSha1(GitTagger):
-    """Tag the build with the sha1 and date of the last git commit."""
-    def tags_to_add(self):
-        return '.{commit_utc}+{commit_sha1}'.format(**self.git_commit_info())
-
-
-class TagBuildWithCommitDate(GitTagger):
-    """Tag the build with the date of the last git commit."""
-    def tags_to_add(self):
-        return '.{commit_utc}'.format(**self.git_commit_info())