4297: Merge branch 'master' into 4297-dispatch-load
[arvados.git] / sdk / python / setup.py
index a2098630f9521532bf4610e26acd5bb50ed8e5f8..64fba0c27474602edbebd8d7bda3aced6a89ae8a 100644 (file)
@@ -1,8 +1,31 @@
+#!/usr/bin/env python
+
+import os
+import subprocess
+import time
+
 from setuptools import setup, find_packages
 
+SETUP_DIR = os.path.dirname(__file__)
+README = os.path.join(SETUP_DIR, 'README.rst')
+
+cmd_opts = {'egg_info': {}}
+try:
+    git_tags = subprocess.check_output(
+        ['git', 'log', '--first-parent', '--max-count=1',
+         '--format=format:%ct %h', SETUP_DIR]).split()
+    assert len(git_tags) == 2
+except (AssertionError, OSError, subprocess.CalledProcessError):
+    pass
+else:
+    git_tags[0] = time.strftime('%Y%m%d%H%M%S', time.gmtime(int(git_tags[0])))
+    cmd_opts['egg_info']['tag_build'] = '.{}.{}'.format(*git_tags)
+
+
 setup(name='arvados-python-client',
       version='0.1',
       description='Arvados client library',
+      long_description=open(README).read(),
       author='Arvados',
       author_email='info@arvados.org',
       url="https://arvados.org",
@@ -10,11 +33,13 @@ setup(name='arvados-python-client',
       license='Apache 2.0',
       packages=find_packages(),
       scripts=[
+        'bin/arv-copy',
         'bin/arv-get',
         'bin/arv-keepdocker',
         'bin/arv-ls',
         'bin/arv-normalize',
         'bin/arv-put',
+        'bin/arv-ws',
         ],
       install_requires=[
         'python-gflags',
@@ -23,4 +48,8 @@ setup(name='arvados-python-client',
         'urllib3',
         'ws4py'
         ],
-      zip_safe=False)
+      test_suite='tests',
+      tests_require=['mock>=1.0', 'PyYAML'],
+      zip_safe=False,
+      options=cmd_opts,
+      )