chiark / gitweb /
update: do not crash with androguard when working with apps without icons
authorHans-Christoph Steiner <hans@eds.org>
Sun, 11 Mar 2018 21:09:09 +0000 (22:09 +0100)
committerHans-Christoph Steiner <hans@eds.org>
Mon, 12 Mar 2018 16:55:45 +0000 (17:55 +0100)
For example, SpeedoMeterApp.main_1.apk

fdroidserver/update.py
tests/SpeedoMeterApp.main_1.apk [new file with mode: 0644]
tests/update.TestCase

index c22ac0f32b70d6add7f64a2367a24ef0e6091761..168ef31f4195310cc8ce8d7a5ee7b8f937e44207 100644 (file)
@@ -1223,9 +1223,11 @@ def scan_apk_androguard(apk, apkfile):
     if apkobject.get_target_sdk_version() is not None:
         apk['targetSdkVersion'] = apkobject.get_target_sdk_version()
 
-    icon_id = int(apkobject.get_element("application", "icon").replace("@", "0x"), 16)
-    icon_name = arsc.get_id(apk['packageName'], icon_id)[1]
-    apk['icons_src'] = _get_apk_icons_src(apkfile, icon_name)
+    icon_id_str = apkobject.get_element("application", "icon")
+    if icon_id_str:
+        icon_id = int(icon_id_str.replace("@", "0x"), 16)
+        icon_name = arsc.get_id(apk['packageName'], icon_id)[1]
+        apk['icons_src'] = _get_apk_icons_src(apkfile, icon_name)
 
     arch_re = re.compile("^lib/(.*)/.*$")
     arch = set([arch_re.match(file).group(1) for file in apkobject.get_files() if arch_re.match(file)])
diff --git a/tests/SpeedoMeterApp.main_1.apk b/tests/SpeedoMeterApp.main_1.apk
new file mode 100644 (file)
index 0000000..2ce7b36
Binary files /dev/null and b/tests/SpeedoMeterApp.main_1.apk differ
index 2e9b687ba170c8681e071c9fb027fb99f53d41d7..03391c181369ed50f3f132aba104ed957e1a4471 100755 (executable)
@@ -333,6 +333,9 @@ class UpdateTest(unittest.TestCase):
                                                  '320': 'res/drawable-xhdpi-v4/icon.png',
                                                  '-1': 'res/drawable-mdpi-v4/icon.png'})
 
+        apk_info = fdroidserver.update.scan_apk('SpeedoMeterApp.main_1.apk')
+        self.assertEqual(apk_info['icons_src'], {})
+
     def test_scan_apk_no_sig(self):
         config = dict()
         fdroidserver.common.fill_config_defaults(config)