mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #18224 -- Changed the dev version number.
Following the move from SVN to git.
This commit is contained in:
		| @@ -1,5 +1,11 @@ | |||||||
|  | import datetime | ||||||
|  | import os | ||||||
|  | import subprocess | ||||||
|  |  | ||||||
|  |  | ||||||
| VERSION = (1, 5, 0, 'alpha', 0) | VERSION = (1, 5, 0, 'alpha', 0) | ||||||
|  |  | ||||||
|  |  | ||||||
| def get_version(version=None): | def get_version(version=None): | ||||||
|     """Derives a PEP386-compliant version number from VERSION.""" |     """Derives a PEP386-compliant version number from VERSION.""" | ||||||
|     if version is None: |     if version is None: | ||||||
| @@ -17,14 +23,31 @@ def get_version(version=None): | |||||||
|  |  | ||||||
|     sub = '' |     sub = '' | ||||||
|     if version[3] == 'alpha' and version[4] == 0: |     if version[3] == 'alpha' and version[4] == 0: | ||||||
|         # At the toplevel, this would cause an import loop. |         git_changeset = get_git_changeset() | ||||||
|         from django.utils.version import get_svn_revision |         if git_changeset: | ||||||
|         svn_revision = get_svn_revision()[4:] |             sub = '.dev%s' % git_changeset | ||||||
|         if svn_revision != 'unknown': |  | ||||||
|             sub = '.dev%s' % svn_revision |  | ||||||
|  |  | ||||||
|     elif version[3] != 'final': |     elif version[3] != 'final': | ||||||
|         mapping = {'alpha': 'a', 'beta': 'b', 'rc': 'c'} |         mapping = {'alpha': 'a', 'beta': 'b', 'rc': 'c'} | ||||||
|         sub = mapping[version[3]] + str(version[4]) |         sub = mapping[version[3]] + str(version[4]) | ||||||
|  |  | ||||||
|     return main + sub |     return main + sub | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def get_git_changeset(): | ||||||
|  |     """Returns a numeric identifier of the latest git changeset. | ||||||
|  |  | ||||||
|  |     The result is the UTC timestamp of the changeset in YYYYMMDDHHMMSS format. | ||||||
|  |     This value isn't guaranteed to be unique but collisions are very unlikely, | ||||||
|  |     so it's sufficient for generating the development version numbers. | ||||||
|  |     """ | ||||||
|  |     repo_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) | ||||||
|  |     git_show = subprocess.Popen('git show --pretty=format:%ct --quiet HEAD', | ||||||
|  |             stdout=subprocess.PIPE, stderr=subprocess.PIPE, | ||||||
|  |             shell=True, cwd=repo_dir, universal_newlines=True) | ||||||
|  |     timestamp = git_show.communicate()[0].partition('\n')[0] | ||||||
|  |     try: | ||||||
|  |         timestamp = datetime.datetime.utcfromtimestamp(int(timestamp)) | ||||||
|  |     except ValueError: | ||||||
|  |         return None | ||||||
|  |     return timestamp.strftime('%Y%m%d%H%M%S') | ||||||
|   | |||||||
| @@ -1,41 +0,0 @@ | |||||||
| import django |  | ||||||
| import re |  | ||||||
|  |  | ||||||
| def get_svn_revision(path=None): |  | ||||||
|     """ |  | ||||||
|     Returns the SVN revision in the form SVN-XXXX, |  | ||||||
|     where XXXX is the revision number. |  | ||||||
|  |  | ||||||
|     Returns SVN-unknown if anything goes wrong, such as an unexpected |  | ||||||
|     format of internal SVN files. |  | ||||||
|  |  | ||||||
|     If path is provided, it should be a directory whose SVN info you want to |  | ||||||
|     inspect. If it's not provided, this will use the root django/ package |  | ||||||
|     directory. |  | ||||||
|     """ |  | ||||||
|     rev = None |  | ||||||
|     if path is None: |  | ||||||
|         path = django.__path__[0] |  | ||||||
|     entries_path = '%s/.svn/entries' % path |  | ||||||
|  |  | ||||||
|     try: |  | ||||||
|         entries = open(entries_path, 'r').read() |  | ||||||
|     except IOError: |  | ||||||
|         pass |  | ||||||
|     else: |  | ||||||
|         # Versions >= 7 of the entries file are flat text.  The first line is |  | ||||||
|         # the version number. The next set of digits after 'dir' is the revision. |  | ||||||
|         if re.match('(\d+)', entries): |  | ||||||
|             rev_match = re.search('\d+\s+dir\s+(\d+)', entries) |  | ||||||
|             if rev_match: |  | ||||||
|                 rev = rev_match.groups()[0] |  | ||||||
|         # Older XML versions of the file specify revision as an attribute of |  | ||||||
|         # the first entries node. |  | ||||||
|         else: |  | ||||||
|             from xml.dom import minidom |  | ||||||
|             dom = minidom.parse(entries_path) |  | ||||||
|             rev = dom.getElementsByTagName('entry')[0].getAttribute('revision') |  | ||||||
|  |  | ||||||
|     if rev: |  | ||||||
|         return u'SVN-%s' % rev |  | ||||||
|     return u'SVN-unknown' |  | ||||||
| @@ -8,7 +8,7 @@ class VersionTests(TestCase): | |||||||
|     def test_development(self): |     def test_development(self): | ||||||
|         ver_tuple = (1, 4, 0, 'alpha', 0) |         ver_tuple = (1, 4, 0, 'alpha', 0) | ||||||
|         # This will return a different result when it's run within or outside |         # This will return a different result when it's run within or outside | ||||||
|         # of a SVN checkout: 1.4.devNNNNN or 1.4. |         # of a git clone: 1.4.devYYYYMMDDHHMMSS or 1.4. | ||||||
|         ver_string = get_version(ver_tuple) |         ver_string = get_version(ver_tuple) | ||||||
|         self.assertRegexpMatches(ver_string, r'1\.4(\.dev\d+)?') |         self.assertRegexpMatches(ver_string, r'1\.4(\.dev\d+)?') | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user