This article is a part of Configuring Android Project series:
Everything we have discussed in current article is available in template project.
Developers usually use some hard coded values for android versionName & versionCode.
<a href="https://medium.com/media/f04f0b271a860d651b4eec03c1a3855a/href">https://medium.com/media/f04f0b271a860d651b4eec03c1a3855a/href</a>
Such approach has several disadvantages:
If you are using git as your source control system it can also help you to generate android versionName & versionCode. It’s a common practice to use git tags to indicate release of new version.
For versionName we can use git describe command.
a. The command finds the most recent tag that is reachable from a commit.
b. If the tag points to the commit, then only the tag is shown.
c. Otherwise, it suffixes the tag name with the number of additional commits on top of the tagged object and the abbreviated object name of the most recent commit.
Example (a-b)
As you can see if you call git describe on a HEAD commit with some tag, it will output this tag.
Example (a-c)
Using git commit hash “1.0–2-gdca226a” we can easily find out from which specific commit build was made.
For versionCode we can use total number of tags. Because every git tag indicate some version, versionCode for next version will be always greater then previous.
In the example above we have 3 tags. This value will be used for our versionCode.
However we are not going to create a git tag for every intermediate version, so for dev build we can use a timestamp of HEAD commit.
In the example above a timestamp of HEAD commit is equal to 1484407970 (seconds since the UNIX epoch January 1, 1970 00:00:00 UTC). This value will be used for our versionCode. If you want to convert it to a human readable date use currentmillis.com site. In our case it’s Sat Jan 14 2017 15:32:50 UTC.
To work with git I suggest to use a library called grgit. Create script-git-version.gradle file with following content:
<a href="https://medium.com/media/899d5870580a1b4c8581154ad1a70e99/href">https://medium.com/media/899d5870580a1b4c8581154ad1a70e99/href</a>
Apply it to your build.gradle file:
<a href="https://medium.com/media/574b6c7dae7d34a4b136e2c15a92cd16/href">https://medium.com/media/574b6c7dae7d34a4b136e2c15a92cd16/href</a>
To check if version name and code are generated correctly call gradle task ./gradlew printVersion which gives you similar output:
<a href="https://medium.com/media/785a01221074e6ed620d343485aa5c8e/href">https://medium.com/media/785a01221074e6ed620d343485aa5c8e/href</a>
Finally use gitVersionName, gitVersionCode and gitVersionCodeTime variables in your build.gradle file.
<a href="https://medium.com/media/85b229e6fdca9075135c82047b59def9/href">https://medium.com/media/85b229e6fdca9075135c82047b59def9/href</a>
Run project and verify app version.
Benefits of such approach:
Note: you can experiment with version name even more: include branch name, timestamp, etc.