Fix KernelVersion comparisons

In the __lt__ function for the class KernelVersions, if
self.groups != other.groups, but self.groups == other.groups[0:n] or
self.groups[0:n] == other.groups for some n, then at some point, one of
the two pieces to be compared will be None, which resulted in an
Exception when calling isdigit.

Hence check whether one of the pieces to be compared is None and handle
this as a special case.

(cherry picked from commit b901203390b4994a8169021d7dc47928561dad24)
This commit is contained in:
Malte Leip 2019-11-01 21:27:14 +01:00 committed by Marek Marczykowski-Górecki
parent fe56b3e0e7
commit 5ba012b7d3
No known key found for this signature in database
GPG Key ID: 063938BA42CFA724

View File

@ -134,6 +134,10 @@ class KernelVersion: # pylint: disable=too-few-public-methods
self.groups, other.groups): self.groups, other.groups):
if self_content == other_content: if self_content == other_content:
continue continue
if self_content is None:
return True
if other_content is None:
return False
if self_content.isdigit() and other_content.isdigit(): if self_content.isdigit() and other_content.isdigit():
return int(self_content) < int(other_content) return int(self_content) < int(other_content)
return self_content < other_content return self_content < other_content