Update to latest oslo version/setup.
Change-Id: I7bd38b950ef9fea8b6eaa1df599085a1c64d8b61
This commit is contained in:
		@@ -57,10 +57,8 @@ copyright = u'2012 OpenStack, LLC.'
 | 
			
		||||
# built documents.
 | 
			
		||||
#
 | 
			
		||||
from swiftclient.version import version_info as swiftclient_version
 | 
			
		||||
# The full version, including alpha/beta/rc tags.
 | 
			
		||||
release = swiftclient_version.version_string()
 | 
			
		||||
# The short X.Y version.
 | 
			
		||||
version = swiftclient_version.canonical_version_string()
 | 
			
		||||
version = swiftclient_version.version_string()
 | 
			
		||||
 | 
			
		||||
# The language for content autogenerated by Sphinx. Refer to documentation
 | 
			
		||||
# for a list of supported languages.
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										2
									
								
								setup.py
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								setup.py
									
									
									
									
									
								
							@@ -32,7 +32,7 @@ def read(fname):
 | 
			
		||||
 | 
			
		||||
setuptools.setup(
 | 
			
		||||
    name=name,
 | 
			
		||||
    version=setup.get_post_version('swiftclient'),
 | 
			
		||||
    version=setup.get_version(name),
 | 
			
		||||
    description='Client Library for OpenStack Object Storage API',
 | 
			
		||||
    long_description=read('README.rst'),
 | 
			
		||||
    url='https://github.com/openstack/python-swiftclient',
 | 
			
		||||
 
 | 
			
		||||
@@ -3,6 +3,15 @@
 | 
			
		||||
OpenStack Swift Python client binding.
 | 
			
		||||
"""
 | 
			
		||||
from client import *
 | 
			
		||||
 | 
			
		||||
# At setup.py time, we haven't installed anything yet, so there
 | 
			
		||||
# is nothing that is able to set this version property. Squelching
 | 
			
		||||
# that exception here should be fine- if there are problems with
 | 
			
		||||
# pkg_resources in a real install, that will manifest itself as
 | 
			
		||||
# an error still
 | 
			
		||||
try:
 | 
			
		||||
    from swiftclient import version
 | 
			
		||||
 | 
			
		||||
__version__ = version.version_info.deferred_version_string()
 | 
			
		||||
    __version__ = version.version_info.cached_version_string()
 | 
			
		||||
except Exception:
 | 
			
		||||
    pass
 | 
			
		||||
 
 | 
			
		||||
@@ -1,6 +1,7 @@
 | 
			
		||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
 | 
			
		||||
 | 
			
		||||
# Copyright 2011 OpenStack LLC.
 | 
			
		||||
# Copyright 2012-2013 Hewlett-Packard Development Company, L.P.
 | 
			
		||||
# All Rights Reserved.
 | 
			
		||||
#
 | 
			
		||||
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
 | 
			
		||||
@@ -19,7 +20,7 @@
 | 
			
		||||
Utilities with minimum-depends for use in setup.py
 | 
			
		||||
"""
 | 
			
		||||
 | 
			
		||||
import datetime
 | 
			
		||||
import email
 | 
			
		||||
import os
 | 
			
		||||
import re
 | 
			
		||||
import subprocess
 | 
			
		||||
@@ -45,8 +46,8 @@ def canonicalize_emails(changelog, mapping):
 | 
			
		||||
    """Takes in a string and an email alias mapping and replaces all
 | 
			
		||||
       instances of the aliases in the string with their real email.
 | 
			
		||||
    """
 | 
			
		||||
    for alias, email in mapping.iteritems():
 | 
			
		||||
        changelog = changelog.replace(alias, email)
 | 
			
		||||
    for alias, email_address in mapping.iteritems():
 | 
			
		||||
        changelog = changelog.replace(alias, email_address)
 | 
			
		||||
    return changelog
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@@ -131,57 +132,6 @@ def _run_shell_command(cmd):
 | 
			
		||||
    return out[0].strip()
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def _get_git_next_version_suffix(branch_name):
 | 
			
		||||
    datestamp = datetime.datetime.now().strftime('%Y%m%d')
 | 
			
		||||
    if branch_name == 'milestone-proposed':
 | 
			
		||||
        revno_prefix = "r"
 | 
			
		||||
    else:
 | 
			
		||||
        revno_prefix = ""
 | 
			
		||||
    _run_shell_command("git fetch origin +refs/meta/*:refs/remotes/meta/*")
 | 
			
		||||
    milestone_cmd = "git show meta/openstack/release:%s" % branch_name
 | 
			
		||||
    milestonever = _run_shell_command(milestone_cmd)
 | 
			
		||||
    if milestonever:
 | 
			
		||||
        first_half = "%s~%s" % (milestonever, datestamp)
 | 
			
		||||
    else:
 | 
			
		||||
        first_half = datestamp
 | 
			
		||||
 | 
			
		||||
    post_version = _get_git_post_version()
 | 
			
		||||
    # post version should look like:
 | 
			
		||||
    # 0.1.1.4.gcc9e28a
 | 
			
		||||
    # where the bit after the last . is the short sha, and the bit between
 | 
			
		||||
    # the last and second to last is the revno count
 | 
			
		||||
    (revno, sha) = post_version.split(".")[-2:]
 | 
			
		||||
    second_half = "%s%s.%s" % (revno_prefix, revno, sha)
 | 
			
		||||
    return ".".join((first_half, second_half))
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def _get_git_current_tag():
 | 
			
		||||
    return _run_shell_command("git tag --contains HEAD")
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def _get_git_tag_info():
 | 
			
		||||
    return _run_shell_command("git describe --tags")
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def _get_git_post_version():
 | 
			
		||||
    current_tag = _get_git_current_tag()
 | 
			
		||||
    if current_tag is not None:
 | 
			
		||||
        return current_tag
 | 
			
		||||
    else:
 | 
			
		||||
        tag_info = _get_git_tag_info()
 | 
			
		||||
        if tag_info is None:
 | 
			
		||||
            base_version = "0.0"
 | 
			
		||||
            cmd = "git --no-pager log --oneline"
 | 
			
		||||
            out = _run_shell_command(cmd)
 | 
			
		||||
            revno = len(out.split("\n"))
 | 
			
		||||
            sha = _run_shell_command("git describe --always")
 | 
			
		||||
        else:
 | 
			
		||||
            tag_infos = tag_info.split("-")
 | 
			
		||||
            base_version = "-".join(tag_infos[:-2])
 | 
			
		||||
            (revno, sha) = tag_infos[-2:]
 | 
			
		||||
        return "%s.%s.%s" % (base_version, revno, sha)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def write_git_changelog():
 | 
			
		||||
    """Write a changelog based on the git changelog."""
 | 
			
		||||
    new_changelog = 'ChangeLog'
 | 
			
		||||
@@ -227,26 +177,6 @@ _rst_template = """%(heading)s
 | 
			
		||||
"""
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def read_versioninfo(project):
 | 
			
		||||
    """Read the versioninfo file. If it doesn't exist, we're in a github
 | 
			
		||||
       zipball, and there's really no way to know what version we really
 | 
			
		||||
       are, but that should be ok, because the utility of that should be
 | 
			
		||||
       just about nil if this code path is in use in the first place."""
 | 
			
		||||
    versioninfo_path = os.path.join(project, 'versioninfo')
 | 
			
		||||
    if os.path.exists(versioninfo_path):
 | 
			
		||||
        with open(versioninfo_path, 'r') as vinfo:
 | 
			
		||||
            version = vinfo.read().strip()
 | 
			
		||||
    else:
 | 
			
		||||
        version = "0.0.0"
 | 
			
		||||
    return version
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def write_versioninfo(project, version):
 | 
			
		||||
    """Write a simple file containing the version of the package."""
 | 
			
		||||
    with open(os.path.join(project, 'versioninfo'), 'w') as fil:
 | 
			
		||||
        fil.write("%s\n" % version)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def get_cmdclass():
 | 
			
		||||
    """Return dict of commands to run from setup.py."""
 | 
			
		||||
 | 
			
		||||
@@ -276,6 +206,9 @@ def get_cmdclass():
 | 
			
		||||
        from sphinx.setup_command import BuildDoc
 | 
			
		||||
 | 
			
		||||
        class LocalBuildDoc(BuildDoc):
 | 
			
		||||
 | 
			
		||||
            builders = ['html', 'man']
 | 
			
		||||
 | 
			
		||||
            def generate_autoindex(self):
 | 
			
		||||
                print "**Autodocumenting from %s" % os.path.abspath(os.curdir)
 | 
			
		||||
                modules = {}
 | 
			
		||||
@@ -311,56 +244,69 @@ def get_cmdclass():
 | 
			
		||||
                if not os.getenv('SPHINX_DEBUG'):
 | 
			
		||||
                    self.generate_autoindex()
 | 
			
		||||
 | 
			
		||||
                for builder in ['html', 'man']:
 | 
			
		||||
                for builder in self.builders:
 | 
			
		||||
                    self.builder = builder
 | 
			
		||||
                    self.finalize_options()
 | 
			
		||||
                    self.project = self.distribution.get_name()
 | 
			
		||||
                    self.version = self.distribution.get_version()
 | 
			
		||||
                    self.release = self.distribution.get_version()
 | 
			
		||||
                    BuildDoc.run(self)
 | 
			
		||||
 | 
			
		||||
        class LocalBuildLatex(LocalBuildDoc):
 | 
			
		||||
            builders = ['latex']
 | 
			
		||||
 | 
			
		||||
        cmdclass['build_sphinx'] = LocalBuildDoc
 | 
			
		||||
        cmdclass['build_sphinx_latex'] = LocalBuildLatex
 | 
			
		||||
    except ImportError:
 | 
			
		||||
        pass
 | 
			
		||||
 | 
			
		||||
    return cmdclass
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def get_git_branchname():
 | 
			
		||||
    for branch in _run_shell_command("git branch --color=never").split("\n"):
 | 
			
		||||
        if branch.startswith('*'):
 | 
			
		||||
            _branch_name = branch.split()[1].strip()
 | 
			
		||||
    if _branch_name == "(no":
 | 
			
		||||
        _branch_name = "no-branch"
 | 
			
		||||
    return _branch_name
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def get_pre_version(projectname, base_version):
 | 
			
		||||
    """Return a version which is leading up to a version that will
 | 
			
		||||
       be released in the future."""
 | 
			
		||||
    if os.path.isdir('.git'):
 | 
			
		||||
        current_tag = _get_git_current_tag()
 | 
			
		||||
        if current_tag is not None:
 | 
			
		||||
            version = current_tag
 | 
			
		||||
        else:
 | 
			
		||||
            branch_name = os.getenv('BRANCHNAME',
 | 
			
		||||
                                    os.getenv('GERRIT_REFNAME',
 | 
			
		||||
                                              get_git_branchname()))
 | 
			
		||||
            version_suffix = _get_git_next_version_suffix(branch_name)
 | 
			
		||||
            version = "%s~%s" % (base_version, version_suffix)
 | 
			
		||||
        write_versioninfo(projectname, version)
 | 
			
		||||
        return version
 | 
			
		||||
    else:
 | 
			
		||||
        version = read_versioninfo(projectname)
 | 
			
		||||
    return version
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def get_post_version(projectname):
 | 
			
		||||
def get_version_from_git():
 | 
			
		||||
    """Return a version which is equal to the tag that's on the current
 | 
			
		||||
    revision if there is one, or tag plus number of additional revisions
 | 
			
		||||
    if the current revision has no tag."""
 | 
			
		||||
 | 
			
		||||
    if os.path.isdir('.git'):
 | 
			
		||||
        version = _get_git_post_version()
 | 
			
		||||
        write_versioninfo(projectname, version)
 | 
			
		||||
        return  _run_shell_command(
 | 
			
		||||
            "git describe --always").replace('-', '.')
 | 
			
		||||
    return None
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def get_version_from_pkg_info(package_name):
 | 
			
		||||
    """Get the version from PKG-INFO file if we can."""
 | 
			
		||||
    try:
 | 
			
		||||
        pkg_info_file = open('PKG-INFO', 'r')
 | 
			
		||||
    except (IOError, OSError):
 | 
			
		||||
        return None
 | 
			
		||||
    try:
 | 
			
		||||
        pkg_info = email.message_from_file(pkg_info_file)
 | 
			
		||||
    except email.MessageError:
 | 
			
		||||
        return None
 | 
			
		||||
    # Check to make sure we're in our own dir
 | 
			
		||||
    if pkg_info.get('Name', None) != package_name:
 | 
			
		||||
        return None
 | 
			
		||||
    return pkg_info.get('Version', None)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def get_version(package_name):
 | 
			
		||||
    """Get the version of the project. First, try getting it from PKG-INFO, if
 | 
			
		||||
    it exists. If it does, that means we're in a distribution tarball or that
 | 
			
		||||
    install has happened. Otherwise, if there is no PKG-INFO file, pull the
 | 
			
		||||
    version from git.
 | 
			
		||||
 | 
			
		||||
    We do not support setup.py version sanity in git archive tarballs, nor do
 | 
			
		||||
    we support packagers directly sucking our git repo into theirs. We expect
 | 
			
		||||
    that a source tarball be made from our git repo - or that if someone wants
 | 
			
		||||
    to make a source tarball from a fork of our repo with additional tags in it
 | 
			
		||||
    that they understand and desire the results of doing that.
 | 
			
		||||
    """
 | 
			
		||||
    version = get_version_from_pkg_info(package_name)
 | 
			
		||||
    if version:
 | 
			
		||||
        return version
 | 
			
		||||
    return read_versioninfo(projectname)
 | 
			
		||||
    version = get_version_from_git()
 | 
			
		||||
    if version:
 | 
			
		||||
        return version
 | 
			
		||||
    raise Exception("Versioning for this project requires either an sdist"
 | 
			
		||||
                    " tarball, or access to an upstream git repository.")
 | 
			
		||||
 
 | 
			
		||||
@@ -1,6 +1,6 @@
 | 
			
		||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
 | 
			
		||||
 | 
			
		||||
#    Copyright 2012 OpenStack LLC
 | 
			
		||||
#    Copyright 2012-2013 Hewlett-Packard Development Company, L.P.
 | 
			
		||||
#
 | 
			
		||||
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
 | 
			
		||||
#    not use this file except in compliance with the License. You may obtain
 | 
			
		||||
@@ -15,134 +15,51 @@
 | 
			
		||||
#    under the License.
 | 
			
		||||
 | 
			
		||||
"""
 | 
			
		||||
Utilities for consuming the auto-generated versioninfo files.
 | 
			
		||||
Utilities for consuming the version from pkg_resources.
 | 
			
		||||
"""
 | 
			
		||||
 | 
			
		||||
import datetime
 | 
			
		||||
import pkg_resources
 | 
			
		||||
 | 
			
		||||
import setup
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class _deferred_version_string(object):
 | 
			
		||||
    """Internal helper class which provides delayed version calculation."""
 | 
			
		||||
    def __init__(self, version_info, prefix):
 | 
			
		||||
        self.version_info = version_info
 | 
			
		||||
        self.prefix = prefix
 | 
			
		||||
 | 
			
		||||
    def __str__(self):
 | 
			
		||||
        return "%s%s" % (self.prefix, self.version_info.version_string())
 | 
			
		||||
 | 
			
		||||
    def __repr__(self):
 | 
			
		||||
        return "%s%s" % (self.prefix, self.version_info.version_string())
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class VersionInfo(object):
 | 
			
		||||
 | 
			
		||||
    def __init__(self, package, python_package=None, pre_version=None):
 | 
			
		||||
    def __init__(self, package):
 | 
			
		||||
        """Object that understands versioning for a package
 | 
			
		||||
        :param package: name of the top level python namespace. For glance,
 | 
			
		||||
                        this would be "glance" for python-glanceclient, it
 | 
			
		||||
                        would be "glanceclient"
 | 
			
		||||
        :param python_package: optional name of the project name. For
 | 
			
		||||
                               glance this can be left unset. For
 | 
			
		||||
                               python-glanceclient, this would be
 | 
			
		||||
                               "python-glanceclient"
 | 
			
		||||
        :param pre_version: optional version that the project is working to
 | 
			
		||||
        :param package: name of the python package, such as glance, or
 | 
			
		||||
                        python-glanceclient
 | 
			
		||||
        """
 | 
			
		||||
        self.package = package
 | 
			
		||||
        if python_package is None:
 | 
			
		||||
            self.python_package = package
 | 
			
		||||
        else:
 | 
			
		||||
            self.python_package = python_package
 | 
			
		||||
        self.pre_version = pre_version
 | 
			
		||||
        self.version = None
 | 
			
		||||
        self._cached_version = None
 | 
			
		||||
 | 
			
		||||
    def _generate_version(self):
 | 
			
		||||
        """Defer to the openstack.common.setup routines for making a
 | 
			
		||||
        version from git."""
 | 
			
		||||
        if self.pre_version is None:
 | 
			
		||||
            return setup.get_post_version(self.python_package)
 | 
			
		||||
        else:
 | 
			
		||||
            return setup.get_pre_version(self.python_package, self.pre_version)
 | 
			
		||||
    def _get_version_from_pkg_resources(self):
 | 
			
		||||
        """Get the version of the package from the pkg_resources record
 | 
			
		||||
        associated with the package."""
 | 
			
		||||
        requirement = pkg_resources.Requirement.parse(self.package)
 | 
			
		||||
        provider = pkg_resources.get_provider(requirement)
 | 
			
		||||
        return provider.version
 | 
			
		||||
 | 
			
		||||
    def _newer_version(self, pending_version):
 | 
			
		||||
        """Check to see if we're working with a stale version or not.
 | 
			
		||||
        We expect a version string that either looks like:
 | 
			
		||||
          2012.2~f3~20120708.10.4426392
 | 
			
		||||
        which is an unreleased version of a pre-version, or:
 | 
			
		||||
          0.1.1.4.gcc9e28a
 | 
			
		||||
        which is an unreleased version of a post-version, or:
 | 
			
		||||
          0.1.1
 | 
			
		||||
        Which is a release and which should match tag.
 | 
			
		||||
        For now, if we have a date-embedded version, check to see if it's
 | 
			
		||||
        old, and if so re-generate. Otherwise, just deal with it.
 | 
			
		||||
        """
 | 
			
		||||
        try:
 | 
			
		||||
            version_date = int(self.version.split("~")[-1].split('.')[0])
 | 
			
		||||
            if version_date < int(datetime.date.today().strftime('%Y%m%d')):
 | 
			
		||||
                return self._generate_version()
 | 
			
		||||
            else:
 | 
			
		||||
                return pending_version
 | 
			
		||||
        except Exception:
 | 
			
		||||
            return pending_version
 | 
			
		||||
 | 
			
		||||
    def version_string_with_vcs(self, always=False):
 | 
			
		||||
    def version_string(self):
 | 
			
		||||
        """Return the full version of the package including suffixes indicating
 | 
			
		||||
        VCS status.
 | 
			
		||||
 | 
			
		||||
        For instance, if we are working towards the 2012.2 release,
 | 
			
		||||
        canonical_version_string should return 2012.2 if this is a final
 | 
			
		||||
        release, or else something like 2012.2~f1~20120705.20 if it's not.
 | 
			
		||||
 | 
			
		||||
        :param always: if true, skip all version caching
 | 
			
		||||
        """
 | 
			
		||||
        if always:
 | 
			
		||||
            self.version = self._generate_version()
 | 
			
		||||
 | 
			
		||||
        if self.version is None:
 | 
			
		||||
 | 
			
		||||
            requirement = pkg_resources.Requirement.parse(self.python_package)
 | 
			
		||||
            versioninfo = "%s/versioninfo" % self.package
 | 
			
		||||
            try:
 | 
			
		||||
                raw_version = pkg_resources.resource_string(requirement,
 | 
			
		||||
                                                            versioninfo)
 | 
			
		||||
                self.version = self._newer_version(raw_version.strip())
 | 
			
		||||
            except (IOError, pkg_resources.DistributionNotFound):
 | 
			
		||||
                self.version = self._generate_version()
 | 
			
		||||
            self.version = self._get_version_from_pkg_resources()
 | 
			
		||||
 | 
			
		||||
        return self.version
 | 
			
		||||
 | 
			
		||||
    def canonical_version_string(self, always=False):
 | 
			
		||||
        """Return the simple version of the package excluding any suffixes.
 | 
			
		||||
    # Compatibility functions
 | 
			
		||||
    canonical_version_string = version_string
 | 
			
		||||
    version_string_with_vcs = version_string
 | 
			
		||||
 | 
			
		||||
        For instance, if we are working towards the 2012.2 release,
 | 
			
		||||
        canonical_version_string should return 2012.2 in all cases.
 | 
			
		||||
 | 
			
		||||
        :param always: if true, skip all version caching
 | 
			
		||||
        """
 | 
			
		||||
        return self.version_string_with_vcs(always).split('~')[0]
 | 
			
		||||
 | 
			
		||||
    def version_string(self, always=False):
 | 
			
		||||
        """Return the base version of the package.
 | 
			
		||||
 | 
			
		||||
        For instance, if we are working towards the 2012.2 release,
 | 
			
		||||
        version_string should return 2012.2 if this is a final release, or
 | 
			
		||||
        2012.2-dev if it is not.
 | 
			
		||||
 | 
			
		||||
        :param always: if true, skip all version caching
 | 
			
		||||
        """
 | 
			
		||||
        version_parts = self.version_string_with_vcs(always).split('~')
 | 
			
		||||
        if len(version_parts) == 1:
 | 
			
		||||
            return version_parts[0]
 | 
			
		||||
        else:
 | 
			
		||||
            return '%s-dev' % (version_parts[0],)
 | 
			
		||||
 | 
			
		||||
    def deferred_version_string(self, prefix=""):
 | 
			
		||||
    def cached_version_string(self, prefix=""):
 | 
			
		||||
        """Generate an object which will expand in a string context to
 | 
			
		||||
        the results of version_string(). We do this so that don't
 | 
			
		||||
        call into pkg_resources every time we start up a program when
 | 
			
		||||
        passing version information into the CONF constructor, but
 | 
			
		||||
        rather only do the calculation when and if a version is requested
 | 
			
		||||
        """
 | 
			
		||||
        return _deferred_version_string(self, prefix)
 | 
			
		||||
        if not self._cached_version:
 | 
			
		||||
            self._cached_version = "%s%s" % (prefix,
 | 
			
		||||
                                             self.version_string())
 | 
			
		||||
        return self._cached_version
 | 
			
		||||
 
 | 
			
		||||
@@ -17,5 +17,4 @@
 | 
			
		||||
 | 
			
		||||
from swiftclient.openstack.common import version as common_version
 | 
			
		||||
 | 
			
		||||
version_info = common_version.VersionInfo('swiftclient',
 | 
			
		||||
                                          python_package='python-swiftclient')
 | 
			
		||||
version_info = common_version.VersionInfo('python-swiftclient')
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user