[pacman-dev] [PATCH] Fix pactest when scriptlet shell is specified
Allan McRae
allan at archlinux.org
Wed May 2 08:27:30 EDT 2012
On 02/05/12 22:17, Dan McGee wrote:
> On Wed, May 2, 2012 at 5:25 AM, Allan McRae <allan at archlinux.org> wrote:
>> If --with-scriptlet-shell is specified, sylimk the shell to /bin/sh
>> in order for the "make check" to pass.
>>
>> Signed-off-by: Allan McRae <allan at archlinux.org>
>
> Hmm. I'm not a fan of doing this in the sed/.in style at all; namely
> because pactest can be used to test the installed binary on the system
> as well as the one in the tree. Thus, tailoring it to the configure
> options without a way of undoing that seems like bad news.
>
> I'd much rather just add a new option to the invocation of pactest
> (--scriptlet-shell= or something) and add that to our one automated
> invocation in the toplevel Makefile.in; the substitution could thus be
> performed there instead.
OK, sounds easy enough to do.
> Finally, do we need to symlink it, or can we simply copy in only that
> binary (derferencing symlinks, of course)?
The only thing that could go wrong is a shell being used that does not
support "echo". I'm not sure if that is even possible, but "python -c"
works so...
> -Dan
>
>> ---
>>
>> This at least works with --with-scriptlet-shell=/bin/bash...
>>
>> test/pacman/Makefile.am | 9 +++++++++
>> test/pacman/{pmtest.py => pmtest.py.in} | 3 +++
>> 2 files changed, 12 insertions(+)
>> rename test/pacman/{pmtest.py => pmtest.py.in} (98%)
>>
>> diff --git a/test/pacman/Makefile.am b/test/pacman/Makefile.am
>> index d198ba2..b821458 100644
>> --- a/test/pacman/Makefile.am
>> +++ b/test/pacman/Makefile.am
>> @@ -19,4 +19,13 @@ EXTRA_DIST = \
>> ldconfig.stub \
>> $(check_SCRIPTS)
>>
>> +CLEANFILES = pmtest.py
>> +
>> +edit = sed \
>> + -e 's|@SCRIPTLET_SHELL[@]|$(SCRIPTLET_SHELL)|g'
>> +
>> +pmtest.py: pmtest.py.in Makefile
>> + $(AM_V_at)$(RM) $@
>> + $(AM_V_GEN)test -f $(srcdir)/$@.in && $(edit) $(srcdir)/$@.in >$@
>> +
>> # vim:set ts=2 sw=2 noet:
>> diff --git a/test/pacman/pmtest.py b/test/pacman/pmtest.py.in
>> similarity index 98%
>> rename from test/pacman/pmtest.py
>> rename to test/pacman/pmtest.py.in
>> index 1a02686..ace532d 100644
>> --- a/test/pacman/pmtest.py
>> +++ b/test/pacman/pmtest.py.in
>> @@ -127,6 +127,9 @@ def generate(self):
>> os.makedirs(sys_dir, 0755)
>> # Only the dynamically linked binary is needed for fakechroot
>> shutil.copy("/bin/sh", bindir)
>> + shell = "@SCRIPTLET_SHELL@"
>> + if not shell == "/bin/sh":
>> + os.symlink("/bin/sh", os.path.join(self.root, shell[1:]))
>> shutil.copy(os.path.join(util.SELFPATH, "ldconfig.stub"),
>> os.path.join(sbindir, "ldconfig"))
>> ld_so_conf = open(os.path.join(etcdir, "ld.so.conf"), "w")
>> --
>> 1.7.10
>>
>>
>
More information about the pacman-dev
mailing list