Cleanup verify_overlaps*.py

Fix issues reported by pylint, Intellij Python checks and also try and
adhere to the Google Python Style Guide.

Bug: 194063708
Test: atest --host verify_overlaps_test
      m out/soong/hiddenapi/hiddenapi-flags.csv
      /usr/bin/pylint --rcfile $ANDROID_BUILD_TOP/tools/repohooks/tools/pylintrc scripts/hiddenapi/verify_overlaps*.py
      pyformat -s 4 --force_quote_type single -i scripts/hiddenapi/verify_overlaps*.py
Change-Id: I6273456abc3a4da4af780ae1a0473ca63521dff5
This commit is contained in:
Paul Duffin
2022-04-08 00:03:32 +01:00
parent 70b9a7e493
commit 181b56cf4d
2 changed files with 153 additions and 153 deletions

View File

@@ -17,24 +17,26 @@
import io
import unittest
from verify_overlaps import * #pylint: disable=unused-wildcard-import,wildcard-import
import verify_overlaps as vo
#pylint: disable=line-too-long
class TestDetectOverlaps(unittest.TestCase):
def read_flag_trie_from_string(self, csvdata):
@staticmethod
def read_flag_trie_from_string(csvdata):
with io.StringIO(csvdata) as f:
return read_flag_trie_from_stream(f)
return vo.read_flag_trie_from_stream(f)
def read_signature_csv_from_string_as_dict(self, csvdata):
@staticmethod
def read_signature_csv_from_string_as_dict(csvdata):
with io.StringIO(csvdata) as f:
return read_signature_csv_from_stream_as_dict(f)
return vo.read_signature_csv_from_stream_as_dict(f)
@staticmethod
def extract_subset_from_monolithic_flags_as_dict_from_string(
self, monolithic, patterns):
monolithic, patterns):
with io.StringIO(patterns) as f:
return extract_subset_from_monolithic_flags_as_dict_from_stream(
return vo.extract_subset_from_monolithic_flags_as_dict_from_stream(
monolithic, f)
extractInput = """
@@ -50,14 +52,14 @@ Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V,blocked
monolithic = self.read_flag_trie_from_string(
TestDetectOverlaps.extractInput)
patterns = 'Ljava/lang/Object;->hashCode()I'
patterns = "Ljava/lang/Object;->hashCode()I"
subset = self.extract_subset_from_monolithic_flags_as_dict_from_string(
monolithic, patterns)
expected = {
'Ljava/lang/Object;->hashCode()I': {
None: ['public-api', 'system-api', 'test-api'],
'signature': 'Ljava/lang/Object;->hashCode()I',
"Ljava/lang/Object;->hashCode()I": {
None: ["public-api", "system-api", "test-api"],
"signature": "Ljava/lang/Object;->hashCode()I",
},
}
self.assertEqual(expected, subset)
@@ -66,18 +68,18 @@ Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V,blocked
monolithic = self.read_flag_trie_from_string(
TestDetectOverlaps.extractInput)
patterns = 'java/lang/Object'
patterns = "java/lang/Object"
subset = self.extract_subset_from_monolithic_flags_as_dict_from_string(
monolithic, patterns)
expected = {
'Ljava/lang/Object;->hashCode()I': {
None: ['public-api', 'system-api', 'test-api'],
'signature': 'Ljava/lang/Object;->hashCode()I',
"Ljava/lang/Object;->hashCode()I": {
None: ["public-api", "system-api", "test-api"],
"signature": "Ljava/lang/Object;->hashCode()I",
},
'Ljava/lang/Object;->toString()Ljava/lang/String;': {
None: ['blocked'],
'signature': 'Ljava/lang/Object;->toString()Ljava/lang/String;',
"Ljava/lang/Object;->toString()Ljava/lang/String;": {
None: ["blocked"],
"signature": "Ljava/lang/Object;->toString()Ljava/lang/String;",
},
}
self.assertEqual(expected, subset)
@@ -86,20 +88,20 @@ Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V,blocked
monolithic = self.read_flag_trie_from_string(
TestDetectOverlaps.extractInput)
patterns = 'java/lang/Character'
patterns = "java/lang/Character"
subset = self.extract_subset_from_monolithic_flags_as_dict_from_string(
monolithic, patterns)
expected = {
'Ljava/lang/Character$UnicodeScript;->of(I)Ljava/lang/Character$UnicodeScript;':
{
None: ['blocked'],
'signature':
'Ljava/lang/Character$UnicodeScript;->of(I)Ljava/lang/Character$UnicodeScript;',
},
'Ljava/lang/Character;->serialVersionUID:J': {
None: ['sdk'],
'signature': 'Ljava/lang/Character;->serialVersionUID:J',
"Ljava/lang/Character$UnicodeScript;"
"->of(I)Ljava/lang/Character$UnicodeScript;": {
None: ["blocked"],
"signature": "Ljava/lang/Character$UnicodeScript;"
"->of(I)Ljava/lang/Character$UnicodeScript;",
},
"Ljava/lang/Character;->serialVersionUID:J": {
None: ["sdk"],
"signature": "Ljava/lang/Character;->serialVersionUID:J",
},
}
self.assertEqual(expected, subset)
@@ -108,17 +110,17 @@ Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V,blocked
monolithic = self.read_flag_trie_from_string(
TestDetectOverlaps.extractInput)
patterns = 'java/lang/Character$UnicodeScript'
patterns = "java/lang/Character$UnicodeScript"
subset = self.extract_subset_from_monolithic_flags_as_dict_from_string(
monolithic, patterns)
expected = {
'Ljava/lang/Character$UnicodeScript;->of(I)Ljava/lang/Character$UnicodeScript;':
{
None: ['blocked'],
'signature':
'Ljava/lang/Character$UnicodeScript;->of(I)Ljava/lang/Character$UnicodeScript;',
},
"Ljava/lang/Character$UnicodeScript;"
"->of(I)Ljava/lang/Character$UnicodeScript;": {
None: ["blocked"],
"signature": "Ljava/lang/Character$UnicodeScript;"
"->of(I)Ljava/lang/Character$UnicodeScript;",
},
}
self.assertEqual(expected, subset)
@@ -126,32 +128,32 @@ Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V,blocked
monolithic = self.read_flag_trie_from_string(
TestDetectOverlaps.extractInput)
patterns = 'java/lang/*'
patterns = "java/lang/*"
subset = self.extract_subset_from_monolithic_flags_as_dict_from_string(
monolithic, patterns)
expected = {
'Ljava/lang/Character$UnicodeScript;->of(I)Ljava/lang/Character$UnicodeScript;':
{
None: ['blocked'],
'signature':
'Ljava/lang/Character$UnicodeScript;->of(I)Ljava/lang/Character$UnicodeScript;',
},
'Ljava/lang/Character;->serialVersionUID:J': {
None: ['sdk'],
'signature': 'Ljava/lang/Character;->serialVersionUID:J',
"Ljava/lang/Character$UnicodeScript;"
"->of(I)Ljava/lang/Character$UnicodeScript;": {
None: ["blocked"],
"signature": "Ljava/lang/Character$UnicodeScript;"
"->of(I)Ljava/lang/Character$UnicodeScript;",
},
'Ljava/lang/Object;->hashCode()I': {
None: ['public-api', 'system-api', 'test-api'],
'signature': 'Ljava/lang/Object;->hashCode()I',
"Ljava/lang/Character;->serialVersionUID:J": {
None: ["sdk"],
"signature": "Ljava/lang/Character;->serialVersionUID:J",
},
'Ljava/lang/Object;->toString()Ljava/lang/String;': {
None: ['blocked'],
'signature': 'Ljava/lang/Object;->toString()Ljava/lang/String;',
"Ljava/lang/Object;->hashCode()I": {
None: ["public-api", "system-api", "test-api"],
"signature": "Ljava/lang/Object;->hashCode()I",
},
'Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V': {
None: ['blocked'],
'signature': 'Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V',
"Ljava/lang/Object;->toString()Ljava/lang/String;": {
None: ["blocked"],
"signature": "Ljava/lang/Object;->toString()Ljava/lang/String;",
},
"Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V": {
None: ["blocked"],
"signature": "Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V",
},
}
self.assertEqual(expected, subset)
@@ -160,36 +162,36 @@ Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V,blocked
monolithic = self.read_flag_trie_from_string(
TestDetectOverlaps.extractInput)
patterns = 'java/**'
patterns = "java/**"
subset = self.extract_subset_from_monolithic_flags_as_dict_from_string(
monolithic, patterns)
expected = {
'Ljava/lang/Character$UnicodeScript;->of(I)Ljava/lang/Character$UnicodeScript;':
{
None: ['blocked'],
'signature':
'Ljava/lang/Character$UnicodeScript;->of(I)Ljava/lang/Character$UnicodeScript;',
},
'Ljava/lang/Character;->serialVersionUID:J': {
None: ['sdk'],
'signature': 'Ljava/lang/Character;->serialVersionUID:J',
"Ljava/lang/Character$UnicodeScript;"
"->of(I)Ljava/lang/Character$UnicodeScript;": {
None: ["blocked"],
"signature": "Ljava/lang/Character$UnicodeScript;"
"->of(I)Ljava/lang/Character$UnicodeScript;",
},
'Ljava/lang/Object;->hashCode()I': {
None: ['public-api', 'system-api', 'test-api'],
'signature': 'Ljava/lang/Object;->hashCode()I',
"Ljava/lang/Character;->serialVersionUID:J": {
None: ["sdk"],
"signature": "Ljava/lang/Character;->serialVersionUID:J",
},
'Ljava/lang/Object;->toString()Ljava/lang/String;': {
None: ['blocked'],
'signature': 'Ljava/lang/Object;->toString()Ljava/lang/String;',
"Ljava/lang/Object;->hashCode()I": {
None: ["public-api", "system-api", "test-api"],
"signature": "Ljava/lang/Object;->hashCode()I",
},
'Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V': {
None: ['blocked'],
'signature': 'Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V',
"Ljava/lang/Object;->toString()Ljava/lang/String;": {
None: ["blocked"],
"signature": "Ljava/lang/Object;->toString()Ljava/lang/String;",
},
'Ljava/util/zip/ZipFile;-><clinit>()V': {
None: ['blocked'],
'signature': 'Ljava/util/zip/ZipFile;-><clinit>()V',
"Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V": {
None: ["blocked"],
"signature": "Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V",
},
"Ljava/util/zip/ZipFile;-><clinit>()V": {
None: ["blocked"],
"signature": "Ljava/util/zip/ZipFile;-><clinit>()V",
},
}
self.assertEqual(expected, subset)
@@ -200,7 +202,7 @@ Ljava/lang/ProcessBuilder$Redirect$1;-><init>()V,blocked
Ljava/lang/Object;->hashCode()I,public-api,system-api,test-api
Ljava/lang/Object;->hashCode()I,blocked
""")
self.assertTrue('Duplicate signature: Ljava/lang/Object;->hashCode()I'
self.assertTrue("Duplicate signature: Ljava/lang/Object;->hashCode()I"
in str(context.exception))
def test_read_trie_missing_member(self):
@@ -209,8 +211,8 @@ Ljava/lang/Object;->hashCode()I,blocked
Ljava/lang/Object,public-api,system-api,test-api
""")
self.assertTrue(
'Invalid signature: Ljava/lang/Object, does not identify a specific member'
in str(context.exception))
"Invalid signature: Ljava/lang/Object, "
"does not identify a specific member" in str(context.exception))
def test_match(self):
monolithic = self.read_signature_csv_from_string_as_dict("""
@@ -219,7 +221,7 @@ Ljava/lang/Object;->hashCode()I,public-api,system-api,test-api
modular = self.read_signature_csv_from_string_as_dict("""
Ljava/lang/Object;->hashCode()I,public-api,system-api,test-api
""")
mismatches = compare_signature_flags(monolithic, modular)
mismatches = vo.compare_signature_flags(monolithic, modular)
expected = []
self.assertEqual(expected, mismatches)
@@ -230,12 +232,12 @@ Ljava/lang/Object;->toString()Ljava/lang/String;,public-api
modular = self.read_signature_csv_from_string_as_dict("""
Ljava/lang/Object;->toString()Ljava/lang/String;,public-api,system-api,test-api
""")
mismatches = compare_signature_flags(monolithic, modular)
mismatches = vo.compare_signature_flags(monolithic, modular)
expected = [
(
'Ljava/lang/Object;->toString()Ljava/lang/String;',
['public-api', 'system-api', 'test-api'],
['public-api'],
"Ljava/lang/Object;->toString()Ljava/lang/String;",
["public-api", "system-api", "test-api"],
["public-api"],
),
]
self.assertEqual(expected, mismatches)
@@ -247,12 +249,12 @@ Ljava/lang/Object;->toString()Ljava/lang/String;,blocked
modular = self.read_signature_csv_from_string_as_dict("""
Ljava/lang/Object;->toString()Ljava/lang/String;,public-api,system-api,test-api
""")
mismatches = compare_signature_flags(monolithic, modular)
mismatches = vo.compare_signature_flags(monolithic, modular)
expected = [
(
'Ljava/lang/Object;->toString()Ljava/lang/String;',
['public-api', 'system-api', 'test-api'],
['blocked'],
"Ljava/lang/Object;->toString()Ljava/lang/String;",
["public-api", "system-api", "test-api"],
["blocked"],
),
]
self.assertEqual(expected, mismatches)
@@ -264,26 +266,26 @@ Ljava/lang/Object;->toString()Ljava/lang/String;,public-api,system-api,test-api
modular = self.read_signature_csv_from_string_as_dict("""
Ljava/lang/Object;->toString()Ljava/lang/String;,blocked
""")
mismatches = compare_signature_flags(monolithic, modular)
mismatches = vo.compare_signature_flags(monolithic, modular)
expected = [
(
'Ljava/lang/Object;->toString()Ljava/lang/String;',
['blocked'],
['public-api', 'system-api', 'test-api'],
"Ljava/lang/Object;->toString()Ljava/lang/String;",
["blocked"],
["public-api", "system-api", "test-api"],
),
]
self.assertEqual(expected, mismatches)
def test_match_treat_missing_from_modular_as_blocked(self):
monolithic = self.read_signature_csv_from_string_as_dict('')
monolithic = self.read_signature_csv_from_string_as_dict("")
modular = self.read_signature_csv_from_string_as_dict("""
Ljava/lang/Object;->toString()Ljava/lang/String;,public-api,system-api,test-api
""")
mismatches = compare_signature_flags(monolithic, modular)
mismatches = vo.compare_signature_flags(monolithic, modular)
expected = [
(
'Ljava/lang/Object;->toString()Ljava/lang/String;',
['public-api', 'system-api', 'test-api'],
"Ljava/lang/Object;->toString()Ljava/lang/String;",
["public-api", "system-api", "test-api"],
[],
),
]
@@ -294,12 +296,12 @@ Ljava/lang/Object;->toString()Ljava/lang/String;,public-api,system-api,test-api
Ljava/lang/Object;->hashCode()I,public-api,system-api,test-api
""")
modular = {}
mismatches = compare_signature_flags(monolithic, modular)
mismatches = vo.compare_signature_flags(monolithic, modular)
expected = [
(
'Ljava/lang/Object;->hashCode()I',
['blocked'],
['public-api', 'system-api', 'test-api'],
"Ljava/lang/Object;->hashCode()I",
["blocked"],
["public-api", "system-api", "test-api"],
),
]
self.assertEqual(expected, mismatches)
@@ -309,12 +311,10 @@ Ljava/lang/Object;->hashCode()I,public-api,system-api,test-api
Ljava/lang/Object;->hashCode()I,blocked
""")
modular = {}
mismatches = compare_signature_flags(monolithic, modular)
mismatches = vo.compare_signature_flags(monolithic, modular)
expected = []
self.assertEqual(expected, mismatches)
#pylint: enable=line-too-long
if __name__ == '__main__':
if __name__ == "__main__":
unittest.main(verbosity=2)