mirror of
https://gitlab.com/fdroid/fdroidserver.git
synced 2024-11-19 21:30:10 +01:00
Merge branch 'write-yaml-overhaul' into 'master'
use pyyaml for writing metadata instead of ruamel Closes #611 See merge request fdroid/fdroidserver!630
This commit is contained in:
commit
d45431aa9e
@ -103,7 +103,6 @@ packages="
|
|||||||
python3-setuptools
|
python3-setuptools
|
||||||
python3-smmap
|
python3-smmap
|
||||||
python3-yaml
|
python3-yaml
|
||||||
python3-ruamel.yaml
|
|
||||||
quilt
|
quilt
|
||||||
rsync
|
rsync
|
||||||
scons
|
scons
|
||||||
|
@ -248,6 +248,13 @@ def fieldtype(name):
|
|||||||
return TYPE_STRING
|
return TYPE_STRING
|
||||||
|
|
||||||
|
|
||||||
|
def yml_fieldtype(name):
|
||||||
|
if name == 'CurrentVersionCode':
|
||||||
|
return TYPE_INT
|
||||||
|
else:
|
||||||
|
return fieldtype(name)
|
||||||
|
|
||||||
|
|
||||||
# In the order in which they are laid out on files
|
# In the order in which they are laid out on files
|
||||||
build_flags_order = [
|
build_flags_order = [
|
||||||
'disable',
|
'disable',
|
||||||
@ -1108,6 +1115,88 @@ def post_parse_yaml_metadata(yamldata):
|
|||||||
build[flag] = ' && '.join(build[flag])
|
build[flag] = ' && '.join(build[flag])
|
||||||
|
|
||||||
|
|
||||||
|
def _format_yml_field(field, value, typ, width=80, offset=0):
|
||||||
|
|
||||||
|
bool_list_hack = ['gradle']
|
||||||
|
|
||||||
|
data = {}
|
||||||
|
default_style = None
|
||||||
|
|
||||||
|
if typ == TYPE_INT:
|
||||||
|
data[field] = int(value)
|
||||||
|
elif typ == TYPE_BOOL:
|
||||||
|
data[field] = bool(value)
|
||||||
|
elif typ == TYPE_SCRIPT:
|
||||||
|
if type(value) != list:
|
||||||
|
value = value.split(' && ')
|
||||||
|
if len(value) > 1:
|
||||||
|
data[field] = value
|
||||||
|
else:
|
||||||
|
data[field] = value[0]
|
||||||
|
elif typ == TYPE_LIST:
|
||||||
|
if field in bool_list_hack:
|
||||||
|
if value in [True, 'yes', ['yes']]:
|
||||||
|
value = [True]
|
||||||
|
data[field] = value
|
||||||
|
elif typ == TYPE_MULTILINE:
|
||||||
|
default_style = '|'
|
||||||
|
data[field] = value.strip()
|
||||||
|
else:
|
||||||
|
data[field] = value
|
||||||
|
|
||||||
|
raw_yml = yaml.dump(data, Dumper=yaml.SafeDumper,
|
||||||
|
default_flow_style=False, width=width,
|
||||||
|
default_style=default_style, indent=4)
|
||||||
|
|
||||||
|
# this is just for debugging purposes remove in production code
|
||||||
|
# debug_print_yaml_item(typ, data, default_style, offset, raw_yml)
|
||||||
|
|
||||||
|
if raw_yml:
|
||||||
|
|
||||||
|
# remove all encapsulation newlines
|
||||||
|
raw_yml = re.sub('\n+$', '', raw_yml)
|
||||||
|
raw_yml = re.sub('^\n+', '', raw_yml)
|
||||||
|
|
||||||
|
if offset > 0:
|
||||||
|
lines = raw_yml.split('\n')
|
||||||
|
for i in range(len(lines)):
|
||||||
|
if lines[i] != '':
|
||||||
|
lines[i] = ' ' * offset + lines[i]
|
||||||
|
raw_yml = '\n'.join(lines)
|
||||||
|
|
||||||
|
if typ == TYPE_LIST or typ == TYPE_SCRIPT:
|
||||||
|
# indent sequence items by 2 spaces
|
||||||
|
new_raw_yml = []
|
||||||
|
for line in raw_yml.split('\n'):
|
||||||
|
if re.match(r'^\s*$', line):
|
||||||
|
new_raw_yml.append('')
|
||||||
|
elif len(new_raw_yml) > 0:
|
||||||
|
new_raw_yml.append(' ' + line)
|
||||||
|
else:
|
||||||
|
new_raw_yml.append(line)
|
||||||
|
raw_yml = '\n'.join(new_raw_yml)
|
||||||
|
elif typ == TYPE_MULTILINE:
|
||||||
|
# remove quotes from mulit line keys
|
||||||
|
raw_yml = re.sub(r'^(\s*)"([a-zA-Z0-9]+)":(\s*\|-)$', '\\1\\2:\\3', raw_yml, flags=re.MULTILINE)
|
||||||
|
|
||||||
|
return raw_yml
|
||||||
|
|
||||||
|
|
||||||
|
def _format_yml_build_entry(build):
|
||||||
|
result = []
|
||||||
|
for field in build_flags:
|
||||||
|
value = getattr(build, field, None)
|
||||||
|
if value:
|
||||||
|
typ = flagtype(field)
|
||||||
|
line = _format_yml_field(field, value, typ, width=0xffffffff, offset=4)
|
||||||
|
if re.match(r'^\s+$', line):
|
||||||
|
result.append('')
|
||||||
|
else:
|
||||||
|
result.append(line)
|
||||||
|
result[0] = ' - ' + result[0][4:]
|
||||||
|
return '\n'.join(result)
|
||||||
|
|
||||||
|
|
||||||
def write_yaml(mf, app):
|
def write_yaml(mf, app):
|
||||||
"""Write metadata in yaml format.
|
"""Write metadata in yaml format.
|
||||||
|
|
||||||
@ -1115,117 +1204,42 @@ def write_yaml(mf, app):
|
|||||||
:param app: app metadata to written to the yaml file
|
:param app: app metadata to written to the yaml file
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# import rumael.yaml and check version
|
result = []
|
||||||
try:
|
for field in yaml_app_field_order:
|
||||||
import ruamel.yaml
|
if field == '\n':
|
||||||
except ImportError as e:
|
if result[-1] != '':
|
||||||
raise FDroidException('ruamel.yaml not instlled, can not write metadata.') from e
|
result.append('')
|
||||||
if not ruamel.yaml.__version__:
|
continue
|
||||||
raise FDroidException('ruamel.yaml.__version__ not accessible. Please make sure a ruamel.yaml >= 0.13 is installed..')
|
|
||||||
m = re.match(r'(?P<major>[0-9]+)\.(?P<minor>[0-9]+)\.(?P<patch>[0-9]+)(-.+)?',
|
|
||||||
ruamel.yaml.__version__)
|
|
||||||
if not m:
|
|
||||||
raise FDroidException('ruamel.yaml version malfored, please install an upstream version of ruamel.yaml')
|
|
||||||
if int(m.group('major')) < 0 or int(m.group('minor')) < 13:
|
|
||||||
raise FDroidException('currently installed version of ruamel.yaml ({}) is too old, >= 1.13 required.'.format(ruamel.yaml.__version__))
|
|
||||||
# suiteable version ruamel.yaml imported successfully
|
|
||||||
|
|
||||||
_yaml_bools_true = ('y', 'Y', 'yes', 'Yes', 'YES',
|
|
||||||
'true', 'True', 'TRUE',
|
|
||||||
'on', 'On', 'ON')
|
|
||||||
_yaml_bools_false = ('n', 'N', 'no', 'No', 'NO',
|
|
||||||
'false', 'False', 'FALSE',
|
|
||||||
'off', 'Off', 'OFF')
|
|
||||||
_yaml_bools_plus_lists = []
|
|
||||||
_yaml_bools_plus_lists.extend(_yaml_bools_true)
|
|
||||||
_yaml_bools_plus_lists.extend([[x] for x in _yaml_bools_true])
|
|
||||||
_yaml_bools_plus_lists.extend(_yaml_bools_false)
|
|
||||||
_yaml_bools_plus_lists.extend([[x] for x in _yaml_bools_false])
|
|
||||||
|
|
||||||
def _class_as_dict_representer(dumper, data):
|
|
||||||
'''Creates a YAML representation of a App/Build instance'''
|
|
||||||
return dumper.represent_dict(data)
|
|
||||||
|
|
||||||
def _field_to_yaml(typ, value):
|
|
||||||
if typ is TYPE_STRING:
|
|
||||||
if value in _yaml_bools_plus_lists:
|
|
||||||
return ruamel.yaml.scalarstring.SingleQuotedScalarString(str(value))
|
|
||||||
return str(value)
|
|
||||||
elif typ is TYPE_INT:
|
|
||||||
return int(value)
|
|
||||||
elif typ is TYPE_MULTILINE:
|
|
||||||
if '\n' in value:
|
|
||||||
return ruamel.yaml.scalarstring.preserve_literal(str(value))
|
|
||||||
else:
|
|
||||||
return str(value)
|
|
||||||
elif typ is TYPE_SCRIPT:
|
|
||||||
if type(value) == list:
|
|
||||||
if len(value) == 1:
|
|
||||||
return value[0]
|
|
||||||
else:
|
|
||||||
return value
|
|
||||||
else:
|
|
||||||
script_lines = value.split(' && ')
|
|
||||||
if len(script_lines) > 1:
|
|
||||||
return script_lines
|
|
||||||
else:
|
|
||||||
return value
|
|
||||||
else:
|
else:
|
||||||
return value
|
value = app.get(field)
|
||||||
|
if field == 'Builds' and app.builds:
|
||||||
def _app_to_yaml(app):
|
result.append('Builds:')
|
||||||
cm = ruamel.yaml.comments.CommentedMap()
|
first_build_entry = True
|
||||||
insert_newline = False
|
for build in app.builds:
|
||||||
for field in yaml_app_field_order:
|
if first_build_entry:
|
||||||
if field == '\n':
|
first_build_entry = False
|
||||||
# next iteration will need to insert a newline
|
|
||||||
insert_newline = True
|
|
||||||
else:
|
|
||||||
if app.get(field) or field == 'Builds':
|
|
||||||
# .txt calls it 'builds' internally, everywhere else its 'Builds'
|
|
||||||
if field == 'Builds':
|
|
||||||
if app.get('builds'):
|
|
||||||
cm.update({field: _builds_to_yaml(app)})
|
|
||||||
elif field == 'CurrentVersionCode':
|
|
||||||
cm.update({field: _field_to_yaml(TYPE_INT, getattr(app, field))})
|
|
||||||
else:
|
else:
|
||||||
cm.update({field: _field_to_yaml(fieldtype(field), getattr(app, field))})
|
result.append('')
|
||||||
|
result.append(_format_yml_build_entry(build))
|
||||||
|
if value:
|
||||||
|
result.append(_format_yml_field(field, value, yml_fieldtype(field)))
|
||||||
|
mf.write('\n'.join(result))
|
||||||
|
|
||||||
if insert_newline:
|
|
||||||
# we need to prepend a newline in front of this field
|
|
||||||
insert_newline = False
|
|
||||||
# inserting empty lines is not supported so we add a
|
|
||||||
# bogus comment and over-write its value
|
|
||||||
cm.yaml_set_comment_before_after_key(field, 'bogus')
|
|
||||||
cm.ca.items[field][1][-1].value = '\n'
|
|
||||||
return cm
|
|
||||||
|
|
||||||
def _builds_to_yaml(app):
|
def debug_print_yaml_item(typ, data, default_style, offset, raw_yml):
|
||||||
builds = ruamel.yaml.comments.CommentedSeq()
|
"""function debugging indiviudal lines during yaml writing"""
|
||||||
for build in app.builds:
|
typTable = {0: 'TYPE_UNKNOWN',
|
||||||
b = ruamel.yaml.comments.CommentedMap()
|
1: 'TYPE_OBSOLETE',
|
||||||
for field in build_flags:
|
2: 'TYPE_STRING',
|
||||||
value = getattr(build, field)
|
3: 'TYPE_BOOL',
|
||||||
if hasattr(build, field) and value:
|
4: 'TYPE_LIST',
|
||||||
if field == 'gradle' and value == ['off']:
|
5: 'TYPE_SCRIPT',
|
||||||
value = [ruamel.yaml.scalarstring.SingleQuotedScalarString('off')]
|
6: 'TYPE_MULTILINE',
|
||||||
if field in ('maven', 'buildozer'):
|
7: 'TYPE_BUILD',
|
||||||
if value == 'no':
|
8: 'TYPE_INT'}
|
||||||
continue
|
print('###', '(' + typTable[typ] + ', default_style='
|
||||||
elif value == 'yes':
|
+ str(default_style) + ', offset=' + str(offset) + ')\n',
|
||||||
value = 'yes'
|
data, '->', raw_yml if raw_yml else '')
|
||||||
b.update({field: _field_to_yaml(flagtype(field), value)})
|
|
||||||
builds.append(b)
|
|
||||||
|
|
||||||
# insert extra empty lines between build entries
|
|
||||||
for i in range(1, len(builds)):
|
|
||||||
builds.yaml_set_comment_before_after_key(i, 'bogus')
|
|
||||||
builds.ca.items[i][1][-1].value = '\n'
|
|
||||||
|
|
||||||
return builds
|
|
||||||
|
|
||||||
yaml_app = _app_to_yaml(app)
|
|
||||||
ruamel.yaml.round_trip_dump(yaml_app, mf, indent=4, block_seq_indent=2)
|
|
||||||
|
|
||||||
|
|
||||||
build_line_sep = re.compile(r'(?<!\\),')
|
build_line_sep = re.compile(r'(?<!\\),')
|
||||||
|
1
setup.py
1
setup.py
@ -80,7 +80,6 @@ setup(name='fdroidserver',
|
|||||||
'python-vagrant',
|
'python-vagrant',
|
||||||
'PyYAML',
|
'PyYAML',
|
||||||
'qrcode',
|
'qrcode',
|
||||||
'ruamel.yaml >= 0.13',
|
|
||||||
'requests >= 2.5.2, != 2.11.0, != 2.12.2, != 2.18.0',
|
'requests >= 2.5.2, != 2.11.0, != 2.12.2, != 2.18.0',
|
||||||
'docker-py >= 1.9, < 2.0',
|
'docker-py >= 1.9, < 2.0',
|
||||||
],
|
],
|
||||||
|
@ -199,14 +199,14 @@ Builds:
|
|||||||
commit: 0.53-test
|
commit: 0.53-test
|
||||||
submodules: true
|
submodules: true
|
||||||
scandelete:
|
scandelete:
|
||||||
- yes
|
- 'yes'
|
||||||
|
|
||||||
- versionName: '0.54'
|
- versionName: '0.54'
|
||||||
versionCode: 540
|
versionCode: 540
|
||||||
commit: '0.54'
|
commit: '0.54'
|
||||||
submodules: true
|
submodules: true
|
||||||
scandelete:
|
scandelete:
|
||||||
- yes
|
- 'yes'
|
||||||
|
|
||||||
- versionName: '0.55'
|
- versionName: '0.55'
|
||||||
versionCode: 550
|
versionCode: 550
|
||||||
@ -498,7 +498,7 @@ Builds:
|
|||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
submodules: true
|
submodules: true
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.95-alpha1
|
- versionName: 0.95-alpha1
|
||||||
versionCode: 95001
|
versionCode: 95001
|
||||||
@ -506,7 +506,7 @@ Builds:
|
|||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
submodules: true
|
submodules: true
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.95-alpha2
|
- versionName: 0.95-alpha2
|
||||||
versionCode: 95002
|
versionCode: 95002
|
||||||
@ -514,7 +514,7 @@ Builds:
|
|||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
submodules: true
|
submodules: true
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: '0.95'
|
- versionName: '0.95'
|
||||||
versionCode: 95050
|
versionCode: 95050
|
||||||
@ -522,7 +522,7 @@ Builds:
|
|||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
submodules: true
|
submodules: true
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.95.1
|
- versionName: 0.95.1
|
||||||
versionCode: 95150
|
versionCode: 95150
|
||||||
@ -530,56 +530,56 @@ Builds:
|
|||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
submodules: true
|
submodules: true
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.96-alpha1
|
- versionName: 0.96-alpha1
|
||||||
versionCode: 96001
|
versionCode: 96001
|
||||||
commit: v0.96-alpha1
|
commit: v0.96-alpha1
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.96-alpha2
|
- versionName: 0.96-alpha2
|
||||||
versionCode: 96002
|
versionCode: 96002
|
||||||
commit: v0.96-alpha2
|
commit: v0.96-alpha2
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.96-alpha3
|
- versionName: 0.96-alpha3
|
||||||
versionCode: 96003
|
versionCode: 96003
|
||||||
commit: v0.96-alpha3
|
commit: v0.96-alpha3
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.96-alpha4
|
- versionName: 0.96-alpha4
|
||||||
versionCode: 96004
|
versionCode: 96004
|
||||||
commit: v0.96-alpha4
|
commit: v0.96-alpha4
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.96-alpha5
|
- versionName: 0.96-alpha5
|
||||||
versionCode: 96005
|
versionCode: 96005
|
||||||
commit: v0.96-alpha5
|
commit: v0.96-alpha5
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.96-alpha6
|
- versionName: 0.96-alpha6
|
||||||
versionCode: 96006
|
versionCode: 96006
|
||||||
commit: v0.96-alpha6
|
commit: v0.96-alpha6
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: '0.96'
|
- versionName: '0.96'
|
||||||
versionCode: 96050
|
versionCode: 96050
|
||||||
commit: v0.96
|
commit: v0.96
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
scanignore:
|
scanignore:
|
||||||
- extern/AndroidPinning/res/raw/cacerts
|
- extern/AndroidPinning/res/raw/cacerts
|
||||||
|
|
||||||
@ -588,7 +588,7 @@ Builds:
|
|||||||
commit: v0.96.1
|
commit: v0.96.1
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
scanignore:
|
scanignore:
|
||||||
- extern/AndroidPinning/res/raw/cacerts
|
- extern/AndroidPinning/res/raw/cacerts
|
||||||
|
|
||||||
@ -597,7 +597,7 @@ Builds:
|
|||||||
commit: v0.97-alpha1
|
commit: v0.97-alpha1
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
scanignore:
|
scanignore:
|
||||||
- extern/AndroidPinning/res/raw/cacerts
|
- extern/AndroidPinning/res/raw/cacerts
|
||||||
|
|
||||||
@ -606,343 +606,343 @@ Builds:
|
|||||||
commit: v0.97-alpha2
|
commit: v0.97-alpha2
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.97-alpha3
|
- versionName: 0.97-alpha3
|
||||||
versionCode: 97003
|
versionCode: 97003
|
||||||
commit: v0.97-alpha3
|
commit: v0.97-alpha3
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.97-alpha4
|
- versionName: 0.97-alpha4
|
||||||
versionCode: 97004
|
versionCode: 97004
|
||||||
commit: v0.97-alpha4
|
commit: v0.97-alpha4
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.97-alpha5
|
- versionName: 0.97-alpha5
|
||||||
versionCode: 97005
|
versionCode: 97005
|
||||||
commit: v0.97-alpha5
|
commit: v0.97-alpha5
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.97-alpha6
|
- versionName: 0.97-alpha6
|
||||||
versionCode: 97006
|
versionCode: 97006
|
||||||
commit: v0.97-alpha6
|
commit: v0.97-alpha6
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.97-alpha7
|
- versionName: 0.97-alpha7
|
||||||
versionCode: 97007
|
versionCode: 97007
|
||||||
commit: v0.97-alpha7
|
commit: v0.97-alpha7
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.97-alpha8
|
- versionName: 0.97-alpha8
|
||||||
versionCode: 97008
|
versionCode: 97008
|
||||||
commit: v0.97-alpha8
|
commit: v0.97-alpha8
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: '0.97'
|
- versionName: '0.97'
|
||||||
versionCode: 97050
|
versionCode: 97050
|
||||||
commit: v0.97
|
commit: v0.97
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.98-alpha1
|
- versionName: 0.98-alpha1
|
||||||
versionCode: 98001
|
versionCode: 98001
|
||||||
commit: v0.98-alpha1
|
commit: v0.98-alpha1
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.98-alpha2
|
- versionName: 0.98-alpha2
|
||||||
versionCode: 98002
|
versionCode: 98002
|
||||||
commit: v0.98-alpha2
|
commit: v0.98-alpha2
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.98-alpha3
|
- versionName: 0.98-alpha3
|
||||||
versionCode: 98003
|
versionCode: 98003
|
||||||
commit: v0.98-alpha3
|
commit: v0.98-alpha3
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.98-alpha4
|
- versionName: 0.98-alpha4
|
||||||
versionCode: 98004
|
versionCode: 98004
|
||||||
commit: v0.98-alpha4
|
commit: v0.98-alpha4
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.98-alpha5
|
- versionName: 0.98-alpha5
|
||||||
versionCode: 98005
|
versionCode: 98005
|
||||||
commit: v0.98-alpha5
|
commit: v0.98-alpha5
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.98-alpha6
|
- versionName: 0.98-alpha6
|
||||||
versionCode: 98006
|
versionCode: 98006
|
||||||
commit: v0.98-alpha6
|
commit: v0.98-alpha6
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.98-alpha7
|
- versionName: 0.98-alpha7
|
||||||
versionCode: 98007
|
versionCode: 98007
|
||||||
commit: v0.98-alpha7
|
commit: v0.98-alpha7
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: '0.98'
|
- versionName: '0.98'
|
||||||
versionCode: 98050
|
versionCode: 98050
|
||||||
commit: v0.98
|
commit: v0.98
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.98.1
|
- versionName: 0.98.1
|
||||||
versionCode: 98150
|
versionCode: 98150
|
||||||
commit: v0.98.1
|
commit: v0.98.1
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.99-alpha1
|
- versionName: 0.99-alpha1
|
||||||
versionCode: 99001
|
versionCode: 99001
|
||||||
commit: v0.99-alpha1
|
commit: v0.99-alpha1
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.99-alpha2
|
- versionName: 0.99-alpha2
|
||||||
versionCode: 99002
|
versionCode: 99002
|
||||||
commit: v0.99-alpha2
|
commit: v0.99-alpha2
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: '0.99'
|
- versionName: '0.99'
|
||||||
versionCode: 99050
|
versionCode: 99050
|
||||||
commit: v0.99
|
commit: v0.99
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.99.1
|
- versionName: 0.99.1
|
||||||
versionCode: 99150
|
versionCode: 99150
|
||||||
commit: v0.99.1
|
commit: v0.99.1
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.99.2
|
- versionName: 0.99.2
|
||||||
versionCode: 99250
|
versionCode: 99250
|
||||||
commit: v0.99.2
|
commit: v0.99.2
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.100-alpha1
|
- versionName: 0.100-alpha1
|
||||||
versionCode: 100001
|
versionCode: 100001
|
||||||
commit: v0.100-alpha1
|
commit: v0.100-alpha1
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.100-alpha2
|
- versionName: 0.100-alpha2
|
||||||
versionCode: 100002
|
versionCode: 100002
|
||||||
commit: v0.100-alpha2
|
commit: v0.100-alpha2
|
||||||
subdir: F-Droid
|
subdir: F-Droid
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.100-alpha3
|
- versionName: 0.100-alpha3
|
||||||
versionCode: 100003
|
versionCode: 100003
|
||||||
commit: v0.100-alpha3
|
commit: v0.100-alpha3
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.100-alpha4
|
- versionName: 0.100-alpha4
|
||||||
versionCode: 100004
|
versionCode: 100004
|
||||||
commit: v0.100-alpha4
|
commit: v0.100-alpha4
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.100-alpha5
|
- versionName: 0.100-alpha5
|
||||||
versionCode: 100005
|
versionCode: 100005
|
||||||
commit: v0.100-alpha5
|
commit: v0.100-alpha5
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.100-alpha6
|
- versionName: 0.100-alpha6
|
||||||
versionCode: 100006
|
versionCode: 100006
|
||||||
commit: v0.100-alpha6
|
commit: v0.100-alpha6
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.100-alpha7
|
- versionName: 0.100-alpha7
|
||||||
versionCode: 100007
|
versionCode: 100007
|
||||||
commit: v0.100-alpha7
|
commit: v0.100-alpha7
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.100-alpha8
|
- versionName: 0.100-alpha8
|
||||||
versionCode: 100008
|
versionCode: 100008
|
||||||
commit: v0.100-alpha8
|
commit: v0.100-alpha8
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: '0.100'
|
- versionName: '0.100'
|
||||||
versionCode: 100050
|
versionCode: 100050
|
||||||
commit: v0.100
|
commit: v0.100
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.100.1
|
- versionName: 0.100.1
|
||||||
versionCode: 100150
|
versionCode: 100150
|
||||||
commit: v0.100.1
|
commit: v0.100.1
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.101-alpha1
|
- versionName: 0.101-alpha1
|
||||||
versionCode: 101001
|
versionCode: 101001
|
||||||
commit: v0.101-alpha1
|
commit: v0.101-alpha1
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.101-alpha2
|
- versionName: 0.101-alpha2
|
||||||
versionCode: 101002
|
versionCode: 101002
|
||||||
commit: v0.101-alpha2
|
commit: v0.101-alpha2
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.101-alpha3
|
- versionName: 0.101-alpha3
|
||||||
versionCode: 101003
|
versionCode: 101003
|
||||||
commit: v0.101-alpha3
|
commit: v0.101-alpha3
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.101-alpha4
|
- versionName: 0.101-alpha4
|
||||||
versionCode: 101004
|
versionCode: 101004
|
||||||
commit: v0.101-alpha4
|
commit: v0.101-alpha4
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.101-alpha5
|
- versionName: 0.101-alpha5
|
||||||
versionCode: 101005
|
versionCode: 101005
|
||||||
commit: v0.101-alpha5
|
commit: v0.101-alpha5
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.101-alpha6
|
- versionName: 0.101-alpha6
|
||||||
versionCode: 101006
|
versionCode: 101006
|
||||||
commit: v0.101-alpha6
|
commit: v0.101-alpha6
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: '0.101'
|
- versionName: '0.101'
|
||||||
versionCode: 101050
|
versionCode: 101050
|
||||||
commit: v0.101
|
commit: v0.101
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.102-alpha1
|
- versionName: 0.102-alpha1
|
||||||
versionCode: 102001
|
versionCode: 102001
|
||||||
commit: v0.102-alpha1
|
commit: v0.102-alpha1
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.102-alpha2
|
- versionName: 0.102-alpha2
|
||||||
versionCode: 102002
|
versionCode: 102002
|
||||||
commit: v0.102-alpha2
|
commit: v0.102-alpha2
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.102-alpha3
|
- versionName: 0.102-alpha3
|
||||||
versionCode: 102003
|
versionCode: 102003
|
||||||
commit: v0.102-alpha3
|
commit: v0.102-alpha3
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: '0.102'
|
- versionName: '0.102'
|
||||||
versionCode: 102050
|
versionCode: 102050
|
||||||
commit: v0.102
|
commit: v0.102
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.102.1
|
- versionName: 0.102.1
|
||||||
versionCode: 102150
|
versionCode: 102150
|
||||||
commit: v0.102.1
|
commit: v0.102.1
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.102.2
|
- versionName: 0.102.2
|
||||||
versionCode: 102250
|
versionCode: 102250
|
||||||
commit: v0.102.2
|
commit: v0.102.2
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.102.3
|
- versionName: 0.102.3
|
||||||
versionCode: 102350
|
versionCode: 102350
|
||||||
commit: v0.102.3
|
commit: v0.102.3
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.103-alpha1
|
- versionName: 0.103-alpha1
|
||||||
versionCode: 103001
|
versionCode: 103001
|
||||||
commit: v0.103-alpha1
|
commit: v0.103-alpha1
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.103-alpha2
|
- versionName: 0.103-alpha2
|
||||||
versionCode: 103002
|
versionCode: 103002
|
||||||
commit: v0.103-alpha2
|
commit: v0.103-alpha2
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
- versionName: 0.103-alpha3
|
- versionName: 0.103-alpha3
|
||||||
versionCode: 103003
|
versionCode: 103003
|
||||||
commit: v0.103-alpha3
|
commit: v0.103-alpha3
|
||||||
subdir: app
|
subdir: app
|
||||||
gradle:
|
gradle:
|
||||||
- yes
|
- true
|
||||||
|
|
||||||
ArchivePolicy: 12 versions
|
ArchivePolicy: 12 versions
|
||||||
AutoUpdateMode: None
|
AutoUpdateMode: None
|
||||||
|
@ -70,6 +70,194 @@ class MetadataTest(unittest.TestCase):
|
|||||||
# yaml.add_representer(fdroidserver.metadata.Build, _build_yaml_representer)
|
# yaml.add_representer(fdroidserver.metadata.Build, _build_yaml_representer)
|
||||||
# yaml.dump(frommeta, f, default_flow_style=False)
|
# yaml.dump(frommeta, f, default_flow_style=False)
|
||||||
|
|
||||||
|
def test_write_yaml_allfields(self):
|
||||||
|
|
||||||
|
mf = io.StringIO()
|
||||||
|
|
||||||
|
app = fdroidserver.metadata.App()
|
||||||
|
app.Disabled = True
|
||||||
|
app.AntiFeatures = ['Karl', 'Bert']
|
||||||
|
app.Provides = "org.fdroid.fdroid"
|
||||||
|
app.Categories = ['Secret', 'Stuff']
|
||||||
|
app.License = 'GPL-3.0-or-later'
|
||||||
|
app.AuthorName = 'He who must not be named.'
|
||||||
|
app.AuthorEmail = 'tom@f-droid.org'
|
||||||
|
app.AuthorWebSite = 'https://f-droid.org/~theDarkLord'
|
||||||
|
app.WebSite = 'https://f-droid.org'
|
||||||
|
app.SourceCode = 'https://gitlab.com/fdroid/fdroidclient.git'
|
||||||
|
app.IssueTracker = "https://gitlab.com/fdroid/fdroidclient/issues"
|
||||||
|
app.Translation = 'https://hosted.weblate.org/projects/f-droid/f-droid'
|
||||||
|
app.Changelog = 'https://example.com/fdroidclient/raw/master/CHANGELOG.md'
|
||||||
|
app.Donate = 'https://f-droid.org/about'
|
||||||
|
app.FlattrID = '343053'
|
||||||
|
app.LiberapayID = '27859'
|
||||||
|
app.Bitcoin = '15u8aAPK4jJ5N8wpWJ5gutAyyeHtKX5i18'
|
||||||
|
app.Litecoin = '000000000000000000000000000000000'
|
||||||
|
app.Name = 'F-Droid'
|
||||||
|
app.AutoName = 'F-Droid'
|
||||||
|
app.Summary = 'The app store that respects freedom and privacy'
|
||||||
|
app.Description = 'The app store that respects freedom and privacy'
|
||||||
|
app.RequiresRoot = True
|
||||||
|
app.RepoType = 'git'
|
||||||
|
app.Repo = 'https://gitlab.com/fdroid/fdroidclient.git'
|
||||||
|
app.Binaries = 'https://f-droid.org/fdroid-%v.apk'
|
||||||
|
app.builds = []
|
||||||
|
|
||||||
|
build = fdroidserver.metadata.Build()
|
||||||
|
build.versionName = '1.0.1'
|
||||||
|
build.versionCode = 101
|
||||||
|
build.disable = 'for this reason'
|
||||||
|
build.commit = '1.0.1'
|
||||||
|
build.timeout = 12345
|
||||||
|
build.subdir = 'app'
|
||||||
|
build.submodules = True
|
||||||
|
build.sudo = 'apt-get update -y && apt-get upgrade -y'
|
||||||
|
build.init = 'sed -i -e "/replace this/with that/" build.gradle'
|
||||||
|
build.patch = ['remove-play-services.patch', 'add-other-service.patch']
|
||||||
|
build.gradle = 'flavor'
|
||||||
|
build.maven = True
|
||||||
|
build.buildozer = True
|
||||||
|
build.output = 'app/build/fdroid-$$VERSION$$.zip'
|
||||||
|
build.scrlibs = ['DragSort@0.6.1,3', 'SlidingMenu@7ebe32772']
|
||||||
|
build.oldsdkloc = True
|
||||||
|
build.encoding = 'utf-8'
|
||||||
|
build.forceversion = True
|
||||||
|
build.forcevercode = True
|
||||||
|
build.rm = ['app/file1', 'app/file2', 'app/other*']
|
||||||
|
build.extlibs = ['android/android-support-v4.jar', 'android/android-support-v13.jar']
|
||||||
|
build.prebuild = 'sed -i -e "/replace this/with that/" build.gradle'
|
||||||
|
build.androidupdate = [False]
|
||||||
|
build.target = 'android-99'
|
||||||
|
build.scanignore = ['libs/a.so', 'libs/b.so']
|
||||||
|
build.scandelete = ['bin/exec', 'bin/run']
|
||||||
|
build.build = 'export NDK_DIR=$$NDK$$'
|
||||||
|
build.buildjni = True
|
||||||
|
build.ndk = 'r99b'
|
||||||
|
build.preassemble = ':gradleTask'
|
||||||
|
build.gradleprops = 'prop4gradle'
|
||||||
|
build.antcommands = 'package'
|
||||||
|
build.novcheck = True
|
||||||
|
build.antifeatures = ['Karl', 'Hank']
|
||||||
|
app.builds.append(build)
|
||||||
|
|
||||||
|
app.MaintainerNotes = 'Great app, highly recommended.'
|
||||||
|
app.ArchivePolicy = '3 versions'
|
||||||
|
app.AutoUpdateMode = 'None'
|
||||||
|
app.UpdateCheckMode = 'Tags'
|
||||||
|
app.UpdateCheckIgnore = '(alpha|beta|rc|RC|dev)'
|
||||||
|
app.VercodeOperation = '%c + 2'
|
||||||
|
app.UpdateCheckName = 'org.fdroid.fdroid'
|
||||||
|
app.UpdateCheckData = 'https://raw.githubusercontent.com/proj/app/master/AndroidManifest.xml|android:versionCode="([0-9]*)"|.|android:versionCode="([0-9]*)"'
|
||||||
|
app.CurrentVersion = '1.0.1'
|
||||||
|
app.CurrentVersionCode = 101
|
||||||
|
app.NoSourceSince = '1.0.1'
|
||||||
|
|
||||||
|
fdroidserver.metadata.write_yaml(mf, app)
|
||||||
|
mf.seek(0)
|
||||||
|
|
||||||
|
self.maxDiff = None
|
||||||
|
self.assertEqual(mf.read(), textwrap.dedent("""\
|
||||||
|
Disabled: true
|
||||||
|
AntiFeatures:
|
||||||
|
- Karl
|
||||||
|
- Bert
|
||||||
|
Provides: org.fdroid.fdroid
|
||||||
|
Categories:
|
||||||
|
- Secret
|
||||||
|
- Stuff
|
||||||
|
License: GPL-3.0-or-later
|
||||||
|
AuthorName: He who must not be named.
|
||||||
|
AuthorEmail: tom@f-droid.org
|
||||||
|
AuthorWebSite: https://f-droid.org/~theDarkLord
|
||||||
|
WebSite: https://f-droid.org
|
||||||
|
SourceCode: https://gitlab.com/fdroid/fdroidclient.git
|
||||||
|
IssueTracker: https://gitlab.com/fdroid/fdroidclient/issues
|
||||||
|
Translation: https://hosted.weblate.org/projects/f-droid/f-droid
|
||||||
|
Changelog: https://example.com/fdroidclient/raw/master/CHANGELOG.md
|
||||||
|
Donate: https://f-droid.org/about
|
||||||
|
FlattrID: '343053'
|
||||||
|
LiberapayID: '27859'
|
||||||
|
Bitcoin: 15u8aAPK4jJ5N8wpWJ5gutAyyeHtKX5i18
|
||||||
|
Litecoin: '000000000000000000000000000000000'
|
||||||
|
|
||||||
|
Name: F-Droid
|
||||||
|
AutoName: F-Droid
|
||||||
|
Summary: The app store that respects freedom and privacy
|
||||||
|
Description: |-
|
||||||
|
The app store that respects freedom and privacy
|
||||||
|
|
||||||
|
RequiresRoot: true
|
||||||
|
|
||||||
|
RepoType: git
|
||||||
|
Repo: https://gitlab.com/fdroid/fdroidclient.git
|
||||||
|
Binaries: https://f-droid.org/fdroid-%v.apk
|
||||||
|
|
||||||
|
Builds:
|
||||||
|
- versionName: 1.0.1
|
||||||
|
versionCode: 101
|
||||||
|
disable: for this reason
|
||||||
|
commit: 1.0.1
|
||||||
|
timeout: 12345
|
||||||
|
subdir: app
|
||||||
|
submodules: true
|
||||||
|
sudo:
|
||||||
|
- apt-get update -y
|
||||||
|
- apt-get upgrade -y
|
||||||
|
init: sed -i -e "/replace this/with that/" build.gradle
|
||||||
|
patch:
|
||||||
|
- remove-play-services.patch
|
||||||
|
- add-other-service.patch
|
||||||
|
gradle: flavor
|
||||||
|
maven: true
|
||||||
|
buildozer: true
|
||||||
|
output: app/build/fdroid-$$VERSION$$.zip
|
||||||
|
oldsdkloc: true
|
||||||
|
encoding: utf-8
|
||||||
|
forceversion: true
|
||||||
|
forcevercode: true
|
||||||
|
rm:
|
||||||
|
- app/file1
|
||||||
|
- app/file2
|
||||||
|
- app/other*
|
||||||
|
extlibs:
|
||||||
|
- android/android-support-v4.jar
|
||||||
|
- android/android-support-v13.jar
|
||||||
|
prebuild: sed -i -e "/replace this/with that/" build.gradle
|
||||||
|
androidupdate:
|
||||||
|
- false
|
||||||
|
target: android-99
|
||||||
|
scanignore:
|
||||||
|
- libs/a.so
|
||||||
|
- libs/b.so
|
||||||
|
scandelete:
|
||||||
|
- bin/exec
|
||||||
|
- bin/run
|
||||||
|
build: export NDK_DIR=$$NDK$$
|
||||||
|
buildjni: true
|
||||||
|
ndk: r99b
|
||||||
|
preassemble: :gradleTask
|
||||||
|
gradleprops: prop4gradle
|
||||||
|
antcommands: package
|
||||||
|
novcheck: true
|
||||||
|
antifeatures:
|
||||||
|
- Karl
|
||||||
|
- Hank
|
||||||
|
|
||||||
|
MaintainerNotes: |-
|
||||||
|
Great app, highly recommended.
|
||||||
|
|
||||||
|
ArchivePolicy: 3 versions
|
||||||
|
AutoUpdateMode: None
|
||||||
|
UpdateCheckMode: Tags
|
||||||
|
UpdateCheckIgnore: (alpha|beta|rc|RC|dev)
|
||||||
|
VercodeOperation: '%c + 2'
|
||||||
|
UpdateCheckName: org.fdroid.fdroid
|
||||||
|
UpdateCheckData: https://raw.githubusercontent.com/proj/app/master/AndroidManifest.xml|android:versionCode="([0-9]*)"|.|android:versionCode="([0-9]*)"
|
||||||
|
CurrentVersion: 1.0.1
|
||||||
|
CurrentVersionCode: 101
|
||||||
|
|
||||||
|
NoSourceSince: 1.0.1"""))
|
||||||
|
|
||||||
def test_rewrite_yaml_fakeotaupdate(self):
|
def test_rewrite_yaml_fakeotaupdate(self):
|
||||||
testdir = tempfile.mkdtemp(prefix=inspect.currentframe().f_code.co_name, dir=self.tmpdir)
|
testdir = tempfile.mkdtemp(prefix=inspect.currentframe().f_code.co_name, dir=self.tmpdir)
|
||||||
fdroidserver.common.config = {'accepted_formats': ['txt', 'yml']}
|
fdroidserver.common.config = {'accepted_formats': ['txt', 'yml']}
|
||||||
@ -307,6 +495,68 @@ class MetadataTest(unittest.TestCase):
|
|||||||
'prebuild': "a && b && "
|
'prebuild': "a && b && "
|
||||||
"sed -i 's,a,b,'"}]})
|
"sed -i 's,a,b,'"}]})
|
||||||
|
|
||||||
|
def test_write_yaml_description_with_trailing_whitespace(self):
|
||||||
|
mf = io.StringIO()
|
||||||
|
app = fdroidserver.metadata.App()
|
||||||
|
app.Categories = ['None']
|
||||||
|
app.Description = "this evil description has a trailing whitespace "
|
||||||
|
app.builds = []
|
||||||
|
build = fdroidserver.metadata.Build()
|
||||||
|
build.versionCode = 102030
|
||||||
|
build.versionName = 'v1.2.3'
|
||||||
|
build.build = "./gradlew compile"
|
||||||
|
app.builds.append(build)
|
||||||
|
fdroidserver.metadata.write_yaml(mf, app)
|
||||||
|
mf.seek(0)
|
||||||
|
self.maxDiff = None
|
||||||
|
self.assertEqual(mf.read(), textwrap.dedent("""\
|
||||||
|
Categories:
|
||||||
|
- None
|
||||||
|
License: Unknown
|
||||||
|
|
||||||
|
Description: |-
|
||||||
|
this evil description has a trailing whitespace
|
||||||
|
|
||||||
|
Builds:
|
||||||
|
- versionName: v1.2.3
|
||||||
|
versionCode: 102030
|
||||||
|
build: ./gradlew compile
|
||||||
|
|
||||||
|
AutoUpdateMode: None
|
||||||
|
UpdateCheckMode: None
|
||||||
|
"""))
|
||||||
|
|
||||||
|
def test_write_yaml_long_description(self):
|
||||||
|
mf = io.StringIO()
|
||||||
|
app = fdroidserver.metadata.App()
|
||||||
|
app.Categories = ['None']
|
||||||
|
app.Description = "long description is long; " * 20
|
||||||
|
app.builds = []
|
||||||
|
build = fdroidserver.metadata.Build()
|
||||||
|
build.versionCode = 102030
|
||||||
|
build.versionName = 'v1.2.3'
|
||||||
|
build.build = "./gradlew compile"
|
||||||
|
app.builds.append(build)
|
||||||
|
fdroidserver.metadata.write_yaml(mf, app)
|
||||||
|
mf.seek(0)
|
||||||
|
self.maxDiff = None
|
||||||
|
self.assertEqual(mf.read(), textwrap.dedent("""\
|
||||||
|
Categories:
|
||||||
|
- None
|
||||||
|
License: Unknown
|
||||||
|
|
||||||
|
Description: |-
|
||||||
|
long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long; long description is long;
|
||||||
|
|
||||||
|
Builds:
|
||||||
|
- versionName: v1.2.3
|
||||||
|
versionCode: 102030
|
||||||
|
build: ./gradlew compile
|
||||||
|
|
||||||
|
AutoUpdateMode: None
|
||||||
|
UpdateCheckMode: None
|
||||||
|
"""))
|
||||||
|
|
||||||
def test_write_yaml_1_line_scripts_as_string(self):
|
def test_write_yaml_1_line_scripts_as_string(self):
|
||||||
mf = io.StringIO()
|
mf = io.StringIO()
|
||||||
app = fdroidserver.metadata.App()
|
app = fdroidserver.metadata.App()
|
||||||
@ -461,6 +711,37 @@ class MetadataTest(unittest.TestCase):
|
|||||||
UpdateCheckMode: None
|
UpdateCheckMode: None
|
||||||
"""))
|
"""))
|
||||||
|
|
||||||
|
def test_write_yaml_very_long_script(self):
|
||||||
|
mf = io.StringIO()
|
||||||
|
app = fdroidserver.metadata.App()
|
||||||
|
app.Categories = ['None']
|
||||||
|
app.builds = []
|
||||||
|
build = fdroidserver.metadata.Build()
|
||||||
|
build.versionCode = 102030
|
||||||
|
build.versionName = 'v1.2.3'
|
||||||
|
build.build = "./gradlew someSpecialTask && sed -i 'd/that wrong config/' gradle.properties && ./gradlew compile && long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long;"
|
||||||
|
app.builds.append(build)
|
||||||
|
fdroidserver.metadata.write_yaml(mf, app)
|
||||||
|
mf.seek(0)
|
||||||
|
self.maxDiff = None
|
||||||
|
self.assertEqual(mf.read(), textwrap.dedent("""\
|
||||||
|
Categories:
|
||||||
|
- None
|
||||||
|
License: Unknown
|
||||||
|
|
||||||
|
Builds:
|
||||||
|
- versionName: v1.2.3
|
||||||
|
versionCode: 102030
|
||||||
|
build:
|
||||||
|
- ./gradlew someSpecialTask
|
||||||
|
- sed -i 'd/that wrong config/' gradle.properties
|
||||||
|
- ./gradlew compile
|
||||||
|
- long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long; long script is very long;
|
||||||
|
|
||||||
|
AutoUpdateMode: None
|
||||||
|
UpdateCheckMode: None
|
||||||
|
"""))
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
os.chdir(os.path.dirname(__file__))
|
os.chdir(os.path.dirname(__file__))
|
||||||
|
Loading…
Reference in New Issue
Block a user