Merge pull request #149 from YunoHost/config_panel_schema

Lint the tests.toml and config_panel.toml with schemas too
This commit is contained in:
Alexandre Aubin 2024-06-09 23:27:13 +02:00 committed by GitHub
commit e38782bfd5
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -310,27 +310,49 @@ def file_exists(file_path):
return os.path.isfile(file_path) and os.stat(file_path).st_size > 0 return os.path.isfile(file_path) and os.stat(file_path).st_size > 0
def spdx_licenses(): def cache_file(cachefile: str, ttl_s: int):
cachefile = ".spdx_licenses" def cache_is_fresh():
if os.path.exists(cachefile) and time.time() - os.path.getmtime(cachefile) < 3600: return os.path.exists(cachefile) and time.time() - os.path.getmtime(cachefile) < ttl_s
def decorator(function):
def wrapper(*args, **kwargs):
if not cache_is_fresh():
with open(cachefile, "w+") as outfile:
outfile.write(function(*args, **kwargs))
return open(cachefile).read() return open(cachefile).read()
return wrapper
url = "https://spdx.org/licenses/" return decorator
content = urlopen(url)["content"]
open(cachefile, "w").write(content)
return content
@cache_file(".spdx_licenses", 3600)
def spdx_licenses():
return urlopen("https://spdx.org/licenses/")["content"]
@cache_file(".manifest.v2.schema.json", 3600)
def manifest_v2_schema(): def manifest_v2_schema():
cachefile = ".manifest.v2.schema.json" return urlopen("https://raw.githubusercontent.com/YunoHost/apps/master/schemas/manifest.v2.schema.json")["content"]
if os.path.exists(cachefile) and time.time() - os.path.getmtime(cachefile) < 3600:
return json.loads(open(cachefile).read())
url = "https://raw.githubusercontent.com/YunoHost/apps/master/schemas/manifest.v2.schema.json"
content = urlopen(url)["content"]
open(cachefile, "w").write(content)
return json.loads(content)
@cache_file(".tests.v1.schema.json", 3600)
def tests_v1_schema():
return urlopen("https://raw.githubusercontent.com/YunoHost/apps/master/schemas/tests.v1.schema.json")["content"]
@cache_file(".config_panel.v1.schema.json", 3600)
def config_panel_v1_schema():
return urlopen("https://raw.githubusercontent.com/YunoHost/apps/master/schemas/config_panel.v1.schema.json")["content"]
def validate_schema(name: str, schema, data):
v = jsonschema.Draft7Validator(schema)
for error in v.iter_errors(data):
try:
error_path = " > ".join(error.path)
except:
error_path = str(error.path)
yield Info(f"Error validating {name} using schema: in key {error_path}\n {error.message}")
tests = {} tests = {}
tests_reports = { tests_reports = {
@ -760,6 +782,8 @@ class App(TestSuite):
"The config panel is set to version 1.x, but the config script is apparently still using some old code from 0.1 such as '$YNH_CONFIG_STUFF' or 'yunohost app action'" "The config panel is set to version 1.x, but the config script is apparently still using some old code from 0.1 such as '$YNH_CONFIG_STUFF' or 'yunohost app action'"
) )
validate_schema("config_panel", config_panel_v1_schema(), toml.load(app.path + "config_panel.toml"))
@test() @test()
def badges_in_readme(app): def badges_in_readme(app):
@ -1157,7 +1181,7 @@ class Configurations(TestSuite):
############################ ############################
@test() @test()
def tests_toml_exists(self): def tests_toml(self):
app = self.app app = self.app
@ -1173,6 +1197,8 @@ class Configurations(TestSuite):
yield Error( yield Error(
"The 'check_process' file that interfaces with the app CI has now been replaced with 'tests.toml' format and is now mandatory for apps v2." "The 'check_process' file that interfaces with the app CI has now been replaced with 'tests.toml' format and is now mandatory for apps v2."
) )
else:
validate_schema("tests.toml", tests_v1_schema(), toml.load(app.path + "tests.toml"))
@test() @test()
def check_process_syntax(self): def check_process_syntax(self):
@ -2229,24 +2255,9 @@ class Manifest(TestSuite):
@test() @test()
def manifest_schema(self): def manifest_schema(self):
v = jsonschema.Draft7Validator(manifest_v2_schema())
if app_packaging_format <= 1: if app_packaging_format <= 1:
return return
validate_schema("manifest", manifest_v2_schema(), self.manifest)
for error in v.iter_errors(self.manifest):
try:
error_path = " > ".join(error.path)
except:
error_path = str(error.path)
yield Info(
"Error validating manifest using schema: in key "
+ error_path
+ "\n "
+ error.message
)
######################################## ########################################