[Piuparts-commits] [SCM] piuparts git repository branch, develop, updated. d11c275fddec946ed571ecac909d496a460d82eb
Mika Pflüger
debian at mikapflueger.de
Mon Nov 21 16:04:54 UTC 2011
The following commit has been merged in the develop branch:
commit 4295173ad46165531c2a17a812f8b3ec342b7da1
Author: Mika Pflüger <debian at mikapflueger.de>
Date: Thu Nov 17 19:50:07 2011 +0100
piuparts-analyze: Remove binNMU-parts from version numbers
The BTS only tracks source versions, so remove binNMU-part from
package versions when comparing with versions from the BTS
diff --git a/debian/changelog b/debian/changelog
index 7842e04..7313e00 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -18,8 +18,10 @@ piuparts (0.42) UNRELEASED; urgency=low
* *.py: Add vim modeline.
[ Mika Pflüger ]
- * piuparts-analyze.py: Rewrite to use python-debianbts to analyze if bugs
- are filed already.
+ * piuparts-analyze.py:
+ - Rewrite to use python-debianbts to analyze if bugs are filed already.
+ - The BTS only tracks source versions, so remove binNMU-part from
+ package versions when comparing with versions from the BTS
* debian/control: Add python-apt and python-debianbts to piuparts depends.
[ Scott Schaefer ]
diff --git a/piuparts-analyze.py b/piuparts-analyze.py
index f5a13eb..f28afb3 100644
--- a/piuparts-analyze.py
+++ b/piuparts-analyze.py
@@ -64,6 +64,16 @@ def package_version(log):
return os.path.basename(log).split("_", 1)[1].rstrip('.log')
+def package_source_version(log):
+ version = package_version(log)
+ possible_binnmu_part = version.rsplit('+',1)[-1]
+ if possible_binnmu_part.startswith('b') and possible_binnmu_part[1:].isdigit():
+ # the package version contains a binnmu-part which is not part of the source version
+ # and therefore not accepted/tracked by the bts. Remove it.
+ version = version.rsplit('+',1)[0]
+ return version
+
+
def extract_errors(log):
"""This pretty stupid implementation is basically just 'grep -i error', and then
removing the timestamps and the name of the chroot and the package version itself."""
@@ -143,7 +153,7 @@ def bts_update_found(bugnr, newversion):
def mark_logs_with_reported_bugs():
for failed_log in find_logs("fail"):
pname = package_name(failed_log)
- pversion = package_version(failed_log)
+ pversion = package_source_version(failed_log)
failed_errors = extract_errors(failed_log)
moved = False
for bug in piuparts_bugs_in(pname):
@@ -161,7 +171,7 @@ def mark_logs_with_reported_bugs():
print('%s/%s: Maybe the bug was filed earlier: %d against %s/%s'
% (pname, pversion, bug, pname, bug_version))
for bugged_log in bugged_logs:
- old_pversion = package_version(bugged_log)
+ old_pversion = package_source_version(bugged_log)
bugged_errors = extract_errors(bugged_log)
if (apt_pkg.version_compare(old_pversion, bug_version) == 0 # old_pversion == bug_version
and
--
piuparts git repository
More information about the Piuparts-commits
mailing list