From 7f36b608f15a0b0b3f55ba0aca6acf906d34898d Mon Sep 17 00:00:00 2001 From: Willem Melching Date: Tue, 28 Jan 2020 15:55:24 -0800 Subject: [PATCH] cleanup version.py old-commit-hash: b552a627e1bf06606253db6a9790e5707cd1a110 --- selfdrive/version.py | 81 +++++++++++++++++++++++--------------------- 1 file changed, 43 insertions(+), 38 deletions(-) diff --git a/selfdrive/version.py b/selfdrive/version.py index d2f6651963..7dec492c85 100644 --- a/selfdrive/version.py +++ b/selfdrive/version.py @@ -5,15 +5,24 @@ from selfdrive.swaglog import cloudlog def get_git_commit(): - return subprocess.check_output(["git", "rev-parse", "HEAD"], encoding='utf8').strip() + try: + return subprocess.check_output(["git", "rev-parse", "HEAD"], encoding='utf8').strip() + except subprocess.CalledProcessError: + return None def get_git_branch(): - return subprocess.check_output(["git", "rev-parse", "--abbrev-ref", "HEAD"], encoding='utf8').strip() + try: + return subprocess.check_output(["git", "rev-parse", "--abbrev-ref", "HEAD"], encoding='utf8').strip() + except subprocess.CalledProcessError: + return None def get_git_full_branchname(): - return subprocess.check_output(["git", "rev-parse", "--abbrev-ref", "--symbolic-full-name", "@{u}"], encoding='utf8').strip() + try: + return subprocess.check_output(["git", "rev-parse", "--abbrev-ref", "--symbolic-full-name", "@{u}"], encoding='utf8').strip() + except subprocess.CalledProcessError: + return None def get_git_remote(): @@ -21,53 +30,49 @@ def get_git_remote(): local_branch = subprocess.check_output(["git", "name-rev", "--name-only", "HEAD"], encoding='utf8').strip() tracking_remote = subprocess.check_output(["git", "config", "branch." + local_branch + ".remote"], encoding='utf8').strip() return subprocess.check_output(["git", "config", "remote." + tracking_remote + ".url"], encoding='utf8').strip() + except subprocess.CalledProcessError: - # Not on a branch, fallback - return subprocess.check_output(["git", "config", "--get", "remote.origin.url"], encoding='utf8').strip() + try: + # Not on a branch, fallback + return subprocess.check_output(["git", "config", "--get", "remote.origin.url"], encoding='utf8').strip() + except subprocess.CalledProcessError: + return None with open(os.path.join(os.path.dirname(os.path.abspath(__file__)), "common", "version.h")) as _versionf: version = _versionf.read().split('"')[1] +training_version = b"0.2.0" +terms_version = b"2" + +dirty = True +origin = get_git_remote() +branch = get_git_full_branchname() + try: - origin = get_git_remote() - if origin.startswith('git@github.com:commaai') or origin.startswith('https://github.com/commaai'): - if origin.endswith('/one.git'): - dirty = True - else: - branch = get_git_full_branchname() - - # This is needed otherwise touched files might show up as modified - try: - subprocess.check_call(["git", "update-index", "--refresh"]) - except subprocess.CalledProcessError: - pass - - dirty = subprocess.call(["git", "diff-index", "--quiet", branch, "--"]) != 0 - if dirty: - dirty_files = subprocess.check_output(["git", "diff-index", branch, "--"], encoding='utf8') - commit = subprocess.check_output(["git", "rev-parse", "--verify", "HEAD"], encoding='utf8').rstrip() - origin_commit = subprocess.check_output(["git", "rev-parse", "--verify", branch], encoding='utf8').rstrip() - cloudlog.event("dirty comma branch", version=version, dirty=dirty, origin=origin, branch=branch, dirty_files=dirty_files, commit=commit, origin_commit=origin_commit) - - else: - dirty = True + is_comma_remote = origin.startswith('git@github.com:commaai') or origin.startswith('https://github.com/commaai') + if is_comma_remote and branch is not None: + # This is needed otherwise touched files might show up as modified + try: + subprocess.check_call(["git", "update-index", "--refresh"]) + except subprocess.CalledProcessError: + pass + + dirty = 'master' in branch + dirty = dirty or (subprocess.call(["git", "diff-index", "--quiet", branch, "--"]) != 0) + if dirty: + dirty_files = subprocess.check_output(["git", "diff-index", branch, "--"], encoding='utf8') + commit = subprocess.check_output(["git", "rev-parse", "--verify", "HEAD"], encoding='utf8').rstrip() + origin_commit = subprocess.check_output(["git", "rev-parse", "--verify", branch], encoding='utf8').rstrip() + cloudlog.event("dirty comma branch", version=version, dirty=dirty, origin=origin, branch=branch, dirty_files=dirty_files, commit=commit, origin_commit=origin_commit) + except subprocess.CalledProcessError: - try: - cloudlog.exception("git subprocess failed while finding version") - except: - pass dirty = True + cloudlog.exception("git subprocess failed while checking dirty") -training_version = b"0.2.0" -terms_version = b"2" if __name__ == "__main__": print("Dirty: %s" % dirty) print("Version: %s" % version) print("Remote: %s" % origin) - - try: - print("Branch %s" % branch) - except NameError: - pass + print("Branch %s" % branch)