diff options
-rwxr-xr-x | iurt2 | 44 |
1 files changed, 27 insertions, 17 deletions
@@ -47,9 +47,12 @@ $run{todo} = [ ]; [ "", "cache", 0, "", "Use the global cache file", sub { $run{cache} = 1 }, "Activating cache use" ], + [ "", "copy_srpm", 0, "", + "Copy also the regenerated SRPM", + sub { $run{copy_srpm} = 1 }, "Activating the copy_srpm mode" ], [ "c", "chroot", 0, "", "Check chroot and update it if needed", - sub { $run{chroot} = 1 }, "Activating debug mode" ], + sub { $run{chroot} = 1 }, "Activating chroot updating" ], [ "", "config", 2, "<configuration keyword> <value>", "Override a configuration file variable", sub { my ($key, $value) = @_; $run{config}{$key} = $value }, "Overriding configuration variable" ], @@ -70,7 +73,7 @@ $run{todo} = [ ]; print *{$run{LOG}}, "command line: @ARGV\n"; 1 }, "Log file" ], - [ "m", "media", -1, "", + [ "m", "media", -1, "", "Media to rebuild", sub { ($run{media}) = @_; 1 }, "Adding a media to rebuild" ], [ "r", "rebuild", -2, "<distro> <architecture> <srpm 1> <srpm 2> ... <srpm n>", @@ -83,7 +86,9 @@ $run{todo} = [ ]; if (m,(.*/)([^/]*.src.rpm)$, && -f $_) { push @{$run{todo}}, [ $1, $2 ]; print {$run{LOG}} "iurt: force build for $2 (from $1)\n"; - 0 + } elsif (m,([^/]*.src.rpm)$, && -f $_) { + push @{$run{todo}}, [ './', $1 ]; + print {$run{LOG}} "iurt: force build for $1\n"; } else { die "FATAL iurt: $_ does not seems to be a SRPM\n" } @@ -313,9 +318,9 @@ retry: # if the previous package has been built without unionfs, chroot need to be cleaned clean_chroot($chroot, \%run) if !$unionfs_tmp; $unionfs_tmp = 1; - system(qq{sudo mount -t tmpfs none $tmpfs}) and die "FATAL iurt: could not mount $tmpfs ($!)"; - system(qq{sudo mount -o dirs=$tmpfs=rw:$home/chroot$debug_tag=ro -t unionfs none $chroot}) and die "FATAL iurt: could not mount $tmpfs and $home/chroot with unionfs ($!)"; - system("sudo mount -t proc none $chroot/proc") and die "FATAL iurt: could not mount /proc in the chroot $chroot."; + system(qq{sudo mount -t tmpfs none $tmpfs &>/dev/null}) and die "FATAL iurt: could not mount $tmpfs ($!)"; + system(qq{sudo mount -o dirs=$tmpfs=rw:$home/chroot$debug_tag=ro -t unionfs none $chroot &>/dev/null}) and die "FATAL iurt: could not mount $tmpfs and $home/chroot with unionfs ($!)"; + system("sudo mount -t proc none $chroot/proc &>/dev/null") and die "FATAL iurt: could not mount /proc in the chroot $chroot."; } } else { print {$run{LOG}} "iurt: installing a new chroot for $srpm in $chroot\n" if $run{verbose} > 1; @@ -367,7 +372,7 @@ retry: debug_mail => $run{debug}, error_regexp => 'cannot be installed', wait_regexp => 'database locked', - wait_callback => sub { $wait_limit++; if ($wait_limit > 10) { $wait_limit = 0; system(qq{sudo pkill -9 urpmi}) } }, + wait_callback => sub { $wait_limit++; if ($wait_limit > 10) { $wait_limit = 0; system(qq{sudo pkill -9 urpmi &>/dev/null}) } }, log => "$local_spool/log/", callback => sub { my ($opt, $output) = @_; @@ -402,7 +407,7 @@ retry: timeout => 60, debug_mail => $run{debug}, log => "$local_spool/log/"); # or next; As this failed quite often, do not stop - print {$run{LOG}} "Compiling $srpm\n" if $run{verbose} > 1; + print {$run{LOG}} "Compiling $srpm\n" if $run{verbose}; if (!perform_command(qq{TMP=/home/builder/tmp/ sudo chroot $chroot /bin/su builder -c "rpm --rebuild /home/builder/rpm/SRPMS/$srpm"}, \%run, $config, mail => $maintainer, @@ -466,8 +471,11 @@ retry: exit } else { print {$run{LOG}} "iurt: build successful, copying packages to $local_spool.\n"; - system("cp $chroot/home/builder/rpm/RPMS/*/*.rpm $local_spool") and print {$run{LOG}} "ERROR: could not copy rpm files from $chroot/home/builder/rpm/RPMS/ to $local_spool ($!)\n"; - process_queue($config, \%run, \@wrong_rpm) + system("cp $chroot/home/builder/rpm/RPMS/*/*.rpm $local_spool &>/dev/null") and print {$run{LOG}} "ERROR: could not copy rpm files from $chroot/home/builder/rpm/RPMS/ to $local_spool ($!)\n"; + if ($run{copy_srpm}) { + system("cp $chroot/home/builder/rpm/SRPMS/$srpm $local_spool &>/dev/null") and print {$run{LOG}} "ERROR: could not copy $srpm from $chroot/home/builder/rpm/SRPMS/ to $local_spool ($!)\n"; + } + process_queue($config, \%run, \@wrong_rpm, 1) } } @@ -518,7 +526,7 @@ sub clean_all_unionfs { print {$run{LOG}} "Cleaning old unionfs remaining dir in $unionfs_dir\n" if $run{verbose} > 1; opendir my $dir, $unionfs_dir or die "FATAL iurt: could not open $unionfs_dir ($!)"; foreach (readdir $dir) { - /unionfs\.(\d+)\.(\d+)/ or next; + /unionfs\.((?:0.)\d+)\.(\d+)$/ or next; clean_unionfs($unionfs_dir, $1, $2); } closedir $dir @@ -547,7 +555,7 @@ sub clean_chroot { die => 1); dump_rpmmacros("$chroot/home/builder/.rpmmacros") or return; - system("sudo mount none -t proc $chroot/proc") and return; + system("sudo mount none -t proc $chroot/proc &>/dev/null") and return; 1 } @@ -566,7 +574,7 @@ sub clean { my $ps; my $i; while ($ps = `$cmd "$var"`) { - system(qq{$kill_cmd "$var"}); + system(qq{$kill_cmd "$var" &>/dev/null}); sleep 1; $ps =~ s/\n/,/g; print {$run{LOG}} "Trying to remove previous blocked processes for $var ($ps)\n" if $verbose > 1; @@ -588,7 +596,7 @@ sub clean_unionfs { my $d = "$unionfs_dir/$t.$run.$union_id"; my $last; while (check_mounted($d, $t)) { - system("sudo fuser -k $d"); + system("sudo fuser -k $d &> /dev/null"); print {$run{LOG}} "iurt: umounting $d\n" if $run{verbose} > 2; if (system(qq{sudo umount $d &> /dev/null})) { print {$run{LOG}} "WARNING iurt: could not umount $d ($!)\n" if $run{verbose} > 1; @@ -641,13 +649,15 @@ sub check_needed { } sub process_queue { - my ($config, $run, $wrong_rpm) = @_; - return if !$run->{upload}; + my ($config, $run, $wrong_rpm, $quiet) = @_; + return if !$run->{upload} && $quiet; my $dir = "$config->{local_upload}/iurt/$run->{distro_tag}/$run->{my_arch}"; opendir my $rpmdir, $dir or next; foreach my $rpm (readdir $rpmdir) { my ($rarch, $srpm) = update_srpm($dir, $rpm, $wrong_rpm); $rarch or next; + print {$run{LOG}} "iurt: $rpm\n"; + next if !$run->{upload}; # recheck if the package has not been uploaded in the meantime my $rpms_dir = "$config->{repository}/$run->{distro}/$run->{my_arch}/media/$run->{media}/"; if (! -f "$rpms_dir/$rpm") { @@ -829,7 +839,7 @@ sub kill_for_good { sub check_chroot { my ($chroot, $chroot_tar, $run) = @_; print {$run{LOG}} "iurt: checking basesystem tar\n" if $run{verbose}; - system(qq{sudo pkill -9 -u root -f "urpmi $urpmi_options --root $chroot"}); + system(qq{sudo pkill -9 -u root -f "urpmi $urpmi_options --root $chroot" &> /dev/null}); clean_chroot($chroot, $run, 1) or die "FATAL iurt: Could no prepare initial chroot"; perform_command("sudo $config->{install_chroot_binary} cooker $config->{basesystem_media} $chroot_tar $chroot 501 basesystem tar rpm-build", $run, $config, |