Gentoo Archives: gentoo-commits

From: Magnus Granberg <zorry@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] proj/tinderbox-cluster:master commit in: buildbot_gentoo_ci/config/, buildbot_gentoo_ci/db/, buildbot_gentoo_ci/steps/
Date: Thu, 28 Jan 2021 01:09:27
Message-Id: 1611796178.7c12da2ec9470fcf82b37943e2a1cc523351aefe.zorry@gentoo
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