-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy pathrepo.py
153 lines (113 loc) · 5.73 KB
/
repo.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
"""This module is used to handle all of the git operations for the
test suite"""
import os
import shutil
import test_util
class Repo:
""" a simple class to manage our git operations """
def __init__(self, suite, directory, name,
branch_wanted=None, pr_wanted=None, hash_wanted=None,
build=0, comp_string=None):
self.suite = suite
self.dir = directory
self.name = name
self.branch_wanted = branch_wanted
self.pr_wanted = pr_wanted
self.hash_wanted = hash_wanted
self.build = build # does this repo contain build directories?
self.comp_string = comp_string # environment vars needed to build
# for storage
self.branch_orig = None
self.hash_current = None
self.update = True
if hash_wanted:
self.update = False
def get_branch_name(self):
"""for descriptive purposes, return the name of the branch we will
use. This could be a PR branch that was fetched"""
if self.pr_wanted is not None:
return f"pr-{self.pr_wanted}"
elif self.branch_wanted is not None:
return self.branch_wanted.strip("\"")
return None
def git_update(self):
""" Do a git update of the repository. If githash is not empty, then
we will check out that version instead of git-pulling. """
os.chdir(self.dir)
# find out current branch so that we can go back later if we need.
stdout0, _, _ = test_util.run("git rev-parse --abbrev-ref HEAD")
self.branch_orig = stdout0.rstrip('\n')
# just in case the branch we want is not in the local repo
# yet, start out with a git fetch
self.suite.log.log(f"git fetch in {self.dir}")
_, _, rc = test_util.run("git fetch", stdin=True)
if rc != 0:
self.suite.log.fail("ERROR: git fetch was unsuccessful")
# if we need a special branch or are working on a PR, check it out now
if self.pr_wanted is not None:
self.suite.log.log(f"fetching PR {self.pr_wanted}")
_, _, rc = test_util.run("git fetch origin pull/{}/head:pr-{}".format(
self.pr_wanted, self.pr_wanted), stdin=True)
if rc != 0:
self.suite.log.fail("ERROR: git fetch was unsuccessful")
self.suite.log.log(f"checking out pr-{self.pr_wanted}")
_, _, rc = test_util.run(f"git checkout pr-{self.pr_wanted}", stdin=True)
if rc != 0:
self.suite.log.fail("ERROR: git checkout was unsuccessful")
elif self.branch_orig != self.branch_wanted:
self.suite.log.log(f"git checkout {self.branch_wanted} in {self.dir}")
_, _, rc = test_util.run(f"git checkout {self.branch_wanted}",
stdin=True)
if rc != 0:
self.suite.log.fail("ERROR: git checkout was unsuccessful")
else:
self.branch_wanted = self.branch_orig
# get up to date on our branch or hash
if self.pr_wanted is None:
if self.hash_wanted == "" or self.hash_wanted is None:
self.suite.log.log(f"'git pull' in {self.dir}")
_, _, rc = test_util.run("git pull", stdin=True,
outfile=f"git.{self.name}.out")
else:
_, _, rc = test_util.run(f"git checkout {self.hash_wanted}",
outfile=f"git.{self.name}.out")
if rc != 0:
self.suite.log.fail("ERROR: git update was unsuccessful")
shutil.copy(f"git.{self.name}.out", self.suite.full_web_dir)
if self.suite.updateGitSubmodules == 1:
# update submodules to those specified by the current commit
# (--init is required because there may be new submodules since the last checkout)
self.suite.log.log(f"git submodule update in {self.dir}")
_, _, rc = test_util.run(f"git submodule update --init")
if rc != 0:
self.suite.log.fail("ERROR: git submodule update was unsuccessful")
def save_head(self):
"""Save the current head of the repo"""
os.chdir(self.dir)
self.suite.log.log(f"saving git HEAD for {self.name}/")
stdout, _, _ = test_util.run("git rev-parse HEAD",
outfile=f"git.{self.name}.HEAD")
self.hash_current = stdout
shutil.copy(f"git.{self.name}.HEAD", self.suite.full_web_dir)
def make_changelog(self):
""" generate a ChangeLog git repository, and copy it to the
web directory"""
os.chdir(self.dir)
self.suite.log.log(f"generating ChangeLog for {self.name}/")
test_util.run("git log --name-only",
outfile=f"ChangeLog.{self.name}", outfile_mode="w")
shutil.copy(f"ChangeLog.{self.name}", self.suite.full_web_dir)
def git_back(self):
""" switch the repo back to its original branch """
os.chdir(self.dir)
self.suite.log.log(f"git checkout {self.branch_orig} in {self.dir}")
_, _, rc = test_util.run(f"git checkout {self.branch_orig}",
stdin=True, outfile=f"git.{self.name}.out")
if rc != 0:
self.suite.log.fail("ERROR: git checkout was unsuccessful")
# if we were working on a PR, delete the temporary branch, since we can't pull on it
if self.pr_wanted is not None:
self.suite.log.log(f"removing pr-{self.pr_wanted}")
_, _, rc = test_util.run(f"git branch -D pr-{self.pr_wanted}", stdin=True)
if rc != 0:
self.suite.log.fail("ERROR: git branch deletion was unsuccessful")