Merge branch 'master' into 4638-ssh-notification
[arvados.git] / services / fuse / setup.py
index fd774b7ff37d2ec2903b81bd692109536be74dda..c9ea98c456ecfb2fefce598d77f745c151345f08 100644 (file)
@@ -1,10 +1,37 @@
 #!/usr/bin/env python
 
-from setuptools import setup
+import os
+import subprocess
+import time
+
+from setuptools import setup, find_packages
+from setuptools.command.egg_info import egg_info
+
+SETUP_DIR = os.path.dirname(__file__)
+README = os.path.join(SETUP_DIR, 'README.rst')
+
+class TagBuildWithCommit(egg_info):
+    """Tag the build with the sha1 and date of the last git commit.
+
+    If a build tag has already been set (e.g., "egg_info -b", building
+    from source package), leave it alone.
+    """
+    def tags(self):
+        if self.tag_build is None:
+            git_tags = subprocess.check_output(
+                ['git', 'log', '--first-parent', '--max-count=1',
+                 '--format=format:%ct %h', SETUP_DIR]).split()
+            assert len(git_tags) == 2
+            git_tags[0] = time.strftime(
+                '%Y%m%d%H%M%S', time.gmtime(int(git_tags[0])))
+            self.tag_build = '.{}.{}'.format(*git_tags)
+        return egg_info.tags(self)
+
 
 setup(name='arvados_fuse',
       version='0.1',
       description='Arvados FUSE driver',
+      long_description=open(README).read(),
       author='Arvados',
       author_email='info@arvados.org',
       url="https://arvados.org",
@@ -15,8 +42,12 @@ setup(name='arvados_fuse',
         'bin/arv-mount'
         ],
       install_requires=[
-        'arvados-python-client',
+        'arvados-python-client>=0.1.20141203150737.277b3c7',
         'llfuse',
         'python-daemon'
         ],
-      zip_safe=False)
+      test_suite='tests',
+      tests_require=['PyYAML'],
+      zip_safe=False,
+      cmdclass={'egg_info': TagBuildWithCommit},
+      )