diff options
| -rwxr-xr-x | iurt2 | 15 | ||||
| -rw-r--r-- | lib/Iurt/Chroot.pm | 15 | ||||
| -rw-r--r-- | lib/Iurt/Urpmi.pm | 3 | 
3 files changed, 11 insertions, 22 deletions
| @@ -39,7 +39,7 @@ use URPM;  use Iurt::DKMS;  use Iurt::Urpmi; -use Iurt::Chroot qw(add_local_user create_temp_chroot remove_chroot clean_all_chroot_tmp check_build_chroot clean_chroot); +use Iurt::Chroot qw(add_local_user create_temp_chroot remove_chroot clean_all_chroot_tmp create_build_chroot clean_chroot);  use Iurt::Process qw(perform_command kill_for_good sudo);  use Iurt::Mail qw(sendmail);  use Iurt::Util qw(plog_init plog); @@ -716,7 +716,7 @@ $run{chroot_tar} = $chroot_tar;  # even in use_old_chroot mode we create the chroot if it does not exist (useful   # if the option is used for the first time  if ($run{chroot} || !-d "$chroot/dev") { -    check_build_chroot($chroot, $chroot_tar, \%run, $config) or die "FATAL $program_name: could not prepare initial chroot"; +    create_build_chroot($chroot, $chroot_tar, \%run, $config) or die "FATAL $program_name: could not prepare initial chroot";  }  # now exit if there is nothing to do and it was just a cleaning pass @@ -864,9 +864,14 @@ retry:  	($ret, $srpm, $spec) = $urpmi->recreate_srpm(\%run, $config,  			$chroot_tmp, $dir, $srpm, $luser, $retry);  	if ($ret == -1) { -	    $retry = 1; -	    goto retry; -	} elsif (!$ret) { +	    if (create_build_chroot($run->{chroot_path}, $run->{chroot_tar}, $run,  $config)) { +		$retry = 1; +		goto retry; +	    } else { +		$ret = 0; +	    } +	}  +	if (!$ret) {  	    # CM: experimental: fail if we can't regenerate the srpm  	    #     This should eliminate bouncers that block the input queue   	    # diff --git a/lib/Iurt/Chroot.pm b/lib/Iurt/Chroot.pm index 01cd514..32232a3 100644 --- a/lib/Iurt/Chroot.pm +++ b/lib/Iurt/Chroot.pm @@ -20,7 +20,6 @@ our @EXPORT = qw(      remove_chroot      create_chroot      create_build_chroot -    check_build_chroot  );  my $sudo = '/usr/bin/sudo'; @@ -409,18 +408,4 @@ sub build_chroot {      1;  } -sub check_build_chroot { -    my ($chroot, $chroot_tar, $run, $config) = @_; - -    plog('DEBUG', "checking basesystem tar"); -     -    my (@stat) = stat $chroot_tar; - -    if (time -$stat[9] > 604800) { -	plog('WARN', "chroot tarball too old, force rebuild"); -	sudo($config, '--rm', '-r', $chroot, $chroot_tar); -    } -    create_build_chroot($chroot, $chroot_tar, $run, $config); -} -  1; diff --git a/lib/Iurt/Urpmi.pm b/lib/Iurt/Urpmi.pm index 5b28c8d..a70febf 100644 --- a/lib/Iurt/Urpmi.pm +++ b/lib/Iurt/Urpmi.pm @@ -5,7 +5,7 @@ use RPM4::Header;  use File::Basename;  use File::NCopy qw(copy);  use MDV::Distribconf::Build; -use Iurt::Chroot qw(add_local_user create_temp_chroot check_build_chroot); +use Iurt::Chroot qw(add_local_user create_temp_chroot);  use Iurt::Process qw(perform_command clean_process sudo);  use Iurt::Config qw(dump_cache_par get_maint get_package_prefix);  use Iurt::Util qw(plog); @@ -642,7 +642,6 @@ sub recreate_srpm {  	    $run, $config, $cache, %opt)) {  	plog("ERROR: chrooting failed (retry $opt{retry}") if $run->{debug};  	if ($opt{retry}) { -	    check_build_chroot($run->{chroot_path}, $run->{chroot_tar}, $run,  $config) or return;  	    return -1;  	}  	return; | 
