summaryrefslogtreecommitdiffstats
path: root/meta/lib/oeqa/utils
diff options
context:
space:
mode:
authorMarkus Lehtonen <markus.lehtonen@linux.intel.com>2016-05-11 16:19:06 +0300
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-07-01 16:22:47 +0100
commit964fffa514fd60bd06eedfdda358133659b30ea2 (patch)
tree191ab764b88c56f2b2adccba4f5ed940b75db808 /meta/lib/oeqa/utils
parent8329d56cd43ef0a51c8040b62d3a40eb59bb39f7 (diff)
downloadpoky-964fffa514fd60bd06eedfdda358133659b30ea2.tar.gz
oeqa.utils: add git module
A new helper module for easier interaction with Git repositories. Provides GitRepo class that represents one local Git repository clone. The GitRepo class currently only has one method, run_cmd(), for running arbitrary git commands in the repository. More specialized methods for commonly used git operations can be added later. (From OE-Core rev: 4eaf434f885afbda03fe67ab6e9ff291c7a9c77e) Signed-off-by: Markus Lehtonen <markus.lehtonen@linux.intel.com> Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/lib/oeqa/utils')
-rw-r--r--meta/lib/oeqa/utils/git.py38
1 files changed, 38 insertions, 0 deletions
diff --git a/meta/lib/oeqa/utils/git.py b/meta/lib/oeqa/utils/git.py
new file mode 100644
index 0000000000..a4c6741f4e
--- /dev/null
+++ b/meta/lib/oeqa/utils/git.py
@@ -0,0 +1,38 @@
1#
2# Copyright (C) 2016 Intel Corporation
3#
4# Released under the MIT license (see COPYING.MIT)
5#
6"""Git repository interactions"""
7from oeqa.utils.commands import runCmd
8
9
10class GitError(Exception):
11 """Git error handling"""
12 pass
13
14class GitRepo(object):
15 """Class representing a Git repository clone"""
16 def __init__(self, cwd):
17 self.top_dir = self._run_git_cmd_at(['rev-parse', '--show-toplevel'],
18 cwd)
19
20 @staticmethod
21 def _run_git_cmd_at(git_args, cwd, **kwargs):
22 """Run git command at a specified directory"""
23 git_cmd = 'git ' if isinstance(git_args, str) else ['git']
24 git_cmd += git_args
25 ret = runCmd(git_cmd, ignore_status=True, cwd=cwd, **kwargs)
26 if ret.status:
27 cmd_str = git_cmd if isinstance(git_cmd, str) \
28 else ' '.join(git_cmd)
29 raise GitError("'{}' failed with exit code {}: {}".format(
30 cmd_str, ret.status, ret.output))
31 return ret.output.strip()
32
33 def run_cmd(self, git_args):
34 """Run Git command"""
35 return self._run_git_cmd_at(git_args, self.top_dir)
36
37
38