1 |
commit: 7c12da2ec9470fcf82b37943e2a1cc523351aefe |
2 |
Author: Magnus Granberg <zorry <AT> gentoo <DOT> org> |
3 |
AuthorDate: Thu Jan 28 01:09:38 2021 +0000 |
4 |
Commit: Magnus Granberg <zorry <AT> gentoo <DOT> org> |
5 |
CommitDate: Thu Jan 28 01:09:38 2021 +0000 |
6 |
URL: https://gitweb.gentoo.org/proj/tinderbox-cluster.git/commit/?id=7c12da2e |
7 |
|
8 |
Add SetReposConf and UpdateRepos |
9 |
|
10 |
Signed-off-by: Magnus Granberg <zorry <AT> gentoo.org> |
11 |
|
12 |
buildbot_gentoo_ci/config/buildfactorys.py | 13 ++-- |
13 |
buildbot_gentoo_ci/db/model.py | 3 +- |
14 |
buildbot_gentoo_ci/db/projects.py | 29 ++++++++- |
15 |
buildbot_gentoo_ci/steps/builders.py | 98 ++++++++++++++++++++++++++---- |
16 |
4 files changed, 123 insertions(+), 20 deletions(-) |
17 |
|
18 |
diff --git a/buildbot_gentoo_ci/config/buildfactorys.py b/buildbot_gentoo_ci/config/buildfactorys.py |
19 |
index a6bafb5..3fad219 100644 |
20 |
--- a/buildbot_gentoo_ci/config/buildfactorys.py |
21 |
+++ b/buildbot_gentoo_ci/config/buildfactorys.py |
22 |
@@ -88,8 +88,8 @@ def build_request_check(): |
23 |
def run_build_request(): |
24 |
f = util.BuildFactory() |
25 |
# FIXME: 5 |
26 |
- # update repo for the profile |
27 |
- f.addStep(builders.UpdateProfileRepo()) |
28 |
+ # set needed Propertys |
29 |
+ f.addStep(builders.SetupPropertys()) |
30 |
# Clean and add new /etc/portage |
31 |
f.addStep(buildbot_steps.RemoveDirectory(dir="portage", |
32 |
workdir='/etc/')) |
33 |
@@ -99,9 +99,10 @@ def run_build_request(): |
34 |
f.addStep(buildbot_steps.MakeDirectory(dir="make.profile", |
35 |
workdir='/etc/portage/')) |
36 |
f.addStep(builders.SetMakeProfile()) |
37 |
- # setup repo.conf dir |
38 |
- #f.addStep(buildbot_steps.MakeDirectory(dir="repo.conf", |
39 |
+ # setup repos.conf dir |
40 |
+ f.addStep(buildbot_steps.MakeDirectory(dir="repos.conf", |
41 |
workdir='/etc/portage/')) |
42 |
- # check if we have all repository's in repos.conf listed in project_repository's |
43 |
- # update all repos listed in project_repository's |
44 |
+ f.addStep(builders.SetReposConf()) |
45 |
+ # update the repositorys listed in project_repository |
46 |
+ f.addStep(builders.UpdateRepos()) |
47 |
return f |
48 |
|
49 |
diff --git a/buildbot_gentoo_ci/db/model.py b/buildbot_gentoo_ci/db/model.py |
50 |
index 0defb0c..596d04e 100644 |
51 |
--- a/buildbot_gentoo_ci/db/model.py |
52 |
+++ b/buildbot_gentoo_ci/db/model.py |
53 |
@@ -138,7 +138,8 @@ class Model(base.DBConnectorComponent): |
54 |
sa.Column('project_uuid', sa.String(36), |
55 |
sa.ForeignKey('projects.uuid', ondelete='CASCADE'), |
56 |
nullable=False), |
57 |
- sa.Column('directorys', sa.Enum('make.profile'), nullable=False), |
58 |
+ # FIXME: directorys should be moved to own table |
59 |
+ sa.Column('directorys', sa.Enum('make.profile', 'repos.conf'), nullable=False), |
60 |
sa.Column('value', sa.String(255), nullable=False), |
61 |
) |
62 |
|
63 |
|
64 |
diff --git a/buildbot_gentoo_ci/db/projects.py b/buildbot_gentoo_ci/db/projects.py |
65 |
index 5c3406a..00e1569 100644 |
66 |
--- a/buildbot_gentoo_ci/db/projects.py |
67 |
+++ b/buildbot_gentoo_ci/db/projects.py |
68 |
@@ -80,7 +80,19 @@ class ProjectsConnectorComponent(base.DBConnectorComponent): |
69 |
return res |
70 |
|
71 |
@defer.inlineCallbacks |
72 |
- def getProjectPortageByUuidAndDirectory(self, uuid, directory): |
73 |
+ def getRepositorysByProjectUuid(self, uuid, auto=True): |
74 |
+ def thd(conn): |
75 |
+ tbl = self.db.model.projects_repositorys |
76 |
+ q = tbl.select() |
77 |
+ q = q.where(tbl.c.project_uuid == uuid) |
78 |
+ q = q.where(tbl.c.auto == auto) |
79 |
+ return [self._row2dict_projects_repositorys(conn, row) |
80 |
+ for row in conn.execute(q).fetchall()] |
81 |
+ res = yield self.db.pool.do(thd) |
82 |
+ return res |
83 |
+ |
84 |
+ @defer.inlineCallbacks |
85 |
+ def getAllProjectPortageByUuidAndDirectory(self, uuid, directory): |
86 |
def thd(conn): |
87 |
tbl = self.db.model.projects_portage |
88 |
q = tbl.select() |
89 |
@@ -91,6 +103,21 @@ class ProjectsConnectorComponent(base.DBConnectorComponent): |
90 |
res = yield self.db.pool.do(thd) |
91 |
return res |
92 |
|
93 |
+ @defer.inlineCallbacks |
94 |
+ def getProjectPortageByUuidAndDirectory(self, uuid, directory): |
95 |
+ def thd(conn): |
96 |
+ tbl = self.db.model.projects_portage |
97 |
+ q = tbl.select() |
98 |
+ q = q.where(tbl.c.project_uuid == uuid) |
99 |
+ q = q.where(tbl.c.directorys == directory) |
100 |
+ res = conn.execute(q) |
101 |
+ row = res.fetchone() |
102 |
+ if not row: |
103 |
+ return None |
104 |
+ return self._row2dict_projects_portage(conn, row) |
105 |
+ res = yield self.db.pool.do(thd) |
106 |
+ return res |
107 |
+ |
108 |
def _row2dict(self, conn, row): |
109 |
return dict( |
110 |
uuid=row.uuid, |
111 |
|
112 |
diff --git a/buildbot_gentoo_ci/steps/builders.py b/buildbot_gentoo_ci/steps/builders.py |
113 |
index 1c8cbb0..d3b3607 100644 |
114 |
--- a/buildbot_gentoo_ci/steps/builders.py |
115 |
+++ b/buildbot_gentoo_ci/steps/builders.py |
116 |
@@ -80,9 +80,9 @@ class GetProjectRepositoryData(BuildStep): |
117 |
yield self.build.addStepsAfterCurrentStep([TriggerRunBuildRequest()]) |
118 |
return SUCCESS |
119 |
|
120 |
-class UpdateProfileRepo(BuildStep): |
121 |
+class SetupPropertys(BuildStep): |
122 |
|
123 |
- name = 'UpdateProfileRepo' |
124 |
+ name = 'SetupPropertys' |
125 |
description = 'Running' |
126 |
descriptionDone = 'Ran' |
127 |
descriptionSuffix = None |
128 |
@@ -101,17 +101,8 @@ class UpdateProfileRepo(BuildStep): |
129 |
self.setProperty('portage_repos_path', self.portage_repos_path, 'portage_repos_path') |
130 |
projectrepository_data = self.getProperty('projectrepository_data') |
131 |
print(projectrepository_data) |
132 |
- repository_data = yield self.gentooci.db.repositorys.getRepositoryByUuid(projectrepository_data['repository_uuid']) |
133 |
project_data = yield self.gentooci.db.projects.getProjectByUuid(projectrepository_data['project_uuid']) |
134 |
self.setProperty('project_data', project_data, 'project_data') |
135 |
- self.profile_repository_data = yield self.gentooci.db.repositorys.getRepositoryByUuid(project_data['profile_repository_uuid']) |
136 |
- profile_repository_path = yield os.path.join(self.portage_repos_path, self.profile_repository_data['name']) |
137 |
- yield self.build.addStepsAfterCurrentStep([ |
138 |
- steps.Git(repourl=self.profile_repository_data['mirror_url'], |
139 |
- mode='incremental', |
140 |
- submodules=True, |
141 |
- workdir=os.path.join(profile_repository_path, '')) |
142 |
- ]) |
143 |
return SUCCESS |
144 |
|
145 |
class SetMakeProfile(BuildStep): |
146 |
@@ -133,7 +124,7 @@ class SetMakeProfile(BuildStep): |
147 |
project_data = self.getProperty('project_data') |
148 |
profile_repository_data = yield self.gentooci.db.repositorys.getRepositoryByUuid(project_data['profile_repository_uuid']) |
149 |
makeprofiles_paths = [] |
150 |
- makeprofiles_data = yield self.gentooci.db.projects.getProjectPortageByUuidAndDirectory(project_data['uuid'], 'make.profile') |
151 |
+ makeprofiles_data = yield self.gentooci.db.projects.getAllProjectPortageByUuidAndDirectory(project_data['uuid'], 'make.profile') |
152 |
for makeprofile in makeprofiles_data: |
153 |
makeprofile_path = yield os.path.join(portage_repos_path, profile_repository_data['name'], 'profiles', makeprofile['value'], '') |
154 |
makeprofiles_paths.append('../../..' + makeprofile_path) |
155 |
@@ -145,3 +136,86 @@ class SetMakeProfile(BuildStep): |
156 |
workdir='/etc/portage/') |
157 |
]) |
158 |
return SUCCESS |
159 |
+ |
160 |
+class SetReposConf(BuildStep): |
161 |
+ |
162 |
+ name = 'SetReposConf' |
163 |
+ description = 'Running' |
164 |
+ descriptionDone = 'Ran' |
165 |
+ descriptionSuffix = None |
166 |
+ haltOnFailure = True |
167 |
+ flunkOnFailure = True |
168 |
+ |
169 |
+ def __init__(self, **kwargs): |
170 |
+ super().__init__(**kwargs) |
171 |
+ |
172 |
+ @defer.inlineCallbacks |
173 |
+ def run(self): |
174 |
+ self.gentooci = self.master.namedServices['services'].namedServices['gentooci'] |
175 |
+ portage_repos_path = self.getProperty('portage_repos_path') |
176 |
+ project_data = self.getProperty('project_data') |
177 |
+ # setup the default.conf |
178 |
+ repos_conf_data = yield self.gentooci.db.projects.getProjectPortageByUuidAndDirectory(project_data['uuid'], 'repos.conf') |
179 |
+ if repos_conf_data is None: |
180 |
+ print('Default repo is not set in repos.conf') |
181 |
+ return FAILURE |
182 |
+ # check if repos_conf_data['value'] is vaild repo name |
183 |
+ separator = '\n' |
184 |
+ default_conf = [] |
185 |
+ default_conf.append('[DEFAULT]') |
186 |
+ default_conf.append('main-repo = ' + repos_conf_data['value']) |
187 |
+ default_conf.append('auto-sync = no') |
188 |
+ default_conf_string = separator.join(default_conf) |
189 |
+ yield self.build.addStepsAfterCurrentStep([ |
190 |
+ steps.StringDownload(default_conf_string + separator, |
191 |
+ workerdest="repos.conf/default.conf", |
192 |
+ workdir='/etc/portage/') |
193 |
+ ]) |
194 |
+ # add all repos that project have in projects_repositorys to repos.conf/reponame.conf |
195 |
+ projects_repositorys_data = yield self.gentooci.db.projects.getRepositorysByProjectUuid(project_data['uuid']) |
196 |
+ for project_repository_data in projects_repositorys_data: |
197 |
+ repository_data = yield self.gentooci.db.repositorys.getRepositoryByUuid(project_repository_data['repository_uuid']) |
198 |
+ repository_path = yield os.path.join(portage_repos_path, repository_data['name']) |
199 |
+ repository_conf = [] |
200 |
+ repository_conf.append('[' + repository_data['name'] + ']') |
201 |
+ repository_conf.append('location = ' + repository_path) |
202 |
+ repository_conf.append('sync-uri = ' + repository_data['mirror_url']) |
203 |
+ repository_conf.append('sync-type = git') |
204 |
+ repository_conf.append('auto-sync = no') |
205 |
+ repository_conf_string = separator.join(repository_conf) |
206 |
+ yield self.build.addStepsAfterCurrentStep([ |
207 |
+ steps.StringDownload(repository_conf_string + separator, |
208 |
+ workerdest='repos.conf/' + repository_data['name'] + '.conf', |
209 |
+ workdir='/etc/portage/') |
210 |
+ ]) |
211 |
+ return SUCCESS |
212 |
+ |
213 |
+class UpdateRepos(BuildStep): |
214 |
+ |
215 |
+ name = 'UpdateRepos' |
216 |
+ description = 'Running' |
217 |
+ descriptionDone = 'Ran' |
218 |
+ descriptionSuffix = None |
219 |
+ haltOnFailure = True |
220 |
+ flunkOnFailure = True |
221 |
+ |
222 |
+ def __init__(self, **kwargs): |
223 |
+ super().__init__(**kwargs) |
224 |
+ |
225 |
+ @defer.inlineCallbacks |
226 |
+ def run(self): |
227 |
+ self.gentooci = self.master.namedServices['services'].namedServices['gentooci'] |
228 |
+ portage_repos_path = self.getProperty('portage_repos_path') |
229 |
+ project_data = self.getProperty('project_data') |
230 |
+ # update/add all repos that in project_repository for the project |
231 |
+ projects_repositorys_data = yield self.gentooci.db.projects.getRepositorysByProjectUuid(project_data['uuid']) |
232 |
+ for project_repository_data in projects_repositorys_data: |
233 |
+ repository_data = yield self.gentooci.db.repositorys.getRepositoryByUuid(project_repository_data['repository_uuid']) |
234 |
+ repository_path = yield os.path.join(portage_repos_path, repository_data['name']) |
235 |
+ yield self.build.addStepsAfterCurrentStep([ |
236 |
+ steps.Git(repourl=repository_data['mirror_url'], |
237 |
+ mode='incremental', |
238 |
+ submodules=True, |
239 |
+ workdir=os.path.join(repository_path, '')) |
240 |
+ ]) |
241 |
+ return SUCCESS |