-
Notifications
You must be signed in to change notification settings - Fork 182
/
schema_lint.py
89 lines (70 loc) · 3.38 KB
/
schema_lint.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#!/usr/bin/env python
import logging
import nf_core.schema
import jsonschema
def schema_lint(self):
"""Pipeline schema syntax
Pipelines should have a ``nextflow_schema.json`` file that describes the different
pipeline parameters (eg. ``params.something``, ``--something``).
.. tip:: Reminder: you should generally never need to edit this JSON file by hand.
The ``nf-core schema build`` command can create *and edit* the file for you
to keep it up to date, with a friendly user-interface for customisation.
The lint test checks the schema for the following:
* Schema should be a valid JSON file
* Schema should adhere to `JSONSchema <https://json-schema.org/>`_, Draft 7.
* Parameters can be described in two places:
* As ``properties`` in the top-level schema object
* As ``properties`` within subschemas listed in a top-level ``definitions`` objects
* The schema must describe at least one parameter
* There must be no duplicate parameter IDs across the schema and definition subschema
* All subschema in ``definitions`` must be referenced in the top-level ``allOf`` key
* The top-level ``allOf`` key must not describe any non-existent definitions
* Default parameters in the schema must be valid
* Core top-level schema attributes should exist and be set as follows:
* ``$schema``: ``https://json-schema.org/draft-07/schema``
* ``$id``: URL to the raw schema file, eg. ``https://raw.githubusercontent.com/YOURPIPELINE/master/nextflow_schema.json``
* ``title``: ``YOURPIPELINE pipeline parameters``
* ``description``: The pipeline config ``manifest.description``
For example, an *extremely* minimal schema could look like this:
.. code-block:: json
{
"$schema": "https://json-schema.org/draft-07/schema",
"$id": "https://raw.githubusercontent.com/YOURPIPELINE/master/nextflow_schema.json",
"title": "YOURPIPELINE pipeline parameters",
"description": "This pipeline is for testing",
"properties": {
"first_param": { "type": "string" }
},
"definitions": {
"my_first_group": {
"properties": {
"second_param": { "type": "string" }
}
}
},
"allOf": [{"$ref": "#/definitions/my_first_group"}]
}
.. tip:: You can check your pipeline schema without having to run the entire pipeline lint
by running ``nf-core schema lint`` instead of ``nf-core lint``
"""
passed = []
warned = []
failed = []
# Only show error messages from schema
logging.getLogger("nf_core.schema").setLevel(logging.ERROR)
# Lint the schema
self.schema_obj = nf_core.schema.PipelineSchema()
self.schema_obj.get_schema_path(self.wf_path)
try:
self.schema_obj.load_lint_schema()
passed.append("Schema lint passed")
except AssertionError as e:
failed.append("Schema lint failed: {}".format(e))
# Check the title and description - gives warnings instead of fail
if self.schema_obj.schema is not None:
try:
self.schema_obj.validate_schema_title_description()
passed.append("Schema title + description lint passed")
except AssertionError as e:
warned.append(str(e))
return {"passed": passed, "warned": warned, "failed": failed}