Merge pull request #1073 from jberry-suse/check_source-remove-diff

check_source: remove DIFFCOUNT algorithm and instead always add review_team.
This commit is contained in:
Jimmy Berry 2017-08-22 17:06:59 -05:00 committed by GitHub
commit 55aeefacb4
3 changed files with 6 additions and 56 deletions

View File

@ -280,39 +280,6 @@ sub prepare_package($) {
print SPEC join('', @lines); print SPEC join('', @lines);
close(SPEC); close(SPEC);
} }
my $dir = getcwd();
my $diffcount = 0;
for my $file (glob "*") {
my $oldfile = $files->{$file};
if ($oldfile) {
for my $line (split(/\n/, diff($oldfile, $file))) {
next unless $line =~ m/^[-+]/;
next if $line =~ m/^\Q---/;
next if $line =~ m/^\Q+++/;
if ($file =~ m/\.spec$/) {
$diffcount++;
for my $command (qw(chmod chown rm)) {
if ($line =~ m/\b$command\b/) {
$diffcount += 3000;
last;
}
}
} else {
$diffcount += 7777;
last;
}
}
delete $files->{$file};
}
else {
$files->{$file} = "$dir/$file";
}
}
return $diffcount;
} }
# move it back so we also diff the service file # move it back so we also diff the service file
@ -325,11 +292,5 @@ chdir($old);
prepare_package(\%files); prepare_package(\%files);
chdir($odir); chdir($odir);
chdir($dir); chdir($dir);
my $diff = prepare_package(\%files); prepare_package(\%files);
for my $file (keys %files) {
$diff += 10000;
}
print "DIFFCOUNT $diff\n";
exit(0); exit(0);

View File

@ -81,8 +81,8 @@ class CheckSource(ReviewBot.ReviewBot):
self.review_messages['declined'] = "A package submitted as %s has to build as 'Name: %s' - found Name '%s'" % (target_package, target_package, new_info['name']) self.review_messages['declined'] = "A package submitted as %s has to build as 'Name: %s' - found Name '%s'" % (target_package, target_package, new_info['name'])
return False return False
# Run source-checker.pl script and interpret output. # Run check_source.pl script and interpret output.
source_checker = os.path.join(CheckSource.SCRIPT_PATH, 'source-checker.pl') source_checker = os.path.join(CheckSource.SCRIPT_PATH, 'check_source.pl')
civs = '' civs = ''
new_version = None new_version = None
if old_info['version'] and old_info['version'] != new_info['version']: if old_info['version'] and old_info['version'] != new_info['version']:
@ -104,23 +104,12 @@ class CheckSource(ReviewBot.ReviewBot):
shutil.rmtree(dir) shutil.rmtree(dir)
self.review_messages['accepted'] = 'Check script succeeded' self.review_messages['accepted'] = 'Check script succeeded'
# Look for DIFFCOUNT in output.
if len(checked) and checked[-1].startswith('DIFFCOUNT'):
# This is a major break through in perl<->python communication!
diff = int(checked.pop().split(' ')[1])
output = ' '.join(checked).translate(None, '\033')
if not new_version:
diff = 12345
else: # e.g. new package
diff = 13579
if len(checked): if len(checked):
self.review_messages['accepted'] += "\n\nOutput of check script (non-fatal):\n" + output self.review_messages['accepted'] += "\n\nOutput of check script (non-fatal):\n" + output
if not self.skip_add_reviews: if not self.skip_add_reviews:
if diff > 8: if self.review_team is not None:
if self.review_team is not None: self.add_review(self.request, by_group=self.review_team, msg='Please review sources')
self.add_review(self.request, by_group=self.review_team, msg='Please review sources')
if self.only_changes(): if self.only_changes():
self.logger.debug('only .changes modifications') self.logger.debug('only .changes modifications')

View File

@ -33,7 +33,7 @@ ln -sr ./osc-check_source.py ./osclib ~/.osc-plugins
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
The program will search also some external scripts (like The program will search also some external scripts (like
source-checker.pl) inside the cloned directory (following the symlink). check_source.pl) inside the cloned directory (following the symlink).
Command line Command line