This document describes the approach to be adopted for the management and the release of changes to the INSPIRE schemas. It is organised in two sections.
The first section describes the governance process to manage changes to the INSPIRE schemas, from the initial stage of change proposal up to the final stage of endorsement and implementation of the changes into a new release. The process defines actors, responsibilities and timelines for each stage of the process, and the GitHub artefacts (issues and labels) to be used in each process.
The second section describes the release process of the INSPIRE schemas. It defines the release plan of the schemas and explains the rules used to version new releases of the schemas.
The process to update/change INSPIRE schemas varies depending on the type of change proposed and its foreseen impact. Based on this, different scenarios are envisaged. They are all captured in the flowchart below and described in the following. An overview of all the labels can be found on https://github.com/INSPIRE-MIF/application-schemas/labels.
The first actor involved in the governance process is the change proposer, i.e. the person, organisation or group of people/organisations that submits a change proposal. The change proposer shall outline the need for the change in a schema, explaining if this is needed because of a bug or because the current version does not fit specific use cases (to be adequately described). The change proposer shall then describe the proposed change and explain whether it would have an impact on the Technical Guidance documents (TG) and/or on the Implementing Rules (IR). The GitHub labels impact on TG and impact on IR are used in such cases. The change proposal shall be described by opening a new issue in the issue tracker of this repository. Note: in contrast to the process for the TGs, no impact is expected on neither the validator nor the registry of a change to the schemas. The validator simply uses the latest approved version of the schemas, and there is no direct relation between the schemas and the registry.
The next actor involved in the governance process is the MIWP Sub-group of experts (referred to as Sub-group in the following), supervised by the JRC and created within Action 2.3 “Simplification of INSPIRE implementation” of the INSPIRE MIWP 2020-2024. The Sub-group shall evaluate the proposal and, in a first step, check whether: i) the change proposal is reasonable; and ii) the change proposal (including the impact) is correct, clear, described with a sufficient level of detail, and the impact of the change in the schema is the one described by the change proposer. To do so, the Sub-group shall interact with the change proposer and shall be closely supported by the INSPIRE helpdesk facilitators. The latter shall also contribute to the analysis of the change proposal and make sure it covers all the required points and is ready to be discussed by the Sub-group. All the interactions between the change proposer, the Sub-group and the helpdesk facilitators shall happen in the issue tracker of this repository, in the form of a discussion under the same issue initially created.
If the change proposal (including the impact) is not reasonable and/or not correct, not clear, or not described with a sufficient level of detail, the Sub-group shall either reject it (in which case the issue will be closed) or ask the change proposer to improve it – with the help of the helpdesk facilitators – and submit it again. In this case, the GitHub label further info required is used. On the opposite, if the change proposal is correct, clear and described with a sufficient level of detail, the GitHub label approved will be used. At this point, depending on the type of change proposal to the schema, the workflow can follow two different paths (see below) based on a decision of the Sub-group. To determine what is the most suitable path for the specific type of change proposed, the Sub-group reserves the right to ask the change proposer for additional evidence or justification of the change proposal (to be given by e.g. a MIG/MIG-T member) and the GitHub label further info required is used. No evidence shall instead be required in the cases of clear bugs to a schema (see below). The two paths are the following:
-
If the proposed change analysed by the Sub-group is obvious and minor, e.g. there is a clear bug to an application schema and the proposal is to fix it, with no impact on the TG and no impact on the IR, the Sub-group shall approve the change and invite the INSPIRE Coordination Team (CT) to endorse it. The GitHub label for INSPIRE CT is used. The INSPIRE CT shall either: i) endorse the proposal; ii) reject the proposal; or iii) ask the change proposer to amend the proposal and submit it again. If the change proposal is rejected by the INSPIRE CT, the issue is closed and the whole process ends; if the INSPIRE CT asks that the change proposal is amended, the GitHub label further info required is used and the change proposer shall amend it according to the feedback received and submit it again.
-
If the proposed change analysed by the Sub-group is major, i.e. it impacts the TG and/or the IR, the following actor in the process is the INSPIRE MIG-T. The GitHub label for INSPIRE MIG-T is The change proposal is presented by the Sub-group (ideally together with the original change proposer) to the MIG-T during the second or the fourth MIG-T meetings of the year, indicatively taking place in April and October. The MIG-T members, who will receive the rationale for the change proposal in written form before the meeting, will be able to ask questions and discuss with the change proposer and express themselves in favor or against the change proposal. An overall decision (in favor/against) from the MIG-T shall be taken during the meeting through a voting process, where MIG-T members voting against the proposal or abstaining from voting need to provide justification. The MIG-T shall either: i) endorse the proposal; ii) reject the proposal, in which case the issue is closed; or iii) ask the change proposer to amend the proposal and submit it again, in which case the GitHub label further info required is used. If the change proposal is rejected by the MIG-T, the whole process ends; if the MIG-T asks that the change proposal is amended, the change proposer shall amend it according to the feedback received and submit it again.
If the change proposal is endorsed by the INSPIRE CT or by the MIG-T, respectively in cases 1) and 2) above, the GitHub label for INSPIRE MIG is used. The INSPIRE MIG is informed about the change proposal and a two-week time window starts, during which MIG members can raise objections to the proposal. If at least one objection is raised during the two-week time window, the GitHub label for INSPIRE MIG discussion is used and the change proposal is discussed at the first MIG meeting immediately following the two-week time window. An overall decision (in favor/against) from the MIG shall be taken during the meeting through a voting process, where MIG members voting against the proposal or abstaining from voting need to provide justification. The MIG shall either: i) endorse the proposal, in which case the GitHub label endorsed is used; ii) reject the proposal, in which case the issue is closed; or iii) ask the change proposer to amend the proposal and submit it again, in which case the GitHub label further info required is used. If the change proposal is rejected by the MIG, the whole process ends; if the MIG asks that the change proposal is amended, the change proposer shall amend it according to the feedback received and submit it again.
If no objection is raised by MIG members during the two-week time window, or if the change proposal is endorsed by the MIG during the meeting, the JRC shall implement the change in the relevant schema and – if relevant – in the TG. Once this is done, the issue is finally closed. It must be noted that the TG will have their own governance process (defined in the Technical Guidance documents repository), based on a specific group of actors (similar to the one for schemas) and a different release plan. If the endorsed change proposal has (also) an impact on the IR, the INSPIRE CT shall submit a proposal for a draft amendment of the IR. The endorsement of this proposal is subject to its own governance process (involving the Comitology procedure) and is outside the scope of the present document.
The release of the endorsed changes to the INSPIRE schemas happens twice a year and it is scheduled to take place by January 31 and July 31. This means that:
- all the changes endorsed by the MIG (either after the two-week scrutiny or during the MIG meeting in June) between February and July will be included in the release published by July 31;
- all the changes endorsed by the MIG (either after the two-week scrutiny or during the MIG meeting in November) between August and January will be included in the release published by January 31.
In addition to the scheduled releases, hotfix releases of the schemas, i.e. releases that fix critical bugs, might be released at any time.
All the releases, including a full changelog listing the changes made, are published (and will remain available) in the Releases page of this repository. After each release, the official repository of the INSPIRE schemas at https://inspire.ec.europa.eu/schemas is updated accordingly.
Each release is identified by a sequential number 202X.Y, where 202X identifies the year of the release and Y identifies the sequential number of the release for that year. As an example, the schema releases in January and July 2022 will be identified by the progressive numbers 2022.1 and 2022.2, respectively.
The versioning of the INSPIRE schemas, which determines the versions available in the official repository at https://inspire.ec.europa.eu/schemas, is performed according to the X.Y.Z pattern, where:
-
X is the major version number. Updates of this version number (e.g. v3.X --> v4.0) are applied as a consequence of changes to the applicable legal framework (e.g. Implementing Rules). These changes are always breaking (or non backwards-compatible), i.e. existing data valid according to the older schema will no longer be valid according to the newer schema. Examples of such non-backwards compatible changes include e.g. adding or removing mandatory properties or changing the types or names of existing properties.
-
Y is the minor version number. Updates of this version number (e.g. v3.0.X --> v3.1) are applied when changes to the schemas are non-breaking (or backwards-compatible), i.e existing data valid according to the older schema will also remain valid according to the newer schema. Examples of such backwards compatible changes include e.g. adding optional properties to existing types or adding new types.
-
Z is the bugfix version number. Updates of this version number (e.g. v3.0 --> v3.0.1) are applied when errors or bugs are fixed in the XML schema. These changes can be breaking (or non-backwards-compatible) or non-breaking (or backwards-compatible). Examples of breaking bug-fixes include e.g. adding restrictions in cardinality of existing properties, adding mandatory associations to schema elements or changing the types assigned to schema elements. Examples of non-breaking bug-fixes include e.g. adding missing types or definitions to elements already defined in a schema.