source: ProjectBuilder/devel/pbtest/bin/pbtest@ 2214

Last change on this file since 2214 was 2214, checked in by Bruno Cornec, 7 years ago

Revert most of rev [2204]

There was an error on the directory considered for PBPRJDIR and PBDEFDIR/PBPROJ.
Back to normal now, as well as the case of pbinit files which was also broken

  • Property svn:executable set to *
File size: 13.4 KB
RevLine 
[1564]1#!/bin/bash
2#
3# Project Builder test suite
4#
5# $Id$
6#
[2032]7# Copyright B. Cornec 2007-2012-2016
[1564]8# Provided under the GPL v2
9
10# First create a dummy account for testing
[1587]11# In order for this script to run well, you should have sudo access
[1564]12
13# You may have multiple distros here
[2204]14TESTVEDIST="debian-8-x86_64 ubuntu-16.04-x86_64 fedora-25-x86_64 opensuse-42.2-x86_64 mageia-5-x86_64 centos-7-x86_64"
[1564]15# Only one VM is tested for now.
16TESTVMDIST="fedora-16-i386"
17TESTVMISO="/users/bruno/iso/Fedora-16-i386-DVD.iso"
[1597]18PBUSER=pbtest
19PBTEST="/home/$PBUSER"
[1587]20export PBPROJ=afio
[1564]21
[1587]22# Sub function to handle execution as pbtest
23# doesn't change to the home dir of the user as su - can't be used to get env var correct
[1581]24sudopbtest() {
25
26cmd=$1
[1587]27msg=$2
[1581]28
[1603]29echo " "
[1587]30if [ _"$cmd" == _"/tmp/pbtestcmd" ]; then
[1597]31 echo "INFO (as $PBUSER): Now running `head -1 $cmd` [$msg]"
[1587]32else
[1597]33 echo "INFO (as $PBUSER): Now running $cmd [$msg]"
[1587]34fi
[1597]35sudo -n -E su - $PBUSER -c "$cmd"
[1587]36ret=$?
37if [ $ret -ne 0 ] && [ _"$msg" == _"" ]; then
38 echo "================================"
39 echo "ERROR: Command $cmd failed: $ret"
40 echo "================================"
41fi
[1619]42return $ret
[1581]43}
44
[1587]45sudocmd() {
[2204]46cmd=$*
[1581]47
[1603]48echo " "
[1587]49echo "INFO (as root): Now running $cmd"
[1590]50sudo -n $cmd
[1587]51ret=$?
52if [ $ret -ne 0 ]; then
53 echo "================================"
54 echo "ERROR: Command $cmd failed: $ret"
55 echo "================================"
56fi
[1619]57return $ret
[1587]58}
59
60
[2204]61# For rpmbootstrap VE
[1603]62for d in $TESTVEDIST; do
63 # umount /proc in VE in case
64 dd=`echo $d | cut -d'-' -f1`
65 vv=`echo $d | cut -d'-' -f2`
66 aa=`echo $d | cut -d'-' -f3`
67 if [ -f "$PBTEST/ve/$dd/$vv/$aa/proc/cpuinfo" ]; then
68 sudocmd "umount $PBTEST/ve/$dd/$vv/$aa/proc"
69 fi
70done
[2204]71
72# Cleanup phase
[1597]73sudocmd "killall -u $PBUSER"
[2204]74sudocmd "rm -rf $PBTEST/"
[1597]75sudocmd "userdel $PBUSER"
76#sudocmd "groupdel $PBUSER" 1
77sudocmd "useradd $PBUSER"
[2204]78sudocmd "chmod 755 $PBTEST"
[1597]79sudocmd "grep -q $PBUSER /etc/sudoers"
[1565]80if [ $? -ne 0 ]; then
[1577]81 cat > /tmp/sudoers << EOF
[1587]82Defaults env_keep += "PBPROJ"
[1604]83# This is for the $PBUSER account for the VE and VM only
[1597]84$PBUSER ALL=NOPASSWD:/usr/sbin/chroot
85$PBUSER ALL=NOPASSWD:/usr/bin/rpmbootstrap
86$PBUSER ALL=NOPASSWD:/usr/sbin/debootstrap
87$PBUSER ALL=NOPASSWD:/bin/chmod
88$PBUSER ALL=NOPASSWD:/bin/cp
89$PBUSER ALL=NOPASSWD:/bin/rm
90$PBUSER ALL=NOPASSWD:/bin/tar
91$PBUSER ALL=NOPASSWD:/bin/mkdir
[1604]92$PBUSER ALL=NOPASSWD:/usr/bin/qemu-kvm
[2204]93$PBUSER ALL=NOPASSWD:/usr/bin/docker
[1564]94EOF
[1619]95 sudocmd "cat /etc/sudoers /tmp/sudoers" | grep -v "INFO " > /tmp/sudoers2
[1587]96 sudocmd "chmod 440 /tmp/sudoers2"
97 sudocmd "chown root:root /tmp/sudoers2"
98 sudocmd "mv /tmp/sudoers2 /etc/sudoers"
[1567]99 rm -f /tmp/sudoers /tmp/sudoers2
[1565]100fi
[2204]101# Force $PBUSER (for now pbtest hardcoded!) account passwd is $PBUSER
[1599]102sudocmd "perl -pi -e 's|^pbtest:.*|pbtest:$2a$08$2Q.tEty4v/fU0RyPeDelk.AjLAtXUXU3DpSs/l/8YrFmau1LJRCqC:15483:0:99999:7:::|' /etc/shadow"
[1594]103sudopbtest "echo export PBPROJ=$PBPROJ >> $PBTEST/.bash_profile"
[1587]104sudopbtest "env | grep PBPROJ"
[1564]105
[1565]106#Taken from Lab document originally
107# SVN repo setup
[1580]108sudopbtest "svnadmin create $PBTEST/svn"
[1577]109cat > /tmp/authz << EOF
[1565]110[/]
[1597]111$PBUSER = rw
[1565]112* = r
113EOF
[1587]114sudocmd "mv /tmp/authz $PBTEST/svn/conf/authz"
[1577]115cat > /tmp/passwd << EOF
[1574]116[users]
[1597]117$PBUSER = $PBUSER
[1565]118EOF
[1587]119sudocmd "mv /tmp/passwd $PBTEST/svn/conf/passwd"
[1567]120cat > /tmp/svnserve.conf << EOF
[1565]121[general]
[1573]122password-db = $PBTEST/svn/conf/passwd
[1565]123authz-db = authz
[1573]124anon-access = read
125auth-access = write
[1575]126realm = pb
[1565]127EOF
[1587]128sudocmd "mv /tmp/svnserve.conf $PBTEST/svn/conf/svnserve.conf"
[1597]129sudocmd "chown ${PBUSER}:$PBUSER $PBTEST/svn/conf/authz $PBTEST/svn/conf/passwd $PBTEST/svn/conf/svnserve.conf"
[1587]130sudopbtest "killall svnserve" 1
131sudopbtest "svnserve -d -r $PBTEST/svn"
132sudopbtest "mkdir -p $PBTEST/{ftp,ve,vm,.ssh,pb}"
133sudopbtest "chmod 700 $PBTEST/.ssh"
[1565]134
[2204]135sudopbtest "pb --version"
[1580]136sudopbtest "pbdistrocheck"
[1577]137
[1567]138cat > /tmp/.pbrc << EOF
[1564]139# Projects
[1565]140pbconfurl afio = svn://localhost/pb/afio/pbconf
[1567]141pbdefdir default = \$ENV{'HOME'}/pb
[1580]142pbconfurl pb = svn://svn.project-builder.org/pb/pbconf
[1567]143pbconfdir pb = \$ENV{'HOME'}/pb/pbconf
[1580]144pburl pb = svn://svn.project-builder.org/pb
[1565]145pburl mondorescue = svn://svn.mondorescue.org/mondorescue/branches
[1587]146sshhost pb = localhost
[1597]147sshlogin pb = $PBUSER
[1587]148sshdir pb = \$ENV{'HOME'}/ftp
[1564]149#
[2204]150pbpackager default = Big Chief <bigchief@project-builder.org>
[1564]151vmport pb = 2200
152pbparallel pb = 6
[1593]153vepath default = $PBTEST/ve
[1594]154vmpath default = $PBTEST/vm
[1587]155EOF
156sudocmd "mv /tmp/.pbrc $PBTEST/.pbrc"
157
[2204]158sudopbtest "pb -p $PBPROJ clean 2>&1 > /dev/null" 1
159
[1587]160cat > /tmp/.pbrc << EOF
[1565]161vmtype default = kvm
162vmcmd default = qemu-kvm
[1564]163vmsize fedora = 10G
[1565]164vmmonport default = 4000
[1604]165vmlogin default = $PBUSER
[1564]166EOF
[1594]167echo "vmlist default = `echo $TESTVMDIST | sed 's/ /,/g'`" >> /tmp/.pbrc
[1587]168sudocmd "mv /tmp/.pbrc $PBTEST/vm/.pbrc"
[1564]169
[1567]170cat > /tmp/.pbrc << EOF
[2204]171vetype default = docker
[1565]172verpmtype default = rpmbootstrap
173vedebtype default = debootstrap
174verebuild default = false
175veopt default =
176vesnap default = false
[1597]177velogin default = $PBUSER
[1565]178EOF
[1587]179echo "velist default = `echo $TESTVEDIST | sed 's/ /,/g'`" >> /tmp/.pbrc
180sudocmd "mv /tmp/.pbrc $PBTEST/ve/.pbrc"
[1597]181sudocmd "chown ${PBUSER}:$PBUSER $PBTEST/.pbrc $PBTEST/ve/.pbrc $PBTEST/vm/.pbrc"
[1565]182
[1587]183sudopbtest "ssh-keygen -f $PBTEST/.ssh/id_rsa -t rsa -b 768 -v -N ''"
184sudopbtest "cp $PBTEST/.ssh/id_rsa.pub $PBTEST/.ssh/authorized_keys"
[2204]185sudopbtest "chmod 600 $PBTEST/.ssh/authorized_keys $PBTEST/.ssh/id_rsa"
186sudopbtest "chmod 644 $PBTEST/.ssh/id_rsa.pub"
[1587]187sudopbtest "ssh localhost touch $PBTEST/ftp/README"
[1574]188
[1577]189# Create SVN conf files - doesn't work fully as it asks for a password - solved with PBVCSOPT
[1574]190cat > /tmp/servers << EOF
[1575]191[global]
[1574]192store-passwords = yes
193store-plaintext-passwords = yes
[1575]194store-auth-creds = yes
[1574]195EOF
[2204]196sudopbtest "mkdir -p $PBTEST/.subversion"
[1587]197sudocmd "mv /tmp/servers $PBTEST/.subversion/servers"
[1597]198sudocmd "chown ${PBUSER}:$PBUSER $PBTEST/.subversion/servers"
[1574]199
[1599]200VCSOPT="--username $PBUSER --password $PBUSER"
[1577]201
[1587]202sudopbtest "svn import $PBTEST/pb svn://localhost/pb -m 'Initial creation of pb repo' $VCSOPT"
203sudopbtest "svn co svn://localhost/pb $PBTEST/pb"
204sudopbtest "touch $PBTEST/pb/README"
205sudopbtest "svn add $PBTEST/pb/README"
[1590]206sudopbtest "svn ci $VCSOPT -m 'add readme' $PBTEST/pb/README"
[2204]207sudopbtest "svn info $PBTEST/pb 2>&1 > /dev/null" 1
208sudopbtest "PBVCSOPT=\"$VCSOPT\" pb -p $PBPROJ -r 2.5 newproj afio"
[1577]209
[1587]210grep -vE '^defpkgdir|^projver|^projtag|^pburl|^pbrepo|^shh' $PBTEST/pb/afio/pbconf/2.5/afio.pb > /tmp/afio.pb
[1567]211cat >> /tmp/afio.pb << EOF
[1565]212defpkgdir afio = dummy
213projver afio = 2.5
214projtag afio = 1
215pburl afio = ftp://ftp.project-builder.org/src/afio-2.5.tar.gz
216pbrepo afio = ftp://ftp.project-builder.org
217sshhost afio = localhost
[1597]218sshlogin afio = $PBUSER
[1567]219sshdir afio = \$ENV{'HOME'}/ftp
[1565]220EOF
[1587]221sudocmd "mv /tmp/afio.pb $PBTEST/pb/afio/pbconf/2.5/afio.pb"
[1597]222sudocmd "chown ${PBUSER}:$PBUSER $PBTEST/pb/afio/pbconf/2.5/afio.pb"
[1587]223cat > /tmp/pbtestcmd << EOF
224perl -pi -e 's|testver\s+afio\s+=\s+true|testver\ afio\ =\ false|' $PBTEST/pb/afio/pbconf/2.5/afio.pb
225EOF
226chmod 755 /tmp/pbtestcmd
227sudopbtest /tmp/pbtestcmd
[1565]228
[1587]229grep -vE 'PBSRC|PBDESC|PBSUMMARY|PBURL|PBLOG' $PBTEST/pb/afio/pbconf/2.5/pbfilter/all.pbf > /tmp/all.pbf
[1567]230cat >> /tmp/all.pbf << EOF
[1565]231filter PBSRC = src/%{name}-%{version}.tar.gz
232filter PBDESC = afio is a cpio compatible archiver with extended features$/It can compress on a file by file basis.
233filter PBSUMMARY = afio is a cpio compatible archiver with extended features
234filter PBURL = http://www.boutell.com/lsm/lsmbyid.cgi/000462
235filter PBLOG = no
236EOF
[1587]237sudocmd "mv /tmp/all.pbf $PBTEST/pb/afio/pbconf/2.5/pbfilter/all.pbf"
[1597]238sudocmd "chown ${PBUSER}:$PBUSER $PBTEST/pb/afio/pbconf/2.5/pbfilter/all.pbf"
[1577]239
[1587]240grep -vE 'PBGRP|PBLIC' $PBTEST/pb/afio/pbconf/2.5/pbfilter/rpm.pbf > /tmp/rpm.pbf
[1567]241cat >> /tmp/rpm.pbf << EOF
[1565]242filter PBGRP = Applications/Archiving
243filter PBLIC = Afio
[1601]244filter PBBDEP = gcc
[1565]245EOF
[1587]246sudocmd "mv /tmp/rpm.pbf $PBTEST/pb/afio/pbconf/2.5/pbfilter/rpm.pbf"
[1597]247sudocmd "chown ${PBUSER}:$PBUSER $PBTEST/pb/afio/pbconf/2.5/pbfilter/rpm.pbf "
[1577]248
[1601]249cat > /tmp/deb.pbf << EOF
[1597]250filter PBGRP = utils
251filter PBLIC = Afio
[1603]252filter PBBDEP = gcc
[1597]253EOF
254sudocmd "mv /tmp/deb.pbf $PBTEST/pb/afio/pbconf/2.5/pbfilter/deb.pbf"
[1599]255sudocmd "chown ${PBUSER}:$PBUSER $PBTEST/pb/afio/pbconf/2.5/pbfilter/deb.pbf "
[1597]256
[1577]257# First build
[2204]258sudopbtest "pb -p $PBPROJ -r 2.5 sbx2build"
[1565]259
[1587]260cat > /tmp/pbtestcmd << EOF
261# Filtering $PBTEST/pb/afio/pbconf/2.5/afio/rpm/afio.spec
262perl -pi -e 's|%configure||' $PBTEST/pb/afio/pbconf/2.5/afio/rpm/afio.spec
263perl -pi -e 's|make %{\?_smp_mflags}|make %{\?_smp_mflags}\nchmod 644 script*/*|' $PBTEST/pb/afio/pbconf/2.5/afio/rpm/afio.spec
[1590]264perl -pi -e 's|make DESTDIR=.*|mkdir -p %{buildroot}%{_bindir}\nmkdir -p %{buildroot}%{_mandir}/man1\ninstall -p -m 755 afio %{buildroot}%{_bindir}\ninstall -p -m 644 afio.1 %{buildroot}%{_mandir}/man1|' $PBTEST/pb/afio/pbconf/2.5/afio/rpm/afio.spec
[1587]265perl -pi -e 's|%doc ChangeLog|%doc HISTORY PORTING README SCRIPTS ANNOUNCE-2.5 perl.artistic.license|' $PBTEST/pb/afio/pbconf/2.5/afio/rpm/afio.spec
266perl -pi -e 's|%doc INSTALL COPYING README AUTHORS NEWS|%doc afio.lsm script1 script2 script3 script4\n%{_bindir}/%{name}\n%{_mandir}/man1/%{name}.1*|' $PBTEST/pb/afio/pbconf/2.5/afio/rpm/afio.spec
[1601]267perl -pi -e 's|^#BuildRequires:|BuildRequires:|' $PBTEST/pb/afio/pbconf/2.5/afio/rpm/afio.spec
[1587]268EOF
269chmod 755 /tmp/pbtestcmd
270sudopbtest /tmp/pbtestcmd
[1565]271
[1577]272cat > /tmp/pbcl << EOF
[1565]273# $Id$
[1564]274
[1565]275AFIO CHANGES
276
2772.5 (2009-12-03)
278- First packages created
279EOF
[1587]280sudocmd "mv /tmp/pbcl $PBTEST/pb/afio/pbconf/2.5/afio/pbcl"
[1597]281sudocmd "chown ${PBUSER}:$PBUSER $PBTEST/pb/afio/pbconf/2.5/afio/pbcl"
[1587]282sudopbtest "svn add $PBTEST/pb/afio/pbconf/2.5/afio/pbcl"
283sudopbtest "svn ci -m 'Adding pbcl for afio' $VCSOPT $PBTEST/pb"
[1565]284
[2204]285sudopbtest "pb -p afio -r 2.5 sbx2pkg"
286sudopbtest "rpm -qilvp $PBTEST/pb/afio/pbbuild/RPMS/x86_64/afio-2.5*"
[1587]287
288cat > /tmp/pbtestcmd << EOF
289# Filtering $PBTEST/pb/afio/pbconf/2.5/afio/deb/control
290perl -pi -e 's|,\s*PBDEP||' $PBTEST/pb/afio/pbconf/2.5/afio/deb/control
[1597]291sed -i '/Recommends: PBREC/d' $PBTEST/pb/afio/pbconf/2.5/afio/deb/control
292sed -i '/Suggests: PBSUG/d' $PBTEST/pb/afio/pbconf/2.5/afio/deb/control
[1587]293EOF
294chmod 755 /tmp/pbtestcmd
295sudopbtest /tmp/pbtestcmd
296
[1567]297cat > /tmp/afio.docs << EOF
[1565]298HISTORY
299PORTING
300README
301SCRIPTS
302ANNOUNCE-2.5
303perl.artistic.license
304afio.lsm
305script1
306script2
307script3
308script4
309EOF
[1587]310sudocmd "mv /tmp/afio.docs $PBTEST/pb/afio/pbconf/2.5/afio/deb/afio.docs"
[1597]311sudocmd "chown ${PBUSER}:$PBUSER $PBTEST/pb/afio/pbconf/2.5/afio/deb/afio.docs "
[1567]312
[1587]313cat > /tmp/pbtestcmd << EOF
314# Filtering $PBTEST/pb/afio/pbconf/2.5/afio/deb/rules
315perl -pi -e 's|config.status: configure|config.status: Makefile|' $PBTEST/pb/afio/pbconf/2.5/afio/deb/rules
316perl -pi -e 's|dh_installchangelogs ChangeLog|dh_installchangelogs debian/changelog|' $PBTEST/pb/afio/pbconf/2.5/afio/deb/rules
[1601]317perl -pi -e 's|# - copy html manual to temporary location for renaming|mkdir -p \\\$(CURDIR)/debian/\\\$(PACKAGE_NAME)/usr/bin \\\$(CURDIR)/debian/\\\$(PACKAGE_NAME)/usr/share/man/man1 ; install -p -m 755 afio \\\$(CURDIR)/debian/\\\$(PACKAGE_NAME)/usr/bin ; install -p -m 644 afio.1 \\\$(CURDIR)/debian/\\\$(PACKAGE_NAME)/usr/share/man/man1|' $PBTEST/pb/afio/pbconf/2.5/afio/deb/rules
[1587]318sed -i -e '/\.\/configure /d' $PBTEST/pb/afio/pbconf/2.5/afio/deb/rules
[1601]319sed -i -e '/ install prefix=/d' $PBTEST/pb/afio/pbconf/2.5/afio/deb/rules
[1587]320EOF
321chmod 755 /tmp/pbtestcmd
322sudopbtest /tmp/pbtestcmd
[1565]323
324#dpkg -I ~ftp/pub/afio/test/debian/5.0/afio_2.5-0.20091204131057_i386.deb
325#dpkg -x ~ftp/pub/afio/test/debian/5.0/afio_2.5-0.20091204131057_i386.deb /tmp/x ; ls -lR /tmp/x
326
[2204]327# need to be part of docker group for Docker
328sudocmd "grep -Eq '^docker:' /etc/group" | grep $PBUSER
329if [ $? -ne 0 ]; then
330 sudocmd usermod $PBUSER -G docker
331fi
[1587]332
[1564]333for d in $TESTVEDIST; do
334 dd=`echo $d | cut -d'-' -f1`
[1596]335 vv=`echo $d | cut -d'-' -f2`
336 aa=`echo $d | cut -d'-' -f3`
[2204]337 #sudopbtest "PATH=${PATH}:/sbin:/usr/sbin pb -p pb -T docker -m $d -i ${dd}:$vv newve"
338 #sudopbtest "pb -p pb -m $d -T docker sbx2setupve"
339 #sudopbtest "pb -p pb -m $d snapve"
340 sudopbtest "pb -p $PBPROJ -r 2.5 -m $d sbx2prepve"
341 sudopbtest "pb -p $PBPROJ -r 2.5 -m $d sbx2ve"
342 # Cleaning VE to use the snapshot
343 #dd=`echo $d | cut -d'-' -f1`
344 #vv=`echo $d | cut -d'-' -f2`
345 #aa=`echo $d | cut -d'-' -f3`
346 #if [ -f "$PBTEST/ve/$dd/$vv/$aa/proc/cpuinfo" ]; then
347 #sudocmd "umount $PBTEST/ve/$dd/$vv/$aa/proc"
348 #fi
349 #sudocmd "rm -rf $PBTEST/ve/$dd/$vv/$aa"
350 #sudopbtest "pb -S -m $d sbx2ve"
[1564]351done
352
[1590]353sudopbtest "svn ci $VCSOPT -m 'sync before newver' $PBTEST/pb"
[2204]354sudopbtest "PBVCSOPT=\"$VCSOPT\" pb -p $PBPROJ -r 2.5 -V 2.6 newver"
[1604]355# We now need to adapt tar file,log ... to a 2.6 content
[2204]356#sudopbtest "pb -p $PBPROJ -r 2.6 sbx2pkg"
[1565]357
[2204]358# need to be part of group video for KVM
[1606]359sudocmd "grep -Eq '^video:' /etc/group" | grep $PBUSER
[1597]360if [ $? -ne 0 ]; then
[2204]361 sudocmd usermod $PBUSER -G video
[1597]362fi
[2204]363
364sudopbtest "pb -p $PBPROJ getconf pburl"
365# test also with pb
366sudopbtest "pb -p pb -r devel getconf pburl"
367sudopbtest "pb -p pb -r devel sbx2pkg"
368sudopbtest "pb -p pb build2ssh"
369sudopbtest "pb -p pb pkg2ssh"
370
371d=mageia-5-i386
372sudopbtest "qemu-img create -f qcow2 $PBTEST/vm/$d.qemu 30G"
373sudopbtest "qemu-kvm -m 1024 -kernel /pub/mageia/distrib/5/i586/isolinux/i386/vmlinuz -initrd /pub/mageia/distrib/5/i586/isolinux/i386/all.rdz -append "ramdisk_size=128000 root=/dev/ram3 kickstart=http://192.168.8.2/pub/ks/guerrero/ks.pl automatic=method:http,server:192.168.8.2,directory:/pub/mageia/distrib/5/i586,network:dhcp" -drive file=$PBTEST/vm/$d.qemu,if=virtio,media=disk -boot once=n -redir tcp:2200:10.0.2.15:22"
[1601]374sudopbtest "pb -p pb -r devel -m $d sbx2setupvm"
[1597]375sudopbtest "pb -p pb -m $d snapvm"
[2204]376sudopbtest "pb -p pb -m $d sbx2vm"
[1580]377
[1601]378# test also with MondoRescue
[2214]379sudopbtest "pb -p mondorescue -r branches/3.3 cms2pkg"
380# and python-redfish
381sudopbtest "pb -p python-redfish sbx2pkg"
[1577]382
[1580]383# cleanup
[2204]384sudopbtest "pb -p $PBPROJ clean"
[1587]385sudopbtest "killall svnserve" 1
[1605]386exit
Note: See TracBrowser for help on using the repository browser.