mirror of
https://gerrit.googlesource.com/git-repo
synced 2024-12-21 07:16:21 +00:00
repo: export GIT_TRACE2_PARENT_SID
This helps with people tracing repo/git execution. We use a similar format to git, but a little simpler since we always initialize the env var setting, and we want to avoid too much overhead. Bug: https://crbug.com/gerrit/12314 Change-Id: I75675b6cc4c6f7c4f5e09f54128eba9456364d04 Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/254331 Reviewed-by: Josh Steadmon <steadmon@google.com> Reviewed-by: Mike Frysinger <vapier@google.com> Tested-by: Mike Frysinger <vapier@google.com>
This commit is contained in:
parent
dc63181fcd
commit
8409410aa2
47
repo
47
repo
@ -10,6 +10,7 @@ copy of repo in the checkout.
|
|||||||
|
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
|
import datetime
|
||||||
import os
|
import os
|
||||||
import platform
|
import platform
|
||||||
import subprocess
|
import subprocess
|
||||||
@ -478,6 +479,39 @@ def _CheckGitVersion():
|
|||||||
raise CloneFailure()
|
raise CloneFailure()
|
||||||
|
|
||||||
|
|
||||||
|
def SetGitTrace2ParentSid(env=None):
|
||||||
|
"""Set up GIT_TRACE2_PARENT_SID for git tracing."""
|
||||||
|
# We roughly follow the format git itself uses in trace2/tr2_sid.c.
|
||||||
|
# (1) Be unique (2) be valid filename (3) be fixed length.
|
||||||
|
#
|
||||||
|
# Since we always export this variable, we try to avoid more expensive calls.
|
||||||
|
# e.g. We don't attempt hostname lookups or hashing the results.
|
||||||
|
if env is None:
|
||||||
|
env = os.environ
|
||||||
|
|
||||||
|
KEY = 'GIT_TRACE2_PARENT_SID'
|
||||||
|
|
||||||
|
now = datetime.datetime.utcnow()
|
||||||
|
value = 'repo-%s-P%08x' % (now.strftime('%Y%m%dT%H%M%SZ'), os.getpid())
|
||||||
|
|
||||||
|
# If it's already set, then append ourselves.
|
||||||
|
if KEY in env:
|
||||||
|
value = env[KEY] + '/' + value
|
||||||
|
|
||||||
|
_setenv(KEY, value, env=env)
|
||||||
|
|
||||||
|
|
||||||
|
def _setenv(key, value, env=None):
|
||||||
|
"""Set |key| in the OS environment |env| to |value|."""
|
||||||
|
if env is None:
|
||||||
|
env = os.environ
|
||||||
|
# Environment handling across systems is messy.
|
||||||
|
try:
|
||||||
|
env[key] = value
|
||||||
|
except UnicodeEncodeError:
|
||||||
|
env[key] = value.encode()
|
||||||
|
|
||||||
|
|
||||||
def NeedSetupGnuPG():
|
def NeedSetupGnuPG():
|
||||||
if not os.path.isdir(home_dot_repo):
|
if not os.path.isdir(home_dot_repo):
|
||||||
return True
|
return True
|
||||||
@ -514,10 +548,7 @@ def SetupGnuPG(quiet):
|
|||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
env = os.environ.copy()
|
env = os.environ.copy()
|
||||||
try:
|
_setenv('GNUPGHOME', gpg_dir, env)
|
||||||
env['GNUPGHOME'] = gpg_dir
|
|
||||||
except UnicodeEncodeError:
|
|
||||||
env['GNUPGHOME'] = gpg_dir.encode()
|
|
||||||
|
|
||||||
cmd = ['gpg', '--import']
|
cmd = ['gpg', '--import']
|
||||||
try:
|
try:
|
||||||
@ -723,10 +754,7 @@ def _Verify(cwd, branch, quiet):
|
|||||||
print(file=sys.stderr)
|
print(file=sys.stderr)
|
||||||
|
|
||||||
env = os.environ.copy()
|
env = os.environ.copy()
|
||||||
try:
|
_setenv('GNUPGHOME', gpg_dir, env)
|
||||||
env['GNUPGHOME'] = gpg_dir
|
|
||||||
except UnicodeEncodeError:
|
|
||||||
env['GNUPGHOME'] = gpg_dir.encode()
|
|
||||||
|
|
||||||
cmd = [GIT, 'tag', '-v', cur]
|
cmd = [GIT, 'tag', '-v', cur]
|
||||||
proc = subprocess.Popen(cmd,
|
proc = subprocess.Popen(cmd,
|
||||||
@ -901,6 +929,9 @@ def _SetDefaultsTo(gitdir):
|
|||||||
def main(orig_args):
|
def main(orig_args):
|
||||||
cmd, opt, args = _ParseArguments(orig_args)
|
cmd, opt, args = _ParseArguments(orig_args)
|
||||||
|
|
||||||
|
# We run this early as we run some git commands ourselves.
|
||||||
|
SetGitTrace2ParentSid()
|
||||||
|
|
||||||
repo_main, rel_repo_dir = None, None
|
repo_main, rel_repo_dir = None, None
|
||||||
# Don't use the local repo copy, make sure to switch to the gitc client first.
|
# Don't use the local repo copy, make sure to switch to the gitc client first.
|
||||||
if cmd != 'gitc-init':
|
if cmd != 'gitc-init':
|
||||||
|
@ -19,8 +19,10 @@
|
|||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
import re
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
|
from pyversion import is_python3
|
||||||
import wrapper
|
import wrapper
|
||||||
|
|
||||||
|
|
||||||
@ -30,16 +32,22 @@ def fixture(*paths):
|
|||||||
return os.path.join(os.path.dirname(__file__), 'fixtures', *paths)
|
return os.path.join(os.path.dirname(__file__), 'fixtures', *paths)
|
||||||
|
|
||||||
|
|
||||||
class RepoWrapperUnitTest(unittest.TestCase):
|
class RepoWrapperTestCase(unittest.TestCase):
|
||||||
"""Tests helper functions in the repo wrapper
|
"""TestCase for the wrapper module."""
|
||||||
"""
|
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
"""Load the wrapper module every time
|
"""Load the wrapper module every time."""
|
||||||
"""
|
|
||||||
wrapper._wrapper_module = None
|
wrapper._wrapper_module = None
|
||||||
self.wrapper = wrapper.Wrapper()
|
self.wrapper = wrapper.Wrapper()
|
||||||
|
|
||||||
|
if not is_python3():
|
||||||
|
self.assertRegex = self.assertRegexpMatches
|
||||||
|
|
||||||
|
|
||||||
|
class RepoWrapperUnitTest(RepoWrapperTestCase):
|
||||||
|
"""Tests helper functions in the repo wrapper
|
||||||
|
"""
|
||||||
|
|
||||||
def test_get_gitc_manifest_dir_no_gitc(self):
|
def test_get_gitc_manifest_dir_no_gitc(self):
|
||||||
"""
|
"""
|
||||||
Test reading a missing gitc config file
|
Test reading a missing gitc config file
|
||||||
@ -80,5 +88,37 @@ class RepoWrapperUnitTest(unittest.TestCase):
|
|||||||
self.assertEqual(self.wrapper.gitc_parse_clientdir('/test/usr/local/google/gitc/'), None)
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/test/usr/local/google/gitc/'), None)
|
||||||
|
|
||||||
|
|
||||||
|
class SetGitTrace2ParentSid(RepoWrapperTestCase):
|
||||||
|
"""Check SetGitTrace2ParentSid behavior."""
|
||||||
|
|
||||||
|
KEY = 'GIT_TRACE2_PARENT_SID'
|
||||||
|
VALID_FORMAT = re.compile(r'^repo-[0-9]{8}T[0-9]{6}Z-P[0-9a-f]{8}$')
|
||||||
|
|
||||||
|
def test_first_set(self):
|
||||||
|
"""Test env var not yet set."""
|
||||||
|
env = {}
|
||||||
|
self.wrapper.SetGitTrace2ParentSid(env)
|
||||||
|
self.assertIn(self.KEY, env)
|
||||||
|
value = env[self.KEY]
|
||||||
|
self.assertRegex(value, self.VALID_FORMAT)
|
||||||
|
|
||||||
|
def test_append(self):
|
||||||
|
"""Test env var is appended."""
|
||||||
|
env = {self.KEY: 'pfx'}
|
||||||
|
self.wrapper.SetGitTrace2ParentSid(env)
|
||||||
|
self.assertIn(self.KEY, env)
|
||||||
|
value = env[self.KEY]
|
||||||
|
self.assertTrue(value.startswith('pfx/'))
|
||||||
|
self.assertRegex(value[4:], self.VALID_FORMAT)
|
||||||
|
|
||||||
|
def test_global_context(self):
|
||||||
|
"""Check os.environ gets updated by default."""
|
||||||
|
os.environ.pop(self.KEY, None)
|
||||||
|
self.wrapper.SetGitTrace2ParentSid()
|
||||||
|
self.assertIn(self.KEY, os.environ)
|
||||||
|
value = os.environ[self.KEY]
|
||||||
|
self.assertRegex(value, self.VALID_FORMAT)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
Loading…
Reference in New Issue
Block a user