Merge branch 'subdir-fastlane-support' into 'master'

update: support fastlane/ dir in subdir:

See merge request fdroid/fdroidserver!1679
This commit is contained in:
Hans-Christoph Steiner 2025-07-17 08:46:27 +00:00
commit 6ad3c74bb4
2 changed files with 94 additions and 13 deletions

View file

@ -1167,7 +1167,7 @@ def insert_localized_app_metadata(apps):
https://f-droid.org/en/docs/All_About_Descriptions_Graphics_and_Screenshots/#in-the-apps-build-metadata-in-an-fdroiddata-collection
"""
sourcedirs = glob.glob(os.path.join('build', '[A-Za-z]*', 'src', '[A-Za-z]*', 'fastlane', 'metadata', 'android', '[a-z][a-z]*'))
sourcedirs += glob.glob(os.path.join('build', '[A-Za-z]*', 'fastlane', 'metadata', 'android', '[a-z][a-z]*'))
sourcedirs += glob.glob(os.path.join('build', '[A-Za-z]*', '**', 'fastlane', 'metadata', 'android', '[a-z][a-z]*'), recursive=True)
sourcedirs += glob.glob(os.path.join('build', '[A-Za-z]*', 'metadata', '[a-z][a-z]*'))
sourcedirs += glob.glob(os.path.join('metadata', '[A-Za-z]*', '[a-z][a-z]*'))
@ -1183,20 +1183,34 @@ def insert_localized_app_metadata(apps):
locale = segments[-1]
destdir = os.path.join('repo', packageName, locale)
# flavors specified in build receipt
build_flavors = []
if (
apps[packageName]
and len(apps[packageName].get('Builds', [])) > 0
and 'gradle' in apps[packageName]['Builds'][-1]
and apps[packageName]['Builds'][-1]['gradle'] != ['yes']
):
build_flavors = common.calculate_gradle_flavor_combination(
apps[packageName]['Builds'][-1]['gradle']
builds = apps.get(packageName, {}).get('Builds', [])
found_in_subdir = (
builds
and len(segments) > 7
and segments[-4] == "fastlane"
and segments[-3] == "metadata"
and segments[-2] == "android"
and '/'.join(segments[2:-4]) == builds[-1].get('subdir')
)
if len(segments) >= 5 and segments[4] == "fastlane" and segments[3] not in build_flavors:
logging.debug("ignoring due to wrong flavor")
# flavors specified in build receipt
build_flavors = []
if builds and 'gradle' in builds[-1] and builds[-1]['gradle'] != ['yes']:
build_flavors = common.calculate_gradle_flavor_combination(
builds[-1]['gradle']
)
if (
not found_in_subdir
and len(segments) >= 5
and segments[4] == "fastlane"
and segments[3] not in build_flavors
):
logging.debug(
'Not scanning "{dir}" with unknown subdir or gradle flavor "{value}"'.format(
dir=os.path.relpath(root), value=segments[3]
)
)
continue
for f in files:
@ -1234,9 +1248,7 @@ def insert_localized_app_metadata(apps):
try:
versionCode = int(base)
locale = segments[-2]
if versionCode in [
a["versionCode"] for a in apps[packageName]["Builds"]
]:
if versionCode in [b["versionCode"] for b in builds]:
_set_localized_text_entry(
apps[packageName],
locale,

View file

@ -253,6 +253,75 @@ class UpdateTest(unittest.TestCase):
fdroidserver.update.insert_localized_app_metadata(apps)
self.assertEqual('42', apps[app.id]['localized']['en-US']['whatsNew'])
def test_fastlane_with_subdir(self):
"""Test if fastlane in simple one-level subdir is found."""
os.chdir(self.testdir)
config = dict()
fdroidserver.common.fill_config_defaults(config)
fdroidserver.update.config = config
app = fdroidserver.metadata.App()
app.id = 'com.example.app'
build_dir = f'build/{app.id}'
flavor = 'flavor'
subdir = 'subproject'
apps = {app.id: app}
build = fdroidserver.metadata.Build()
build.versionCode = 42
build.gradle = [flavor]
build.subdir = subdir
app['Builds'] = [build]
first_value = 'first'
first_dir = Path(f'{build_dir}/src/{flavor}/fastlane/metadata/android/en-US')
first_dir.mkdir(parents=True)
(first_dir / 'title.txt').write_text(first_value)
fdroidserver.update.insert_localized_app_metadata(apps)
self.assertEqual(first_value, apps[app.id]['localized']['en-US']['name'])
second_value = 'second'
second_dir = Path(f'{build_dir}/{subdir}/fastlane/metadata/android/en-US')
second_dir.mkdir(parents=True)
(second_dir / 'title.txt').write_text(second_value)
fdroidserver.update.insert_localized_app_metadata(apps)
self.assertEqual(second_value, apps[app.id]['localized']['en-US']['name'])
def test_fastlane_with_multi_level_subdir(self):
"""Test if fastlane in multi-level subdir is found."""
os.chdir(self.testdir)
config = dict()
fdroidserver.common.fill_config_defaults(config)
fdroidserver.update.config = config
app = fdroidserver.metadata.App()
app.id = 'org.videolan.vlc'
build_dir = f'build/{app.id}'
subdir = 'application/app'
apps = {app.id: app}
build = fdroidserver.metadata.Build()
build.versionCode = 42
build.gradle = ['yes']
build.subdir = subdir
app['Builds'] = [build]
first_value = 'first'
first_dir = Path(f'{build_dir}/{subdir}/fastlane/metadata/android/en-US')
first_dir.mkdir(parents=True)
(first_dir / 'title.txt').write_text(first_value)
fdroidserver.update.insert_localized_app_metadata(apps)
self.assertEqual(first_value, apps[app.id]['localized']['en-US']['name'])
# I'm not sure that it is correct behavior for this path to
# override the above path, but it is how it is working now. It
# seems to me it should be the other way around, but that is
# really hard to implement using the current algorithm.
second_value = 'second'
second_dir = Path(f'{build_dir}/fastlane/metadata/android/en-US')
second_dir.mkdir(parents=True)
(second_dir / 'title.txt').write_text(second_value)
fdroidserver.update.insert_localized_app_metadata(apps)
self.assertEqual(second_value, apps[app.id]['localized']['en-US']['name'])
def test_name_title_scraping(self):
"""metadata file --> fdroiddata localized files --> fastlane/triple-t in app source --> APK"""
shutil.copytree(basedir, self.testdir, dirs_exist_ok=True)