[PATCH] Allow spec file to be in a different path than /
Mike McLean
mikem at redhat.com
Fri Oct 24 15:29:46 UTC 2014
On 10/22/2014 03:55 AM, Thomas wrote:
> Hi All,
>
> I updated your patch so it does not assume sourcedir=chrootdir
> But it's not yet the perfect solution.
This looks reasonable, except that you dropped the directory existence
check, which makes the code /require/ the new layout if
support_rpm_source_layout is enabled. This is something of an interim
solution and I'd rather not break things for other folks (esp since
support_rpm_source_layout defaults to True).
I think the fix is something like this:
> For reference the layout is:
> SPEC/
> SOURCES/
> .metadata-file
>
> diff --git a/builder/kojid b/builder/kojid
> index 821f19d..4210823 100755
> --- a/builder/kojid
> +++ b/builder/kojid
> @@ -455,6 +455,10 @@ class BuildRoot(object):
>
> def build_srpm(self, specfile, sourcedir, source_cmd):
> self.session.host.setBuildRootState(self.id,'BUILDING')
> + if self.options.support_rpm_source_layout:
> + sources_dir = "%s/SOURCES" % sourcedir
> + else:
> + sources_dir = sourcedir
> if source_cmd:
> # call the command defined by source_cmd in the chroot so
> any required files not stored in
> # the SCM can be retrieved
> @@ -466,7 +470,7 @@ class BuildRoot(object):
> self.expire()
> raise koji.BuildError, "error retrieving sources, %s"
> % self._mockResult(rv)
>
> - args = ['--no-clean', '--buildsrpm', '--spec', specfile,
> '--sources', sourcedir,
> + args = ['--no-clean', '--buildsrpm', '--spec', specfile,
> '--sources', sources_dir,
> '--target', 'noarch']
>
> rv = self.mock(args)
> @@ -3793,10 +3797,7 @@ class BuildSRPMFromSCMTask(BaseBuildTask):
>
> #build srpm
> self.logger.debug("Running srpm build")
> - sources_dir = "%s/SOURCES" % sourcedir
> - if not self.options.support_rpm_source_layout or not
> os.path.isdir(sources_dir):
> - sources_dir = sourcedir
> - broot.build_srpm(spec_file, sources_dir, scm.source_cmd)
> + broot.build_srpm(spec_file, sourcedir, scm.source_cmd)
>
> srpms = glob.glob('%s/*.src.rpm' % broot.resultdir())
> if len(srpms) == 0:
>
> On Fri, Aug 15, 2014 at 12:10 AM, Mike McLean <mikem at redhat.com> wrote:
>> On 08/13/2014 06:05 PM, Mike McLean wrote:
>>> This much gets you halfway there, but it looks like the system is just
>>> going to choke later on having the sources under SOURCES instead of the
>>> git root dir.
>>>
>>> I guess you could set up a source_cmd to move or link the sources
>>> around, but that's hardly a clean solution.
>>>
>>> I wouldn't mind teaching koji to handle this layout, but it looks like
>>> it might be a little more involved than just the spec portion (unless
>>> I'm missing something). Did you have a solution for the SOURCES dir?
>>
>> Actually not that complicated after all. I did add an option to turn the
>> support off in case it causes a problem (possible that someone could
>> have a SOURCES dir in their checkout for some other reason).
>>
>> Anyway, here is where I'm at. Seems to be working.
>>
>
>
>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0001-do-not-require-rpm-source-layout.patch
Type: text/x-patch
Size: 1122 bytes
Desc: not available
URL: <http://lists.fedoraproject.org/pipermail/buildsys/attachments/20141024/f91963b3/attachment.bin>
More information about the buildsys
mailing list