mirror of
https://github.com/f-droid/fdroidserver.git
synced 2025-09-13 14:32:28 +03:00
Compare commits
4 commits
19d709edcd
...
b19b8050db
Author | SHA1 | Date | |
---|---|---|---|
![]() |
b19b8050db | ||
![]() |
6a3758d3c4 | ||
![]() |
546821fc3d | ||
![]() |
120a1655b4 |
4 changed files with 69 additions and 12 deletions
|
@ -2733,17 +2733,17 @@ def getpaths_map(build_dir, globpaths):
|
||||||
paths[p] = [r[len(str(build_dir)) + 1:] for r in glob.glob(full_path)]
|
paths[p] = [r[len(str(build_dir)) + 1:] for r in glob.glob(full_path)]
|
||||||
if not paths[p]:
|
if not paths[p]:
|
||||||
not_found_paths.append(p)
|
not_found_paths.append(p)
|
||||||
|
return paths, not_found_paths
|
||||||
|
|
||||||
|
|
||||||
|
def getpaths(build_dir, globpaths):
|
||||||
|
"""Extend via globbing the paths from a field and return them as a set."""
|
||||||
|
paths_map, not_found_paths = getpaths_map(build_dir, globpaths)
|
||||||
if not_found_paths:
|
if not_found_paths:
|
||||||
raise FDroidException(
|
raise FDroidException(
|
||||||
"Some glob paths did not match any files/dirs:\n"
|
"Some glob paths did not match any files/dirs:\n"
|
||||||
+ "\n".join(not_found_paths)
|
+ "\n".join(not_found_paths)
|
||||||
)
|
)
|
||||||
return paths
|
|
||||||
|
|
||||||
|
|
||||||
def getpaths(build_dir, globpaths):
|
|
||||||
"""Extend via globbing the paths from a field and return them as a set."""
|
|
||||||
paths_map = getpaths_map(build_dir, globpaths)
|
|
||||||
paths = set()
|
paths = set()
|
||||||
for k, v in paths_map.items():
|
for k, v in paths_map.items():
|
||||||
for p in v:
|
for p in v:
|
||||||
|
|
|
@ -750,8 +750,12 @@ def scan_source(build_dir, build=metadata.Build(), json_per_build=None):
|
||||||
]
|
]
|
||||||
]
|
]
|
||||||
|
|
||||||
scanignore = common.getpaths_map(build_dir, build.scanignore)
|
scanignore, scanignore_not_found_paths = common.getpaths_map(
|
||||||
scandelete = common.getpaths_map(build_dir, build.scandelete)
|
build_dir, build.scanignore
|
||||||
|
)
|
||||||
|
scandelete, scandelete_not_found_paths = common.getpaths_map(
|
||||||
|
build_dir, build.scandelete
|
||||||
|
)
|
||||||
|
|
||||||
scanignore_worked = set()
|
scanignore_worked = set()
|
||||||
scandelete_worked = set()
|
scandelete_worked = set()
|
||||||
|
@ -1109,11 +1113,19 @@ def scan_source(build_dir, build=metadata.Build(), json_per_build=None):
|
||||||
json_per_build,
|
json_per_build,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
for p in scanignore_not_found_paths:
|
||||||
|
logging.error(_("Non-exist scanignore path: %s") % p)
|
||||||
|
count += 1
|
||||||
|
|
||||||
for p in scanignore:
|
for p in scanignore:
|
||||||
if p not in scanignore_worked:
|
if p not in scanignore_worked:
|
||||||
logging.error(_('Unused scanignore path: %s') % p)
|
logging.error(_('Unused scanignore path: %s') % p)
|
||||||
count += 1
|
count += 1
|
||||||
|
|
||||||
|
for p in scandelete_not_found_paths:
|
||||||
|
logging.error(_("Non-exist scandelete path: %s") % p)
|
||||||
|
count += 1
|
||||||
|
|
||||||
for p in scandelete:
|
for p in scandelete:
|
||||||
if p not in scandelete_worked:
|
if p not in scandelete_worked:
|
||||||
logging.error(_('Unused scandelete path: %s') % p)
|
logging.error(_('Unused scandelete path: %s') % p)
|
||||||
|
|
|
@ -1148,6 +1148,7 @@ def insert_localized_app_metadata(apps):
|
||||||
|
|
||||||
metadata/<locale>/
|
metadata/<locale>/
|
||||||
fastlane/metadata/android/<locale>/
|
fastlane/metadata/android/<locale>/
|
||||||
|
<subdir>/fastlane/metadata/android/<locale>/
|
||||||
src/<buildFlavor>/fastlane/metadata/android/<locale>/
|
src/<buildFlavor>/fastlane/metadata/android/<locale>/
|
||||||
|
|
||||||
...as well as the /metadata/<packageName>/<locale> directory.
|
...as well as the /metadata/<packageName>/<locale> directory.
|
||||||
|
@ -1186,7 +1187,7 @@ def insert_localized_app_metadata(apps):
|
||||||
builds = apps.get(packageName, {}).get('Builds', [])
|
builds = apps.get(packageName, {}).get('Builds', [])
|
||||||
found_in_subdir = (
|
found_in_subdir = (
|
||||||
builds
|
builds
|
||||||
and len(segments) > 7
|
and len(segments) > 6
|
||||||
and segments[-4] == "fastlane"
|
and segments[-4] == "fastlane"
|
||||||
and segments[-3] == "metadata"
|
and segments[-3] == "metadata"
|
||||||
and segments[-2] == "android"
|
and segments[-2] == "android"
|
||||||
|
@ -1199,12 +1200,18 @@ def insert_localized_app_metadata(apps):
|
||||||
build_flavors = common.calculate_gradle_flavor_combination(
|
build_flavors = common.calculate_gradle_flavor_combination(
|
||||||
builds[-1]['gradle']
|
builds[-1]['gradle']
|
||||||
)
|
)
|
||||||
|
found_in_flavor = (
|
||||||
|
len(segments) > 7
|
||||||
|
and segments[2] == 'src'
|
||||||
|
and segments[4] == "fastlane"
|
||||||
|
and segments[3] in build_flavors
|
||||||
|
)
|
||||||
|
|
||||||
if (
|
if (
|
||||||
not found_in_subdir
|
not found_in_subdir
|
||||||
and len(segments) >= 5
|
and not found_in_flavor
|
||||||
and segments[4] == "fastlane"
|
and segments[0] == 'build'
|
||||||
and segments[3] not in build_flavors
|
and segments[2] not in ('metadata', 'fastlane')
|
||||||
):
|
):
|
||||||
logging.debug(
|
logging.debug(
|
||||||
'Not scanning "{dir}" with unknown subdir or gradle flavor "{value}"'.format(
|
'Not scanning "{dir}" with unknown subdir or gradle flavor "{value}"'.format(
|
||||||
|
|
|
@ -286,6 +286,44 @@ class UpdateTest(unittest.TestCase):
|
||||||
fdroidserver.update.insert_localized_app_metadata(apps)
|
fdroidserver.update.insert_localized_app_metadata(apps)
|
||||||
self.assertEqual(second_value, apps[app.id]['localized']['en-US']['name'])
|
self.assertEqual(second_value, apps[app.id]['localized']['en-US']['name'])
|
||||||
|
|
||||||
|
def test_fastlane_with_schildichat(self):
|
||||||
|
"""Test if fastlane is found in this tangle of dirs and symlinks.
|
||||||
|
|
||||||
|
https://github.com/SchildiChat/schildichat-android-next/tree/sc_v0.10.3-ex_25_6_2
|
||||||
|
"""
|
||||||
|
os.chdir(self.testdir)
|
||||||
|
config = dict()
|
||||||
|
fdroidserver.common.fill_config_defaults(config)
|
||||||
|
fdroidserver.update.config = config
|
||||||
|
|
||||||
|
app = fdroidserver.metadata.App()
|
||||||
|
app.id = 'chat.schildi.android'
|
||||||
|
build_dir = f'build/{app.id}'
|
||||||
|
flavors = ['fdroid', 'sc', 'default']
|
||||||
|
subdir = 'app'
|
||||||
|
apps = {app.id: app}
|
||||||
|
build = fdroidserver.metadata.Build()
|
||||||
|
build.versionCode = 42
|
||||||
|
build.gradle = flavors
|
||||||
|
build.subdir = subdir
|
||||||
|
app['Builds'] = [build]
|
||||||
|
|
||||||
|
wrong_value = 'wrong'
|
||||||
|
wrong_dir = Path(f'{build_dir}/upstream_infra/fastlane/metadata/android/en-US')
|
||||||
|
wrong_dir.mkdir(parents=True)
|
||||||
|
(wrong_dir / 'title.txt').write_text(wrong_value)
|
||||||
|
|
||||||
|
right_value = 'right'
|
||||||
|
right_dir = Path(f'{build_dir}/metadata/en-US')
|
||||||
|
right_dir.mkdir(parents=True)
|
||||||
|
(right_dir / 'title.txt').write_text(right_value)
|
||||||
|
_fastlane = Path('.fastlane/metadata')
|
||||||
|
_fastlane.mkdir(parents=True)
|
||||||
|
os.symlink('../../metadata', _fastlane / 'android')
|
||||||
|
os.symlink('.fastlane', 'fastlane')
|
||||||
|
fdroidserver.update.insert_localized_app_metadata(apps)
|
||||||
|
self.assertEqual(right_value, apps[app.id]['localized']['en-US']['name'])
|
||||||
|
|
||||||
def test_fastlane_with_multi_level_subdir(self):
|
def test_fastlane_with_multi_level_subdir(self):
|
||||||
"""Test if fastlane in multi-level subdir is found."""
|
"""Test if fastlane in multi-level subdir is found."""
|
||||||
os.chdir(self.testdir)
|
os.chdir(self.testdir)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue