diff --git a/sources/document.err.html b/sources/document.err.html new file mode 100644 index 0000000..916ed2f --- /dev/null +++ b/sources/document.err.html @@ -0,0 +1,721 @@ +
Line | ID | +Message | Context | Severity | + +
---|---|---|---|---|
_module |
+term reference not in expected format:Cambridge Dictionary | #<Asciidoctor::Block@592500 {context: :paragraph, content_model: :simple, style: nil, lines: 1}> | 1 | |
000606 | _2b43404f-7def-4d0b-a2e5-1fcde57fa9d4 |
+Error: Term reference to requirements missing: "requirements" is not defined in document
+ | <refterm>requirements</refterm> | 1 |
000621 | _8132d980-0554-4a2b-960a-6bd4bff3a809 |
+Error: Term reference to requirement-class missing: "requirement-class" is not defined in document
+ | <refterm>requirement class</refterm> | 1 |
002156 | _d4097bf0-eaa5-4d48-b13f-bf413b743940 |
+Error: Term reference to conformance-test-classes missing: "conformance-test-classes" is not defined in document
+ | <refterm>conformance test classes</refterm> | 1 |
Line | ID | +Message | Context | Severity | + +
---|---|---|---|---|
000090 | _5127019d-9703-94b2-2151-d392c6830cc0 |
+Crossreference target cls-6 is undefined | <xref target="cls-6"/> | 1 |
000123 | _5664038a-c90f-41ab-bfbf-6669c629144f |
+normalised identifier in | <xref target="Terms_and_Definitions">cls-4</xref> | 2 |
000123 | _c2c40101-dda5-399c-4569-ddfd58d282a6 |
+Crossreference target Terms_and_Definitions is undefined | <xref target="Terms_and_Definitions">cls-4</xref> | 1 |
000126 | _67dd03fd-3dc2-a6f9-b5ac-8f17ccce22c5 |
+Crossreference target Annex_C is undefined | <xref target="Annex_C">annex-C</xref> | 1 |
000126 | _ba9a7b3d-d7a7-41e0-85f6-ae8c066b507e |
+normalised identifier in | <xref target="Annex_C">annex-C</xref> | 2 |
000171 | _81795308-85a8-d659-b8f2-ab49abbba286 |
+Crossreference target cls-6 is undefined | <xref target="cls-6"/> | 1 |
000179 | _63225180-37d8-b5d0-dcbe-58b8788328c2 |
+Crossreference target cls-6 is undefined | <xref target="cls-6"/> | 1 |
000220 | iso19105_2022 |
+normalised identifier in | <bibitem id="iso19105_2022" type="standard" schema-version="v1.2.8"> <fetched>2024-12-17</fetched> +<title type="title-intro" format="text/plain" language="en" script="Latn">Geographic information</title> + +<title type="title-main" format="text/plain" language="en" script="Latn">Conformance and testing</title> + | 2 |
000278 | _5e083bae-1002-419d-acbe-adbede48ae92 |
+normalised identifier in | <xref target="Annex_C">annex-C</xref> | 2 |
000278 | _def69548-3806-45ca-3bba-5c1da0e82ee3 |
+Crossreference target Annex_C is undefined | <xref target="Annex_C">annex-C</xref> | 1 |
000886 | _828c1575-f6ae-33c9-5055-82586b512f69 |
+Crossreference target Requirement_1 is undefined | <xref target="Requirement_1">req-1</xref> | 1 |
000886 | _c3b1d058-4622-4109-a358-37146f281fc1 |
+normalised identifier in | <xref target="Requirement_1">req-1</xref> | 2 |
000925 | _875f9b1a-e635-e726-a40f-00bce22dcd56 |
+Crossreference target term-all-components-schema-document is undefined | <xref target="term-all-components-schema-document"/> | 1 |
000941 | _72703e4f-47cf-189e-d14a-1116985cd140 |
+Crossreference target annex-B-2 is undefined | <xref target="annex-B-2"/> | 1 |
001104 | _5966d231-3b63-4c29-abbd-1bf1c62df1e7 |
+normalised identifier in | <xref target="term-indirect-dependency-_of-a-requirements-class_"/> | 2 |
001587 | _58cd33a2-4eb2-8484-d837-a183158c43e9 |
+Crossreference target annex-A-2-1 is undefined | <xref target="annex-A-2-1"/> | 1 |
001610 | _8b2d1036-30ea-4bb4-9f29-c7e41d664618 |
+normalised identifier in | <xref target="Clause_6.1">cls-6-1</xref> | 2 |
001610 | _c9d15222-d5a6-8439-754b-15b0689d81d3 |
+Crossreference target Clause_6.1 is undefined | <xref target="Clause_6.1">cls-6-1</xref> | 1 |
Line | ID | +Message | Context | Severity | + +
---|---|---|---|---|
-- |
+Abstract is missing! | 2 | ||
-- |
+Keywords are missing! | 2 | ||
-- |
+Submitters is missing! | 2 | ||
000044 | _f5d8b18c-48bc-39d4-765e-c315cfc653e3 |
+Table should have title | <table id="_f5d8b18c-48bc-39d4-765e-c315cfc653e3" unnumbered="true"> <tbody> <tr> <th valign="middle" align="center">Person</th> +<th valign="middle" align="center">Organization Represented</th> +</tr> <tr> <td valign="middle" align="left">Carl Reed</td> +<td valign="middle" align="left">Carl Reed & Associates</td> +</tr> <tr> <td valign="middle" align="left">Chuck Heazel</td> | 2 |
000058 | _18f1cff9-c268-fc8f-944c-0d82334b6180 |
+Table should have title | <table id="_18f1cff9-c268-fc8f-944c-0d82334b6180" unnumbered="true"> <tbody> <tr> <th valign="middle" align="center">Person</th> +<th valign="middle" align="center">Organization Represented</th> +</tr> <tr> <td valign="middle" align="left">Simon Cox</td> +<td valign="middle" align="left">CSIRO and OGC Fellow</td> +</tr> <tr> <td valign="middle" align="left">Chuck Heazel</td> | 2 |
000098 | cls-1 |
+Hanging paragraph in clause | <clause id="cls-1" type="scope" obligation="normative"> +<title>Scope</title> +<p id="_ab28fb11-e5bd-ffbc-2e46-207f6c65db0f">This OGC Standard for Designing and Writing Modular Standards, also known as the <tt>ModSpec</tt>:</p> + +<ul id="_c8c40b5a-3342-c347-9470-9934f13b73a6"> <li> <p id="_901e1445-2ed9-5758-1b98-ff4dfb370bc0">Specifies rules for the internal structure and organization of a standard.</p> | 2 |
000692 | cls-5 |
+Hanging paragraph in clause | <clause id="cls-5" obligation="normative"> +<title>Conventions</title> +<clause id="_symbols_and_abbreviated_terms" obligation="normative"> +<title>Symbols (and abbreviated terms)</title> +<p id="_189b05f8-d8bd-86ff-6cae-0a71bf9b4a45">All symbols used in this document are either:</p> | 2 |
000945 | cls-8-1 |
+Hanging paragraph in clause | <clause id="cls-8-1" obligation="normative"> +<title>ModSpec Requirements Class: Core</title> +<p id="_f2e2c084-296f-e1fe-c944-85f274700eaf">The following requirements specify the rules for the content and structure of a modular standard. These requirements are also known as the <tt>core</tt> of the ModSpec.<note id="_70b49cf5-fe90-d2d5-3348-c645fb3cdb10"> <p id="_54e20bb1-972d-13e9-e471-ab01380d3772">The following requirement is for OGC work only and will be moved to the OGC Policy statement regarding the use of the ModSpec. This move will happen once the policy is removed.</p> +</note> </p> + | 2 |
000952 | req-0 |
+Table should have title | <table id="req-0" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ000</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/ogc-compliance</strong> <br/> +Any new OGC Standard, abstract specification that contains requirements, or major revision of an existing OGC Standard <em>SHALL</em> comply with the requirements stated in this document.</td> +</tr> </tbody> +</table> | 2 |
000960 | req-1 |
+Table should have title | <table id="req-1" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ001</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/reqs-are-testable</strong> <br/> +All the parts of a requirement, a requirements module, or requirements class <em>SHALL</em> be +testable. Failure to pass any part of any requirement shall be a failure to pass the +associated conformance test class.</td> | 2 |
000972 | req-2 |
+Table should have title | <table id="req-2" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ002</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/all-components-assigned-uri</strong> <br/> +Each component of the standard, including requirements, requirements modules, +requirements classes, conformance test cases, conformance modules and conformance +classes <em>SHALL</em> be assigned a URI. | 2 |
000985 | rec-1 |
+Table should have title | <table id="rec-1" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REC001</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/uri-external-use</strong> <br/> +These URI identities <em>SHOULD</em> be used in any external documentation that reference +these component elements in a normative manner, including but not limited to other +standards, implementations of the conformance test suite, or certificates of | 2 |
000999 | per-1 |
+Table should have title | <table id="per-1" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER001</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/informational-content-in-core</strong> <br/> +The informational and structural universals of the standard <em>MAY</em> be included in the +core text and its associated models without violations of the ModSpec. This is +true if the requirements of the extension are not implicit in what is | 2 |
001013 | per-2 |
+Table should have title | <table id="per-2" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER002</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/core-may-contain-schema-terms</strong> <br/> +The core <em>MAY</em> contain the definition and schema of commonly used terms and data +structures for use in other structures throughout the standard.</td> +</tr> </tbody> | 2 |
001020 | per-3 |
+Table should have title | <table id="per-3" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER003</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/core-names-of-operations</strong> <br/> +This may include the list of the names of all operations and operation parameters +to be used in any request-response pairs defined in any conformance class of the +standard. If a service receives a request that is not supported in its | 2 |
001032 | req-3 |
+Table should have title | <table id="req-3" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ003</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/vocabulary-and-parent-req-class</strong> <br/> +Requirements on the use and interpretation of vocabulary <em>SHALL</em> be in the +requirements class where that use or interpretation is used.</td> +</tr> </tbody> | 2 |
001039 | per-4 |
+Table should have title | <table id="per-4" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER004</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/external-vocabs-core</strong> <br/> +Importation of external vocabularies and schemas <em>MAY</em> be in the core.</td> +</tr> </tbody> +</table> | 2 |
001082 | req-4 |
+Table should have title | <table id="req-4" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ004</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/single-standardization-target</strong> <br/> +Each requirement in a conformant standard <em>SHALL</em> have a single standardization +target type.</td> +</tr> </tbody> | 2 |
001094 | req-5 |
+Table should have title | <table id="req-5" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ005</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/modspec/test-class-single-standardization-target</strong> <br/> +All conformance tests in a single conformance test class in a conformant +standard <em>SHALL</em> have the same standardization target.</td> +</tr> </tbody> | 2 |
001106 | per-5 |
+Table should have title | <table id="per-5" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER005</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/repeated-requirements</strong> <br/> +If needed, a requirement <em>MAY</em> be repeated word for word in another requirement up +to but not including the identification of the standardization target type.</td> +</tr> </tbody> | 2 |
001124 | per-6 |
+Table should have title | <table id="per-6" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER006</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/abstract-superclass</strong> <br/> +The standard may introduce an abstract superclass of all affected standardization target types and +use this for the requirements common to all of the affected target types. This is +diagrammed in <xref target="fig-6-1"/>.</td> | 2 |
001145 | req-6 |
+Table should have title | <table id="req-6" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ006</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/requirements-grouped</strong> <br/> +Requirements SHALL be grouped together in clauses (numbered sections) of the +document in a strictly hierarchical manner, consistent with +requirements classes.</td> | 2 |
001153 | req-7 |
+Table should have title | <table id="req-7" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ007</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/requirements-test-suite-structure</strong> <br/> +The requirements structure of the document SHALL be in a logical correspondence to +the test suite structure.</td> +</tr> </tbody> | 2 |
001190 | req-8 |
+Table should have title | <table id="req-8" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ008</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/requirements-class-correspondence-to-conformance-classes</strong> <br/> +The requirements classes shall be in a one-to-one correspondence to the conformance test classes, +and thus to the various certificate of conformance types possible for a candidate implementation.</td> +</tr> </tbody> | 2 |
001204 | req-9 |
+Table should have title | <table id="req-9" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ009</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/no-optional-tests</strong> <br/> +A Conformance class SHALL not contain any optional conformance tests.</td> +</tr> </tbody> +</table> | 2 |
001217 | per-7 |
+Table should have title | <table id="per-7" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER007</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/conf-class-paramterized</strong> <br/> +A Conformance class may be parameterized.</td> +</tr> </tbody> +</table> | 2 |
001238 | req-10 |
+Table should have title | <table id="req-10" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ010</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/all-parameters-expressed</strong> <br/> +A certificate of conformance SHALL specify all parameter values used to pass the +tests in its conformance test class.</td> +</tr> </tbody> | 2 |
001247 | req-11 |
+Table should have title | <table id="req-11" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ011</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/conf-class-single-req-class</strong> <br/> +A Conformance class SHALL explicitly test only requirements from a single +requirements class.</td> +</tr> </tbody> | 2 |
001259 | req-12 |
+Table should have title | <table id="req-12" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ012</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/con-class-dependencies</strong> <br/> +A Conformance class SHALL specify any other conformance class upon which it is +dependent and that other conformance class shall be used to test the specified +dependency.</td> | 2 |
001295 | req-13 |
+Table should have title | <table id="req-13" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ013</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/imported-requirements-class</strong> <br/> </td> +</tr> <tr> <td valign="middle" align="center">A</td> +<td valign="middle" align="left">If a requirements class is imported from another standard for use within a +standard conformant to the ModSpec, and if any imported requirement is | 2 |
001312 | req-14 |
+Table should have title | <table id="req-14" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ014</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/all-classes-explicitly-named</strong> <br/> +For the sake of consistency and readability, all requirements classes and all +conformance test classes <em>SHALL</em> be explicitly named, with corresponding requirements +classes and conformance test classes having similar names.</td> | 2 |
001330 | req-15 |
+Table should have title | <table id="req-15" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ015</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/req-in-only-one-rec-class</strong> <br/> </td> +</tr> <tr> <td valign="middle" align="center">A</td> +<td valign="middle" align="left">Each requirement in the standard <em>SHALL</em> be contained in one and only one +requirements class.</td> | 2 |
001345 | rec-2 |
+Table should have title | <table id="rec-2" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REC002</strong> </td> +<td valign="middle" align="left"> <strong>/rec/core/parallel-structure</strong> <br/> +If possible, the structure of the normative clauses of the standard <em>SHOULD</em> +parallel the structure of the conformance classes in the conformance clause.</td> +</tr> </tbody> | 2 |
001359 | req-16 |
+Table should have title | <table id="req-16" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ016</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/co-dependent-requirements</strong> <br/> </td> +</tr> <tr> <td valign="middle" align="center">A</td> +<td valign="middle" align="left">If any two requirements are co-dependent (each +dependent on the other) then they shall be in the same requirements class.</td> | 2 |
001374 | rec-3 |
+Table should have title | <table id="rec-3" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REC003</strong> </td> +<td valign="middle" align="left"> <strong>/rec/core/circular-dependencies</strong> <br/> +Circular dependencies of all types should be avoided whenever possible.</td> +</tr> </tbody> +</table> | 2 |
001380 | req-17 |
+Table should have title | <table id="req-17" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REQ017</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/structure-requirements-classes</strong> <br/> +There <em>SHALL</em> be a natural structure to the requirements classes so that each may be +implemented on top of any implementations of its dependencies and independent of its +extensions.</td> | 2 |
001401 | req-18 |
+Table should have title | <table id="req-18" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ018</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/requirements-and-dependencies</strong> <br/> +No requirements class <em>SHALL</em> redefine the requirements of its dependencies, unless +that redefinition is for an entity derived from but not contained in those +dependencies.#</td> | 2 |
001431 | req-19 |
+Table should have title | <table id="req-19" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ019</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/profile-conformance</strong> <br/> +The conformance tests for a profile of a standard <em>SHALL</em> be defined as the +union of a list of conformance classes that are to be satisfied by that profile’s +standardization targets.</td> | 2 |
001442 | req-20 |
+Table should have title | <table id="req-20" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ020</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/core-requirements-separate</strong> <br/> +Every standard <em>SHALL</em> define and identify a core set of requirements as a +separate conformance class.</td> +</tr> </tbody> | 2 |
001449 | req-21 |
+Table should have title | <table id="req-21" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ021</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/requirements-and-dependencies</strong> <br/> +All general recommendations <em>SHALL</em> be in the core.</td> +</tr> </tbody> +</table> | 2 |
001455 | req-22 |
+Table should have title | <table id="req-22" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ022</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/requirements-and-dependencies</strong> <br/> </td> +</tr> <tr> <td valign="middle" align="center">A</td> +<td valign="middle" align="left">Every other requirements class in a standard <em>SHALL</em> a standardization +target type which is a subtype of that of the core</td> | 2 |
001465 | rec-4 |
+Table should have title | <table id="rec-4" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REC004</strong> </td> +<td valign="middle" align="left"> <strong>/rec/core/simple-core</strong> <br/> +The core <em>SHOULD</em> be as simple as possible.</td> +</tr> </tbody> +</table> | 2 |
001471 | per-8 |
+Table should have title | <table id="per-8" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER008</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/core-type</strong> <br/> +The core <em>MAY</em> be partially or totally abstract.</td> +</tr> </tbody> +</table> | 2 |
001477 | per-9 |
+Table should have title | <table id="per-9" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER009</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/req-class-another-standard</strong> <br/> +The core requirements class <em>MAY</em> be a conformance class in another standard.</td> +</tr> </tbody> +</table> | 2 |
001483 | rec-5 |
+Table should have title | <table id="rec-5" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>REC005</strong> </td> +<td valign="middle" align="left"> <strong>/rec/core/optional-tests</strong> <br/> +If a requirements class is from another standard, the current standard <em>SHOULD</em> identify any optional tests +in that conformance class that are required by the current standard’s core requirements class. See <xref target="req-13"/>.</td> +</tr> </tbody> | 2 |
001494 | per-10 |
+Table should have title | <table id="per-10" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="left"> <strong>PER010</strong> </td> +<td valign="middle" align="left"> <strong>/per/core/core-maybe-recommendations</strong> <br/> +Since the basic concept of some standards is mechanism not implementation, the core <em>MAY</em> contain only +recommendations, and include no requirements.</td> +</tr> </tbody> | 2 |
001516 | req-23 |
+Table should have title | <table id="req-23" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ023</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/core-and-extensions</strong> <br/> +Each standard conformant to the ModSpec <em>SHALL</em> consist of the core and some +number of requirements classes defined as extensions to that core.</td> +</tr> </tbody> | 2 |
001523 | req-24 |
+Table should have title | <table id="req-24" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ024</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/extensions-conformant-to-the-modspec</strong> <br/> +A standard conformant to the ModSpec <em>SHALL</em> require all conformant extensions +to itself to be conformant to the ModSpec.</td> +</tr> </tbody> | 2 |
001536 | req-25 |
+Table should have title | <table id="req-25" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ025</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/restriction-of-extensions</strong> <br/> +A standard conformant to the ModSpec <em>SHALL</em> never restrict in any manner +future, logically valid extensions of its standardization targets.</td> +</tr> </tbody> | 2 |
001558 | req-26 |
+Table should have title | <table id="req-26" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ026</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/optional requirements</strong> <br/> +The only conditional requirements acceptable in a standard conformant with the ModSpec <em>SHALL</em> be expressible as a list of conformance classes to be passed.</td> +</tr> </tbody> +<note id="_61c51519-40a9-ed25-ac7f-d2adfcfd7889"> <p id="_f4e6c737-d2a3-6ebb-edeb-2251c9e710a5">Standards and implementations are restricted by this, but not instances of | 2 |
001576 | req-27 |
+Table should have title | <table id="req-27" width="90%"> <colgroup> <col width="25%"/> <col width="75%"/> </colgroup> <tbody> <tr> <td valign="middle" align="center"> <strong>REQ027</strong> </td> +<td valign="middle" align="left"> <strong>/req/core/req-class-overlap-by-reference</strong> <br/> +The common portion of any two requirements classes <em>SHALL</em> consist only of references +to other requirements classes.</td> +</tr> </tbody> | 2 |
002095 | annex-B |
+Hanging paragraph in clause | <annex id="annex-B" obligation="normative"> +<title>OGC Only: Changes required in the OGC Standards</title> +<note id="_b37e62e1-9150-ac84-bf8a-eed002ecf6da"> <p id="_26a1a2db-74fd-baf5-c5e0-85ca8d2b73eb">The following is for OGC Standards and Abstract Specifications only: No changes are required to existing OGC Standards</p> +</note> + | 2 |
002178 | fig-C-1 |
+Figure should have title | <figure id="fig-C-1"> + <image src="" mimetype="image/png" id="_86514e24-a06f-0af0-53d1-1268764bafac" height="auto" width="auto"/> +</figure> | 2 |
002613 | _f13846da-3c06-cda0-02ad-cf27c2daf5e2 |
+Table should have title | <table id="_f13846da-3c06-cda0-02ad-cf27c2daf5e2" unnumbered="true"> <tbody> <tr> <th valign="middle" align="center">Person</th> +<th valign="middle" align="center">Organization Represented</th> +</tr> <tr> <td valign="middle" align="left">Simon Cox</td> +<td valign="middle" align="left">CSIRO</td> +</tr> <tr> <td valign="middle" align="left">David Danko</td> | 2 |
Line | ID | +Message | Context | Severity | + +
---|---|---|---|---|
-- |
+Draft is not a recognised status | 2 |
Line | ID | +Message | Context | Severity | + +
---|---|---|---|---|
XML Line 000004:42 |
+attribute "format" not allowed here; expected attribute "locale", "script" or "type" | 2 | ||
XML Line 000005:148 |
+character content of element "on" invalid; must be a string matching the regular expression "([\+\-]?\d{4})((-?)((0[1-9]|1[0-2])((-?)([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-2])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6]))))?" | 2 | ||
XML Line 000005:194 |
+character content of element "on" invalid; must be a string matching the regular expression "([\+\-]?\d{4})((-?)((0[1-9]|1[0-2])((-?)([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-2])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6]))))?" | 2 | ||
XML Line 000017:144 |
+character content of element "subdoctype" invalid; must be equal to "conceptual-model", "conceptual-model-and-encoding", "conceptual-model-and-implementation", "encoding", "extension", "general", "implementation", "profile" or "profile-with-extension" | 2 | ||
XML Line 000068:82 |
+element "clause" not allowed here; expected the element end-tag or element "submitters" | 2 | ||
XML Line 000075:66 |
+element "clause" not allowed here; expected the element end-tag or element "submitters" | 2 | ||
XML Line 000087:71 |
+element "clause" not allowed here; expected the element end-tag or element "submitters" | 2 | ||
XML Line 000103:66 |
+element "clause" not allowed here; expected the element end-tag or element "submitters" | 2 | ||
XML Line 000106:61 |
+element "clause" not allowed here; expected the element end-tag or element "submitters" | 2 | ||
XML Line 000115:58 |
+element "clause" not allowed here; expected the element end-tag or element "submitters" | 2 | ||
XML Line 000123:102 |
+element "clause" not allowed here; expected the element end-tag or element "submitters" | 2 | ||
XML Line 000162:52 |
+element "clause" not allowed here; expected the element end-tag or element "admonition", "amend", "bookmark", "columnbreak", "dl", "example", "figure", "form", "formula", "hr", "imagemap", "note", "ol", "p", "pagebreak", "passthrough", "permission", "pre", "quote", "recommendation", "requirement", "review", "sourcecode", "svgmap", "table", "toc" or "ul" | 2 | ||
XML Line 000183:65 |
+element "clause" not allowed here; expected the element end-tag or element "admonition", "amend", "bookmark", "columnbreak", "dl", "example", "figure", "form", "formula", "hr", "imagemap", "note", "ol", "p", "pagebreak", "passthrough", "permission", "pre", "quote", "recommendation", "requirement", "review", "sourcecode", "svgmap", "table", "toc" or "ul" | 2 | ||
XML Line 000569:112 |
+element "strong" not allowed here; expected element "eref", "erefstack", "refterm", "renderterm", "termref" or "xref" | 2 | ||
XML Line 000569:229 |
+element "concept" incomplete; expected element "eref", "erefstack", "refterm", "renderterm", "termref" or "xref" | 2 | ||
XML Line 000584:109 |
+element "strong" not allowed here; expected element "eref", "erefstack", "refterm", "renderterm", "termref" or "xref" | 2 | ||
XML Line 000584:245 |
+element "concept" incomplete; expected element "eref", "erefstack", "refterm", "renderterm", "termref" or "xref" | 2 | ||
XML Line 001089:11 |
+element "example" incomplete; expected element "dl", "figure", "formula", "ol", "p", "quote", "sourcecode" or "ul" | 2 | ||
XML Line 002112:129 |
+element "concept" incomplete; expected element "eref", "erefstack", "refterm", "renderterm", "termref" or "xref" | 2 | ||
XML Line 002112:18 |
+element "strong" not allowed here; expected element "eref", "erefstack", "refterm", "renderterm", "termref" or "xref" | 2 | ||
XML Line 002531:74 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002533:74 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002537:74 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002539:74 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002545:75 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002547:74 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002549:68 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002552:257 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002554:146 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002556:215 |
+element "link" missing required attribute "target" | 2 | ||
XML Line 002556:82 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002557:217 |
+element "link" missing required attribute "target" | 2 | ||
XML Line 002557:82 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002559:75 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002561:74 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002563:74 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002565:68 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002570:256 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002572:144 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002575:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 | ||
XML Line 002578:295 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002579:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002581:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 | ||
XML Line 002584:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 | ||
XML Line 002587:295 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002588:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002590:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 | ||
XML Line 002597:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 | ||
XML Line 002603:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 | ||
XML Line 002609:75 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002611:74 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002613:74 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002615:68 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002620:256 |
+attribute "format" not allowed here; expected attribute "language", "locale" or "script" | 2 | ||
XML Line 002622:146 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002623:110 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002625:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 | ||
XML Line 002628:294 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002629:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002630:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002631:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002632:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002633:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002634:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002635:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002636:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002637:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002638:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002640:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 | ||
XML Line 002642:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 | ||
XML Line 002645:294 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002646:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002647:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002648:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002649:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002650:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002651:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002652:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002653:97 |
+found attribute "format", but no attributes allowed here | 2 | ||
XML Line 002655:28 |
+attribute "format" not allowed here; expected attribute "language", "locale", "script" or "type" | 2 |
This OGC member developed and approved document defines a model and related requirements and recommendations for writing and structuring modular standards documents. Further, this model is designed to enable the consistent and verifiable testing of implementations of a standard that claim conformance.
The goal is to ensure that a standard specifies requirements in a common and consistent manner and that these requirements are testable.
NOTE 1: For OGC only: Any new OGC Standard, abstract specification that contains requirements, or major revision of an existing OGC Standard shall comply with the requirements stated in this document.
NOTE 2: Historically, this document has been known and abbreviated as the “ModSpec”. For continuity and ease of understanding this document may also be refered to as the “OGC ModSpec”.
Suggested additions, changes, and comments on this this document are welcome and +
This OGC member developed and approved document, referred to as the ModSpec, defines a model and related requirements and recommendations for writing and structuring modular standards documents. Further, this model is designed to enable the consistent and verifiable testing of implementations of a standard that claim conformance.
The goal is to ensure that a standard specifies requirements in a common and consistent manner and that these requirements are testable.
NOTE: Historically, this document has been known and abbreviated as the “ModSpec”. For continuity and ease of understanding this document may also be refered to as the “OGC ModSpec”.
Suggested additions, changes, and comments on this this document are welcome and encouraged. Such suggestions may be submitted through the OGC Change Request System -(http://www.opengeospatial.org/standards/cr) or by creating an issue in the GitHub repository for this document (https://github.com/opengeospatial/ogc-modspec).
No security considerations have been made for this document.
The following organizations submitted this Document to the Open Geospatial Consortium (OGC):
This document uses the standard terms defined in Subclause 5.3 of [OGC 05-008], which +(http://ogc.standardstracker.org/) or by creating an issue in the OGC ModSpec GitHub repository (https://github.com/opengeospatial/ogc-modspec).
No security considerations have been made for this document.
The following organizations submitted this Document to the Open Geospatial Consortium (OGC):
This document uses the standard terms defined in Subclause 5.3 of [OGC 05-008], which is based on the ISO/IEC Directives, Part 2. Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the imperative verb form used to indicate a requirement to be strictly followed to -conform to this standard.
The following OGC Members participated in editing this document:
Person | Organization Represented |
---|---|
Carl Reed | Carl Reed & Associates |
Chuck Heazel | Heazeltech |
The following OGC Members contributed and particpated in developing Version 2 of the ModSpec.
Person | Organization Represented |
---|---|
Simon Cox | CSIRO and OGC Fellow |
Chuck Heazel | Heazeltech |
Clemens Portele | interactive instruments GmbH |
Jeff Yutzler | ImageMatters |
This is the second normative version of this document.
Improvements to this document will be made based on implementation and changing technical requirements. Planned extensions include:
ModSpec Part providing requirements and recommendations for specifying requirements and conformance tests using RDFS, SHACL, and OWL.
+conform to the ModSpec.The following OGC Members participated in editing this document:
Person | Organization Represented |
---|---|
Carl Reed | Carl Reed & Associates |
Chuck Heazel | Charles Heazel |
The following OGC Members contributed and particpated in developing Version 2 of the ModSpec.
Person | Organization Represented |
---|---|
Simon Cox | CSIRO and OGC Fellow |
Chuck Heazel | Charles Heazel |
Clemens Portele | interactive instruments GmbH |
Jeff Yutzler | ImageMatters |
This is the second normative version of this document.
Improvements to this document will be made based on implementation and changing technical requirements. Planned extensions include:
ModSpec Part providing requirements and recommendations for specifying requirements and conformance tests using RDFS, SHACL, and OWL.
ModSpec Part providing requirements and recommendations for specifying requirements and conformance tests using JSON.
This OGC document (aka the ModSpec) specifies a formal structure for standards documents but does not supply -specific content. Where possible, this document is conformant with itself (with respect to the core conformance test class, [cls-6] -and the Conformance Test Suite Annex A.1).
Attention is drawn to the possibility that some of the elements of this document may be the subject of patent rights. The Open Geospatial Consortium Inc. shall not be held responsible for identifying any or all such patent rights.
Recipients of this document are requested to submit, with their comments, notification of any relevant patent claims or other intellectual property rights of which they may be aware that might be infringed by any implementation of the standard set forth in this document, and to provide supporting documentation.
The following OGC Members were key contributors to Version 1 of the ModSpec
Person | Organization Represented |
---|---|
Simon Cox | CSIRO |
David Danko | ESRI |
James Greenwood | SeiCorp, Inc. |
John R. Herring | Oracle USA |
Andreas Matheus | University of the Bundeswehr — ITS |
Richard Pearsall | US National Geospatial-Intelligence Agency (NGA) |
Clemens Portele | interactive instruments GmbH |
Barry Reff | US Department of Homeland Security (DHS) |
Paul Scarponcini | Bentley Systems, Inc. |
Arliss Whiteside | BAE Systems — C3I Systems |
The ModSpec defines characteristics and structure for the specification of Standards +
The OGC ModSpec — A Standard for Designing and Writing Modular Standards specifies a formal structure and requirements for writing modular standards documents. However, the ModSpec does not supply specific content. Where possible, this document is conformant with itself (with respect to the core conformance test class, [cls-6] +and the Conformance Test Suite Annex A.1).
Attention is drawn to the possibility that some of the elements of this document may be the subject of patent rights. The Open Geospatial Consortium Inc. shall not be held responsible for identifying any or all such patent rights.
Recipients of this document are requested to submit, with their comments, notification of any relevant patent claims or other intellectual property rights of which they may be aware that might be infringed by any implementation of the standard set forth in this document, and to provide supporting documentation.
This OGC Standard for Designing and Writing Modular Standards, also known as the ModSpec:
Specifies rules for the internal structure and organization of a standard.
+Defines requirements for specifying the structure of a standards document as organized sets of criteria, those that are to be tested (“requirements”) and those that are not tested (“recommendations” and “permissions”).
+Is designed to enable the clear and concise specification of requirements (the shalls or musts in a standard) that fully supports the ability to define implementable conformance tests.
+Formalizes implementing the requirements specified in the ModSpec so that reusable, modular standards can be developed.
+The standardization goal of the ModSpec is to define characteristics and a structure for the specification of modular and testable Standards that will encourage implementation by minimizing difficulty determining -requirements, mimicking implementation structure and maximizing usability and -interoperability.
NOTE: For OGC Standards work, the word “standard” in this document applies to all OGC draft standards, approved standards, draft Abstract Specifications, and approved Abstract Specifications. The exceptions are OGC Abstract Specifications that originate in ISO or Community Standards that are developed external to the OGC and then submitted to the OGC.
[Annex-B] defines the UML model upon which the ModSpec is -based. Annex B also contains informal and non-normative definitions ordered for ease +requirements, mimicking implementation structure, and maximizing usability and +interoperability. The ultimate goal of this approach is to enable interoperable implementations of a standard to be tested and deemed conformant or not.
Therefore, a standard that follows the rules specified in the ModSpec presents requirements organized in requirements classes which must be satisfied by passing the tests defined in a conformance suite (also known as the Abstract Test Suite in an OGC Standard). These tests are organized into conformance classes, each of which represents a mechanism for partial satisfaction of the standard. This results in a standard having a modular structure, where each requirements class has a corresponding conformance (test) class. In a well written standard, the normative clauses and any model or schema are organized in a manner that parallels the requirements and conformance clauses. A goal of the design pattern is the ability to define requirements classes and associated conformance classes that can be used across multiple standards. The approach modelled in the ModSpec has been referred to as the “core and extension model” due to its insistence on a modular structure throughout all parts of a standard and its implementation.
There are numerous examples of requirements/conformance classes that can be used not only in OGC Standards, but for geospatially focused standards defined by other organizations and Standards Development Organizations (SDOs). Some OGC examples can be found in the OGC API — Common Part 1: Core Standard and in the CDB 2.0 Standard CRS Requirements Module. By formally implementing the requirements specified in the ModSpec, reusable, testable, modular standards can be developed.
Reading the Terms and Definitions clause and Clause cls-4 will help understanding the content and +requirements stated in this document.
+ +annex-C defines the UML model upon which the ModSpec is +based. Annex C also contains informal and non-normative definitions ordered for ease of understanding. These two sections can be read first to aid in the understanding of -the rest of the document.
Conformance to the ModSpec by technical implementation standards -can be tested by inspection. The test suite is in Annex A.
There are five (5) conformance classes for this document:
Standards documents in general (the core) — see [cls-6] and Annex A.1
+the rest of the document.NOTE 1: For OGC Standards work, the word “standard” in the ModSpec applies to all OGC draft standards, approved standards, draft Abstract Specifications, and approved Abstract Specifications. The exceptions are OGC Abstract Specifications that originate in ISO or Community Standards that are developed external to the OGC and then submitted to the OGC.
NOTE 2: Please note that the ModSpec has been approved by the OGC Membership as a policy directive for the development and revision of any OGC Standard or Abstract Specification that has requirements. However, the ModSpec is written to be non-OGC specific and can be used by any Standards Development Organization (SDO) as a formal guide for structuring a standards document.
NOTE 3: In informative sections, the word “will” implies that something is an implication of a requirement. The “will” statements are +not requirements, but explain the consequence of requirements.
Version 2.0 of the ModSpec is split into a Core standard and multiple Parts. These are:
+ +Core: contains all the core requirements and informational text that define the model and internal structure of a standard.
Standards using UML to state requirements, extending the core — see -Clause 10.2.2 and Annex A.2
+Part 1: UML Model requirements
Standards using XML schema to state requirements, extending the core — see -Clause 10.2.3 and Annex A.3
+Part 2: XML and Schematron Model requirements
+Future Parts to the ModSpec Standard may include:
+ +Part 3: RDF/OWL requirements
Standards using Schematron to state requirements, extending XML schema — see -Clause 10.2.4 and Annex A.4
+Part 4: JSON Schema
Standards defining requirement for a new category of XML schemas, extending -the core, whose target XML schemas must be conformant with the XML schema conformance -class above — see Clause 10.2.5 and Annex A.5.
+Conformance to the ModSpec by technical implementation standards +can be tested by inspection. The test suite is in Annex A.
There is one conformance class for this document:
This document contains normative language and thus places requirements on +
This document contains normative language and thus places requirements on conformance, or mechanism for adoption, of candidate standards to which the ModSpec -applies. In particular:
[cls-6] specifies the core requirements which shall be met by all conformant +applies. In particular:
[cls-6] specifies the core requirements which shall be met by all conformant standards.
Clause 10 gives information on how the ModSpec is to be applied to requirements, -conformance clauses, UML models, or XML Schemas.
+Clause 9 gives information on how the ModSpec is to be applied to extensions to the core model for requirements and +conformance clauses.
The various subclauses of Clause 10 list requirements partially derived from the -core, but more specific to the conditions where a data model expressed in one of the -specified languages (UML or XML) is involved. These requirements classes are -extensions of the core presented in [cls-6].
The following documents are referred to in the text in such a way that some or all of their content constitutes requirements of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies.
+Such extensions are defined in additional Parts (volumes) to the Core.
The following documents are referred to in the text in such a way that some or all of their content constitutes requirements of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies.
ISO/IEC: ISO/IEC 10000-1, ISO, IEC
ISO/IEC DIR 2, ISO/IEC Directives, Part 2. https://www.iso.org/sites/directives/current/part2/index.xhtml.
-ISO: ISO 19105, Geographic information — Conformance and testing. International Organization for Standardization, Geneva https://www.iso.org/standard/76457.html.
-ISO/IEC: ISO/IEC 19501, Information technology — Open Distributed Processing — Unified Modeling Language (UML) Version 1.4.2. International Organization for Standardization, International Electrotechnical Commission, Geneva https://www.iso.org/standard/32620.html.
-OMG Unified Modeling Language (OMG UML), Infrastructure, V2.1.2, OMG Document Number: formal/2007-11-04, Standard document URL: http://www.omg.org/spec/UML/2.1.2/Infrastructure/PDF
-OMG Unified Modeling Language (OMG UML), Superstructure, V2.1.2, OMG Document Number: formal/2007-11-02; Standard document URL: http://www.omg.org/spec/UML/2.1.2/Superstructure/PDF
+ISO: ISO 19105:2022, Geographic information — Conformance and testing. International Organization for Standardization, Geneva (2022). https://www.iso.org/standard/76457.html.
+OMG Unified Modeling Language (OMG UML), Infrastructure, V2.5, OMG Document Number: formal/2015-03-01, Standard document URL: https://www.omg.org/spec/UML/2.5
+OMG Unified Modeling Language (OMG UML), Superstructure, V2.4.1, OMG Document Number: formal/2012-05-07; Standard document URL: https://www.omg.org/spec/UML/ISO/19505-2/PDF
ISO/IEC: ISO/IEC 19757-3:2006, Information technology — Document Schema Definition Languages (DSDL) — Part 3: Rule-based validation — Schematron. International Organization for Standardization, International Electrotechnical Commission, Geneva (2006). https://www.iso.org/standard/40833.html.
W3C: W3C xmlschema-1, XML Schema Part 1: Structures Second Edition. World Wide Web Consortium https://www.w3.org/TR/xmlschema-1/.
W3C: W3C xmlschema-2, XML Schema Part 2: Datatypes Second Edition. World Wide Web Consortium https://www.w3.org/TR/xmlschema-2/.
-For the purposes of this document, the following terms and definitions shall apply. @@ -1592,179 +1601,158 @@ Standard English (common US and UK) meanings. The form of the definitions is defined by ISO Directives.
-Many of these definitions depend upon the model given in [cls-6-1].
- +Many of these definitions depend upon the model given in annex-C.
-XML schema document which includes, either directly or through the inclusion of -other schema documents, all schema components associated to its namespace
+a requirements class or a requirements module with no direct dependencies on other requirements classes or modules and their associated compliance test class or compliance test module.
-a requirements class or a requirements module and their associated compliance test class or compliance test module.
- -evidence of conformance to all or part of a standard, awarded for passing one or -more of the conformance test classes (Clause 4.7) specified in +
evidence of conformance to all or part of a standard, awarded for passing one or +more of the conformance test classes (Clause 4.6) specified in that standard
-Note 1 to entry: “Certificates” do not have to be instantiated documents. Having proof of passing +
Note 1 to entry: “Certificates” do not have to be instantiated documents. Having proof of passing the conformance test class is sufficient. For example, the OGC currently keeps -an online list of conformant applications at https://www.ogc.org/resources/certified-products/.
Each certificate of conformance is awarded to a standardization target (Clause 4.26).
Each certificate of conformance is awarded to a standardization target (Clause 4.26).
test, abstract or real, of a single requirements (Clause 4.21) contained +
test, abstract or real, of a single requirements (Clause 4.21) contained within a standard, or set of standards
-test for a particular requirement or a set of related requirements
- +test for a particular requirement or a set of related requirements
-Note 1 to entry: When no ambiguity, the word “case” may be omitted. i.e. -conformance test (Clause 4.4) is the same as -conformance test case (Clause 4.5).
set of related for against a given requirements module all with the same standardization target
+Note 1 to entry: When no ambiguity, the word “case” may be omitted. i.e. +conformance test is the same as conformance test case.
set of related tests for a given requirements module all with the same standardization target
+Note 1 to entry: When there is no ambiguity, the word “test” may be omitted. i.e. conformance test module +is the same as conformance module. Conformance modules may be nested in a hierarchical way.
Note 1 to entry: When there is no ambiguity, the word “test” may be omitted. i.e. conformance test module (Clause 4.6) -is the same as conformance module. Conformance modules may be nested in a hierarchical way.
[SOURCE: ISO 19105]
+conformance class ALTERNATIVE
-conformance test level ALTERNATIVE
+set of conformance tests that must be passed to receive a single certificate of conformance (Clause 4.2)
-set of term conformance tests, display conformance test not resolved via ID conformance-tests that must be passed to receive a single certificate of conformance (Clause 4.3)
+Note 1 to entry: When no ambiguity is possible, the word “test” may be left out, so conformance test class +maybe called a conformance class.
In the ModSpec, the set of requirements (Clause 4.21) tested by the +conformance tests within a conformance class is a +requirements class and its dependencies. Optional requirements will +be in a separate requirements class (Clause 4.22) with other requirements +that are part of the same option. Each requirements class corresponds to a +separate conformance test class.
Each requirements class will be in a 1 to 1 correspondence to a similarly named +conformance test class (Clause 4.6) that tests all of the requirements in a requirements class.
All requirements (Clause 4.21) in a conformance class will have the same standardization target (Clause 4.26).
Note 1 to entry: When no ambiguity is possible, the word “test” may be left out, so conformance test class (Clause 4.7) -maybe called a conformance class.
In the ModSpec, the set of requirements (Clause 4.21) tested by the -conformance tests within a conformance class is a -requirements class (Clause 4.22) and its dependencies. Optional requirements (Clause 4.21) will -be in a separate requirements class (Clause 4.22) with other requirements (Clause 4.21) -that are part of the same option. Each requirements class (Clause 4.22) corresponds to a -separate conformance class
Each requirements class will be in a 1 to 1 correspondence to a similarly named -conformance class that tests all of the -requirements class’s (Clause 4.22) requirements (Clause 4.21).
All requirements (Clause 4.21) in a conformance class -will have the same standardization target (Clause 4.26).
conformance test suite ALTERNATIVE
abstract test suite ALTERNATIVE
-conformance test suite ALTERNATIVE
abstract test suite ALTERNATIVE
+set of conformance classes that define tests for all requirements of a standard or abstract specification
-set of conformance classes that define tests for all requirements (Clause 4.21) of a standard or abstract specification
+Note 1 to entry: The conformance suite is the union of all conformance classes. It is by definition the +conformance class of the entire standard or abstract specification.
In the ModSpec, each requirement (Clause 4.21) is mandatory within its conformance class and each requirement (Clause 4.21) is tested in at least one conformance test (Clause 4.3).
Note 1 to entry: The conformance suite (Clause 4.8) is the union of all conformance classes. It is by definition the -conformance class of the entire standard or abstract specification.
In this Policy, each requirement (Clause 4.21) is mandatory within its conformance class and each requirement (Clause 4.21) is tested in at least one conformance test (Clause 4.4).
unique requirements class (Clause 4.22) that must be satisfied by any conformant +
unique requirements class (Clause 4.22) that must be satisfied by any conformant standardization targets (Clause 4.26) associated to the standard
-Note 1 to entry: The core requirements class (Clause 4.22) is unique because if it were possible to have +
Note 1 to entry: The core requirements class is unique because if it were possible to have more than one, then each core would have to be implemented to pass any -conformance test class (Clause 4.7), and thus would have to be contained in any other +conformance test class (Clause 4.6), and thus would have to be contained in any other core. The core may be empty, or all or part of another standard or related -set of standards.
The “core” can refer to this requirements class (Clause 4.22), its associated -conformance test class (Clause 4.7) or the software module that implements that +set of standards.
The “core” can refer to this requirements class, its associated +conformance test class (Clause 4.6) or the software module that implements that requirements class.
another requirements class (Clause 4.22) (the dependency) whose requirements (Clause 4.21) are defined to also be -requirements (Clause 4.21) of this -requirements class (Clause 4.22)
- - -Note 1 to entry: A direct dependency (Clause 4.10) -of the current requirements class (Clause 4.22) will have the same -standardization target (Clause 4.26) as the current -requirements class (Clause 4.22). This is another ways of saying that the current -requirements class (Clause 4.22) extends, or uses all the aspects of the - direct dependency (Clause 4.10). -Any tests associated with this -dependency (Clause 4.10) can be applied to this -requirements class (Clause 4.22).
When testing a - direct dependency (Clause 4.10), the -standardization target (Clause 4.26) is directly subject to the test in the specified -conformance test class (Clause 4.7) of the direct dependency (Clause 4.10).
requirements class (Clause 4.22) with a different +
another requirements class (Clause 4.22) (the dependency) whose requirements (Clause 4.21) are defined to also be +requirement(s) of this requirements class
+ + +Note 1 to entry: A direct dependency (of a requirements class) of the current requirements class (Clause 4.22) will have the same +standardization target (Clause 4.26) as the current requirements class. This is another way of saying that the current +requirements class extends, or uses all the aspects of the direct dependency (of a requirements class). +Any tests associated with this direct dependency (of a requirements class) can be applied to this requirements class.
When testing a direct dependency of a requirements class, the standardization target is directly subject to the test in the specified +conformance test class (Clause 4.6) of the direct dependency of a requirements class.
requirements class (Clause 4.22) with a different standardization target (Clause 4.26) which is used, produced or associated to by the implementation of this requirements class (Clause 4.22)
-Note 1 to entry: In this instance, as opposed to the -direct dependency (Clause 4.10), -the test against the consumable or product used +
Note 1 to entry: In this instance, as opposed to the +direct dependency of a requirements class, the test against the consumable or product used or produced by the requirements class (Clause 4.22) does not directly test the -requirements class (Clause 4.22), but tests only its side effects. Hence, a particular +requirements class, but tests only its side effects. Hence, a particular type of feature service could be required to produce valid XML documents, but the test of validity for the XML document is not directly testing the service, but only indirectly testing the validity of its output. - Direct dependencies (Clause 4.10) -test the same standardization target (Clause 4.26), but - indirect dependencies (Clause 4.11) -test related but different standardization targets (Clause 4.26).
For example, if a DRM-enabled service is required +Direct dependencies test the same standardization target (Clause 4.26), but +indirect dependencies}} test related but different standardization target,standardization targets.
For example, if a DRM-enabled service is required to have an association to a licensing service, then the requirements of a licensing service are indirect requirements for the DRM-enabled service. Such a requirement may be stated as the associated licensing service has a -certificate of conformance (Clause 4.3) of a particular kind.
requirements class (Clause 4.22) which has a - direct dependency (Clause 4.10) on another -requirements class (Clause 4.22)
+requirements class (Clause 4.22) which has a direct dependency on another requirements class
-Note 1 to entry: Here extension (Clause 4.12) is -defined on requirements class (Clause 4.22) so that their implementation may be -software extensions in a manner analogous to the extension relation between the -requirements classes (Clause 4.22).
Note 1 to entry: Here an extension of a requirements class is defined on requirements class so that their implementation may be +software extensions in a manner analogous to the extension relation between the requirements classes.
recommendation applying to all entities in a standard
+recommendation applying to all entities in a standard
-official statement of a requirement (Clause 4.21) or recommendation (Clause 4.20) that is the +
official statement of a requirement (Clause 4.21) or recommendation (Clause 4.20) that is the precedent for any other version repeated or rephrased elsewhere in a standard
-Note 1 to entry: Explanatory text associated with normative language often repeats or rephrases the +
Note 1 to entry: Explanatory text associated with normative language often repeats or rephrases the requirement to aid in the discussion and understanding of the official version of the normative language. Since such restatements are often less formal than the original source and potentially subject to alternate interpretation, it is important to know the location of the home official version of the language.
abstract model ALTERNATIVE
conceptual model ALTERNATIVE
+abstract model ALTERNATIVE
conceptual model ALTERNATIVE
-theoretical construct that represents something, with a set of variables and a +
theoretical construct that represents something, with a set of variables and a set of logical and quantitative relationships between them.
-one of a set of separate parts that can be joined together to form a larger object
+one of a set of separate parts that can be joined together to form a larger object
+ + +An optional requirements class may or may not be implemented or specified in a profile or extension. However, if a profile, extension, or implementation specifies the use of an optional requirements class, then every requirement in that requirements class shall be implemented.
-An optional requirements class may or may not be implemented or specified in a profile or extension. However, if a profile, extension, or implementation specifies the use of an optional requirements class, then every requirement in that requirements class shall be implemented.
+Collection of requirements that are parts to a requirement. Satisfaction of all requirement parts are necessary for this requirement to be satisfied. The use of parts is optional.
specification or standard consisting of a set of references to one or more base standards and/or other profiles, and the identification of any chosen -conformance test classes (Clause 4.7), +conformance test classes (Clause 4.6), conforming subsets, options and parameters of those base standards, or profiles necessary to accomplish a particular function.
@@ -1800,9 +1788,9 @@Note 1 to entry: Although using normative language, a recommendation (Clause 4.20) is not +
Note 1 to entry: Although using normative language, a recommendation is not a requirement (Clause 4.21). The usual form replaces the “shall” (imperative or -command) of a requirement (Clause 4.21) with a “should” (suggestive or +command) of a requirement with a “should” (suggestive or conditional).
Note 2 to entry: Recommendations are not tested and therefor have no related conformance test.
[SOURCE: ISO/IEC DIR 2]
Note 1 to entry: Each requirement (Clause 4.21) is a normative criterion for a single -type of standardization target. In the ModSpec, requirements are -associated to conformance tests (Clause 4.4) that can be used to prove -compliance to the underlying criteria by the standardization target (Clause 4.26).
The implementation of a requirement (Clause 4.21) is dependent on the type of +
Note 1 to entry: Each requirement is a normative criterion for a single type of standardization target. In the ModSpec, requirements are +associated to conformance tests (Clause 4.3) that can be used to prove +compliance to the underlying criteria by the standardization target (Clause 4.26).
The implementation of a requirement is dependent on the type of standard being written. A data standard requires data structures, but a procedural standard requires software implementations. The view of a -standard in terms of a set of testable requirements (Clause 4.21) allows us to -use set descriptions of both the standard and its implementations.
Requirements (Clause 4.21) use normative language and are -commands and use the imperative “shall” or similar imperative constructs. +standard in terms of a set of testable requirements allows for +using set descriptions of both the standard and its implementations.
Requirements use normative language and are commands and use the imperative “shall” or similar imperative constructs. Statements in standards which are not requirements and need to be either conditional or future tense normally use “will” and should not be confused with requirements that use “shall” imperatively.
[SOURCE: ISO/IEC DIR 2]
aggregate of all term requirements, display requirement not resolved via ID requirements with a single standrdization target that -must all be satisfied to pass a conformance test class (Clause 4.7)
+must all be satisfied to pass a conformance test class (Clause 4.6)Note 1 to entry: There is some confusion possible here, since the testing of indirect @@ -1844,34 +1830,34 @@
document containing recommendations (Clause 4.20), -requirements (Clause 4.21) and conformance tests (Clause 4.4) for +requirements (Clause 4.21) and conformance tests (Clause 4.3) for those requirements (Clause 4.21)
-Note 1 to entry: This definition is included for completeness. See Clause 7.4.
This does not restrict what else a standard may contain, as long as it does -contain the three types of element cited.
Note 1 to entry: This definition is included for completeness.
Note 2 to entry: In the OGC, there are Abstract Specifications and Implementation Standards. Abstract Specifications may or may not be +testable. Further, Abstract Specifications may not be directly implementable. +Implementatins Standards are always testable and contain a conformance test suite (Clause 4.7).
document that has been approved by a legitimate Standards Body
-Note 1 to entry: This definition is included for completeness. Standard (Clause 4.25) and -specification (Clause 4.24) can apply to the same document. While specification (Clause 4.24) is -always valid, standard (Clause 4.25) only applies after the adoption of the document by a +
Note 1 to entry: This definition is included for completeness. Standard (Clause 4.25) and +specification (Clause 4.24) can apply to the same document. While specification is +always valid, standard only applies after the adoption of the document by a legitimate standards organization.
entity to which some requirements (Clause 4.21) of a standard (Clause 4.25) apply
- - -Note 1 to entry: The standardization target (Clause 4.26) is the entity which may receive a -certificate of conformance (Clause 4.3) for a requirements class (Clause 4.22).
Note 2 to entry: Need to add examples! The standardization target of the CDB version 2.0 CRS Requirements Classes is to ensure that an implementation clearly defines (with metadata) the CRS for a CDB compliant datastore.
Note 1 to entry: The standardization target is the entity which may receive a +certificate of conformance (Clause 4.2) for a requirements class (Clause 4.22).
type of entity or set of entities to which the requirements (Clause 4.21) of a -standard (Clause 4.25) apply
+type of entity or set of entities to which the requirements (Clause 4.21) of a standard (Clause 4.25) apply
Note 1 to entry: For example, the standardization target type for The OGC API – Features Standard are Web APIs. The standardization target type for the CDB Standard is “datastore”. It is important to understand that a standard’s root standardization target type and can have sub-types and that there can be a hierarchy of target types. For example, a Web API can have sub types of client, server, security, and so forth. As such, each requirements class can have a standardization target type that is a sub-type of the root.
Note 1 to entry: Includes all statements in a document not part of the normative -requirements (Clause 4.21), -recommendations (Clause 4.20) or - conformance tests (Clause 4.4). Included for completeness.
[SOURCE: ISO/IEC DIR 2]
-NOTE 1: Reading the Terms and Definitions clause and Clause <TBD> will help understanding the content and -requirements stated in this document.
This OGC document, also known as the ModSpec:
Specifies rules for the internal structure and organization of a standard.
-Defines requirements for specifying the structure of a standards document as organized sets of criteria, those that are to be tested (“requirements”) and those that are not tested (“recommendations” and “permissions”).
-Designed to enable the clear and concise specification of requirements (the shalls or musts in a standard) that fully supports the ability to define implementable conformance tests.
-The goal of this approach is to enable implementations of a standard to be tested and deemed conformant or not.
NOTE 2: Please note that the ModSpec has been approved by the OGC Membership as a policy directive for the development and revision of any OGC Standard or Abstract Specification that has requirements. However, the ModSpec is written to be non-OGC specific and can be used by any Standards Development Organization (SDO) as a formal guide for structuring a standards document.
A standard that follows the rules specified in the ModSpec presents requirements organized in requirements classes which must be satisfied by passing the tests defined in a conformance suite (also known as the Abstract Test Suite in an OGC Standard). These tests are organized into conformance classes, each of which represents a mechanism for partial satisfaction of the standard. This results in a standard having a modular structure, where each requirements class has a corresponding conformance (test) class. In a well written standard, the normative clauses and any model or schema are organized in a manner that parallels the requirements and conformance clauses. A goal of the design pattern is the ability to define requirements classes and associated conformance classes that can be used across multiple standards.
There are numerous examples of requirements/conformance classes that can be used not only in OGC Standards, but for geospatially focused standards defined by other organizations and Standards Development Organizations (SDOs). Some OGC examples can be found in the OGC API — Common Part 1: Core Standard and in the CDB 2.0 Standard CRS Requirements Module. By formally implementing the requirements specified in the ModSpec, reusable, modular standards can be developed.
In the conformance test suite there will be a test defined to verify the validity of -the claim that an implementation of the standard (standardization target) satisfies -each mandatory requirement specified in the standard. Since the normative language of the body of the standard and the -conformance test classes both define what conformance to the standard means, they -will be equivalent in a well-written standard. The ModSpec requires -a standards document to be well-written, at least in stating requirements and conformance -tests.
- -Conformance tests are aggregated into conformance classes that specify how certain -“certificates of conformance” are achieved. The natural inclination is to aggregate -the requirements. The issue that blocks this approach is that some requirements are -optional while others are mandatory. To achieve a cleaner separation of requirements, -the ModSpec separates them into sets (called “requirements classes”), each of which -has no optional components. Since the normative statement of each requirement is only -declared once and is uniquely identified as such, each requirement will be in a clause associated to its requirements class.
- -Therefore, the ModSpec defines a “requirements class” as a set of requirements that must -all be passed to achieve a particular conformance class (see -Clause 4.7). This document also includes a “middle” structure -called a conformance test module. Requirements modules -parallel the conformance test modules. A standard written to the ModSpec may -use this “module” structure in any manner consistent with the rest of this Policy.
- -A standard may have mandatory and optional requirements classes. This allows the options -in the testing procedure to be grouped into non-varying mandatory and optional conformance classes. -Each requirement within an optional requirements class is mandatory when that requirements class is -implemented. When needed, a particular requirements class may contain only a single -requirement.
- -However, care must be taken, since the requirements classes may not always in a one-to-one -correspondence to conformance classes in other standards which may be the source of -requirements for a standard conformant to this Policy. If other standards are -used, their options shall be specified to be useable within a standard conformant to -this policy, see Clause 9.4.1.
- -Conformance classes may contain dependencies on one another. These are represented by -tests in one conformance class that state that another conformance class must be -passed to qualify to pass this conformance class. In terms of requirements, that says -that the dependent conformance class contains tests (by reference) for all -requirements of the “included” conformance class.
- -As defined in the ModSpec, one requirements -class is dependent on another if the other is included through such a reference. In -this manner, requirements classes can be treated as sets of requirements (each in a -single requirements class but included in others by reference to its “home” -requirements class).
- -In the ModSpec, each conformance requirement is separated in its own labeled -paragraph, such as Table 1 above.
- -The distribution of the information in a standard is not restricted. The only -requirement is that requirements be grouped in a manner -consistent with the conformance test classes, see Table 13 and Table 14.
-NOTE: For OGC Standards, the assumptions is that documents are in a commonly used -logical form (template).
This form should be specified by the following descriptions:
- -A standards document contains Clauses (corresponding to numbered sections as they might -appear in a table of contents) which describe its standardization target and its requirements.
-A standard contains Annexes or is associated to other documents (both a -logical type of Clause), one of which is the Conformance Test Suite (which may be an -abstract description of the test suites to be implemented separately). In OGC Documents, this is Annex A – Abstract Test Suite.
-All requirements, recommendations, permissions, and models are introduced and defined first in -the numbered Clauses.
-All requirements are identifiable as requirements.
-All requirements in a document are uniquely numbered.
-All tests for conformance to those requirements are defined in the Conformance Test Suite.
-Tests are be grouped for convenience into conformance test classes and if desired the classes are grouped into conformance test modules.
-The tests, if conducted, determine to some degree of certainty whether an -implementation meets the requirements which the tests reference.
-The tests are organized into some number of conformance “classes” where each conformance class has a one to one relationship with a requirements class. If a standard -does not do this, it is has by default only one “conformance class”.
-Certificates of conformance (see Clause 4.1) are -awarded by a testing entity based on these conformance classes.
-There is a clear distinction between normative and informative parts of the text.
-Examples and notes are informative, and do not use “normative” -language.
-In informative sections, the word “will” implies that something is an implication of a requirement. The “will” statements are -not requirements, but explain the consequence of requirements.
- -The ModSpec defines a “requirement” of a standard as an atomic testable -criterion. See the formal definition of requirement in Clause 4.21
- -A UML representation of important properties of this model is given in [annex-B-2].
-Version 2.0 of the ModSpec is split into a Core standard and multiple Parts. These are:
- -Core: contains all the core requirements and informational text that define the model and internal structure of a standard.
-Part 1: UML Model requirements
-Part 2: XML Model requirements
-Part 3: Schematron requirements
-Part 4: XML Metaschema requirements
-Future Parts to the ModSpec Standard may include:
- -Part 5: RDF/OWL requirements
-In software development technology, there is a concept called building block. In software development, building blocks are used to support the software build process where source code files/libraries can be accessed from multiple sources, converted into executable code, and linked together in the proper order until a complete set of executable files is generated. The same concept can be applied to OGC Standards development: Requirements classes and/or modules can be linked together from one or more standards to create a new standard not originally envisioned when the requirements were originally defined.
- -The Open Group suggests that building blocks have the following characteristics:
- -A building block is a package of functionality defined to meet business or domain needs.
-A building block may interoperate with other, inter-dependent, building blocks.
-A good building block has the following characteristics:
-Considers implementation and usage, and evolves to exploit technology and standards.
-May be assembled from other building blocks.
-May be a subassembly of other building blocks.
-Ideally a building block is re-usable and replaceable, and well specified.
-A building block may have multiple implementations but with different inter-dependent building blocks.
-These characteristics are slightly modified from the Open Group definitions to accommodate the use of the building block concept in standards work.
NOTE: The approach modelled in the ModSpec has been referred to as the “core and extension model” due to its -insistence on a modular structure throughout all parts of a standard and its implementation.
Note 1 to entry: Includes all statements in a document not part of the normative +requirements (Clause 4.21), recommendations (Clause 4.20) or + conformance tests (Clause 4.3). Included for completeness.
[SOURCE: ISO/IEC DIR 2]
+All symbols used in this document are either:
+All symbols used in this document are either:
-Common mathematical symbols
+Common mathematical symbols
UML 2 (Unified Modeling Language) as defined by OMG and accepted as a publicly +
UML 2 (Unified Modeling Language) as defined by OMG and accepted as a publicly available standard (PAS) by ISO in its earlier 1.3 version.
The normative provisions in this standard are denoted by the URI namespace
+The normative provisions in this standard are denoted by the URI namespace
-https://www.opengis.net/spec/modspec/1.1/
+https://www.opengis.net/spec/modspec/1.1/
-All requirements that appear in this document are denoted by partial URIs which are relative to the namespace shown above.
+All requirements that appear in this document are denoted by partial URIs which are relative to the namespace shown above.
-For the sake of brevity, the use of “req” in a requirement URI denotes:
+For the sake of brevity, the use of “req” in a requirement URI denotes:
-https://www.opengis.net/spec/modspec/1.1/
+https://www.opengis.net/spec/modspec/1.1/
-An example might be:
+An example might be:
-/req/core/crs
+/req/core/crs
-All conformance tests that appear in this document are denoted by partial URIs which are relative to the namespace shown above.
+All conformance tests that appear in this document are denoted by partial URIs which are relative to the namespace shown above.
-For the sake of brevity, the use of “conf” in a requirement URI denotes:
+For the sake of brevity, the use of “conf” in a requirement URI denotes:
-https://www.opengis.net/spec/modspec/1.1/
+https://www.opengis.net/spec/modspec/1.1/
-The same convenstion is used for permissions (per) and recommendations (rec).
-The same convention is used for permissions (per) and recommendations (rec).
+In this document the following abbreviations and acronyms are used or introduced:
+In this document the following abbreviations and acronyms are used or introduced:
-ERA
Entity, Relation, Attribute (pre-object modeling technique)
-ISO
International Organization for Standardization (from Greek for “same”)
-OCL
Object Constraint Language (part of UML)
-OGC
Open Geospatial Consortium (http://www.opengeospatial.org/)
-OMG
Object Management Group (http://www.omg.org/)
-OOP
Object Oriented Programming
-OOPL
OOP Language (such as C++ or Java)
-SQL
ISO/IEC 9075 query language for relational databases, not originally an acronym, but now often cited as “Structured Query Language”
-TC
Technical Committee (usually either in ISO or OGC)
-UML
Unified Modeling Language (an object modeling language)
-XML
eXtensible Markup Language
+ERA
Entity, Relation, Attribute (pre-object modeling technique)
+ISO
International Organization for Standardization (from Greek for “same”)
+OCL
Object Constraint Language (part of UML)
+OGC
Open Geospatial Consortium (http://www.opengeospatial.org/)
+OMG
Object Management Group (http://www.omg.org/)
+OOP
Object Oriented Programming
+OOPL
OOP Language (such as C++ or Java)
+SQL
ISO/IEC 9075 query language for relational databases, not originally an acronym, but now often cited as “Structured Query Language”
+TC
Technical Committee (usually either in ISO or OGC)
+UML
Unified Modeling Language (an object modeling language)
+XML
eXtensible Markup Language
Each normative statement in the ModSpec is stated in one and only one place, +
Each normative statement in the ModSpec is stated in one and only one place, in a standard format, with an unique label, such as REQ001, REC001, or PER001. A requirement, recommendation, or permission may be repeated for clarification. The statement with the unique label is considered the official statement of the normative requirement or recommendation.
-In this document, all requirements are associated with tests specified in the test suite +
In this document, all requirements are associated with tests specified in the test suite in Annex A. The reference to the requirement in the test case is done by a requirements label Recommendations are not tested although they still are documented using a standard template and have unique identifiers.
-Requirements classes are separated into their own clauses and named, and specified +
Requirements classes are separated into their own clauses and named, and specified according to inheritance (direct dependencies). The Conformance test classes in the test suite are similarly named to establish an explicit and link between requirements classes and conformance test classes.
-NOTE: For OGC Standards, the assumption is that documents are in a commonly used -logical form (template).
This form should be specified by the following descriptions:
- -A standards document contains Clauses (corresponding to numbered sections as they might -appear in a table of contents) which describe its standardization target and its requirements.
-A standard contains Annexes or is associated to other documents (both a -logical type of Clause), one of which is the Conformance Test Suite (which may be an -abstract description of the test suites to be implemented separately). In OGC Documents, this is Annex A – Abstract Test Suite.
-All requirements, recommendations, permissions, and models are introduced and defined first in -the numbered Clauses.
-All requirements are identifiable as requirements.
-All requirements in a document are uniquely numbered.
-All tests for conformance to those requirements are defined in the Conformance Test Suite.
-Tests are be grouped for convenience into conformance test classes and if desired the classes are grouped into conformance test modules.
-The tests, if conducted, determine to some degree of certainty whether an -implementation meets the requirements which the tests reference.
-The tests are organized into some number of conformance “classes” where each conformance class has a one to one relationship with a requirements class. If a standard -does not do this, by default it has only one “conformance class”.
-Certificates of conformance (see Clause 4.1) are -awarded by a testing entity based on these conformance classes.
-There is a clear distinction between normative and informative parts of the text.
-Examples and notes are informative, and do not use “normative” -language.
-In informative sections, the use of the word “will” implies that something is an implication of a requirement. The “will” statements are -not requirements but explain the consequence of requirements.
- -The ModSpec defines a “requirement” of a standard as an atomic testable -criterion. See the formal definition of requirement in Clause 4.21
- -A UML representation of important properties of this model is given in [annex-B-2].
-Version 2.0 of the ModSpec is split into a Core standard and multiple Parts. These are:
+Core: contains all the core requirements and informational text that define the model and internal structure of a standard.
-Part 1: UML Model requirements
-Part 2: XML Model requirements
-Part 3: Schematron requirements
-Part 4: XML Metaschema requirements
-Future Parts to the ModSpec Standard may include:
- -Part 5: RDF/OWL requirements
-In software development technology, there is a concept called building block. In software development, building blocks are used to support the software build process where source code files/libraries can be accessed from multiple sources, converted into executable code, and linked together in the proper order until a complete set of executable files is generated. The same concept can be applied to OGC Standards development: Requirements classes and/or modules can be linked together from one or more standards to create a new standard not originally envisioned when the requirements were originally defined.
-In software development technology, there is a concept called building block. In software development, building blocks are used to support the software build process where source code files/libraries can be accessed from multiple sources, converted into executable code, and linked together in the proper order until a complete set of executable files is generated. The same concept can be applied to OGC Standards development: Requirements classes and/or modules can be linked together from one or more standards to create a new standard not originally envisioned when the requirements were originally defined.
+The Open Group suggests that building blocks have the following characteristics:
-The Open Group suggests that building blocks have the following characteristics:
- -A building block is a package of functionality defined to meet business or domain needs.
+A building block is a package of functionality defined to meet business or domain needs.
A building block may interoperate with other, inter-dependent, building blocks.
+A building block may interoperate with other, inter-dependent, building blocks.
A good building block has the following characteristics:
-Considers implementation and usage and evolves to exploit technology and standards.
+A good building block has the following characteristics:
+Considers implementation and usage, and evolves to exploit technology and standards.
May be assembled from other building blocks.
+May be assembled from other building blocks.
May be a subassembly of other building blocks.
+May be a subassembly of other building blocks.
Ideally a building block is re-usable and replaceable, and well specified.
+Ideally a building block is re-usable and replaceable, and well specified.
A building block may have multiple implementations but with different inter-dependent building blocks.
+A building block may have multiple implementations but with different inter-dependent building blocks.
These characteristics are slightly modified from the Open Group definitions to accommodate the use of the building block concept in standards work.
NOTE: The approach modelled in the ModSpec has been referred to as the “core and extension model” due to its -insistence on a modular structure throughout all parts of a standard and its implementation. -The modular approach is consistent with the definition and use of software building blocks.
These characteristics are slightly modified from the Open Group definitions to accommodate the use of the building block concept in standards work.
+Every standards document should include a Standardization Goal. This is a concise statement of the problem that the standard helps address and the strategy envisioned for achieving a solution. This strategy typically identifies real-world entities that need to be modified or constrained. At the abstract level, those entities are the Standardization Target Types. These are the classes of entities to be standardized. A Standard defines the requirements levied on one or more Standardization Target Types.
-Every OGC Standard document shall include a Standardization Goal. This is a concise statement of the problem that the Standard helps address and the strategy envisioned for achieving a solution. This strategy typically identifies real-world entities that need to be modified or constrained. At the abstract level, those entities are the Standardization Target Types. These are the classes of entities to be standardized. A Standard defines the requirements levied on one or more Standardization Target Types.
+Instances of a Standardization Target Type are the Standardization Targets. These are the real-world manifestations of the Standardization Target Type. In summary:
-Instances of a Standardization Target Type are the Standardization Targets. These are the real-world manifestations of the Standardization Target Type. In summary:
- -Standardization Goal – identifies the problem and identifies the actors and entities involved in solving that problem
+Standardization Goal – identifies the problem and identifies the actors and entities involved in solving that problem
Standardization Target Type – An abstract representation of one of the actors or entities identified in the Standardization Goal
+Standardization Target Type – An abstract representation of one of the actors or entities identified in the Standardization Goal
Standardization Target – an implementation of a Standardization Target Type. These are the real-world entities which can be tested for conformance with the requirements documented in the Standard.
+Standardization Target – an implementation of a Standardization Target Type. These are the real-world entities which can be tested for conformance with the requirements documented in the Standard.
Standardization Target Types can be hierarchical. The Conceptual, Logical, Physical hierarchy is one example where the Standardization Target Types are information models. Another example would be implementations of OGC API — Features Part 2 which support XML data exchange.
+Standardization Target Types can be hierarchical. The Conceptual, Logical, Physical hierarchy is one example where the Standardization Target Types are information models. Another example would be implementations of OGC API — Features Part 2 which support XML data exchange.
-Notice that the Standardization Targets and Standardization Target Types no longer form a simple taxonomy. The Standardization Target Types, Standardization Targets, and Standardization Goal provide a well-defined context for the standard. This will help users of standards to quickly understand the scope of a Standard and to select those Standards appropriate for their needs. It also will help keep Standards developers focused on the intended use of their standards, avoiding standards which are overly broad and/or unfocused.
-Notice that the Standardization Targets and Standardization Target Types no longer form a simple taxonomy. The Standardization Target Types, Standardization Targets, and Standardization Goal provide a well-defined context for the standard. This will help users of standards to quickly understand the scope of a standard and to select those standards appropriate for their needs. It also will help keep standards developers focused on the intended use of their standards, avoiding standards which are overly broad and/or unfocused.
+In the conformance test suite, there will be a test defined to verify the validity of +
In the conformance test suite, there will be a test defined to verify the validity of the claim that an implementation of the standard (standardization target) satisfies each mandatory requirement specified in the standard. Since the normative language of the body of the standard and the conformance test classes both define what conformance to the standard means, they @@ -2235,7 +1987,7 @@
Conformance tests are aggregated into conformance classes that specify how certain +
Conformance tests are aggregated into conformance classes that specify how certain “certificates of conformance” are achieved. The natural inclination is to aggregate the requirements. The issue that blocks this approach is that some requirements are optional while others are mandatory. To achieve a cleaner separation of requirements, @@ -2243,82 +1995,131 @@
Therefore, the ModSpec defines a “requirements class” as a set of requirements that must +
Therefore, the ModSpec defines a “requirements class” as a set of requirements that must all be passed to achieve a particular conformance class (see -Clause 4.7). This document also includes a “middle” structure +Clause 4.6). This document also includes a “middle” structure called a conformance test module. Requirements modules parallel the conformance test modules. A standard written to the ModSpec may use this “module” structure in any manner consistent with the rest of this Policy.
-A standard may have mandatory and optional requirements classes. This allows the options +
A standard may have mandatory and optional requirements classes. This allows the options in the testing procedure to be grouped into non-varying mandatory and optional conformance classes. Each requirement within an optional requirements class is mandatory when that requirements class is implemented. When needed, a particular requirements class may contain only a single requirement.
-However, care must be taken, since the requirements classes may not always in a one-to-one +
However, care must be taken, since the requirements classes may not always in a one-to-one correspondence to conformance classes in other standards which may be the source of requirements for a standard conformant to the ModSpec. If other standards are used, their options shall be specified to be useable within a standard conformant to -this policy, see Clause 9.4.1.
+this policy, see Clause 8.4.1. -Conformance classes may contain dependencies on one another. These are represented by +
Conformance classes may contain dependencies on one another. These are represented by tests in one conformance class that state that another conformance class must be passed to qualify to pass this conformance class. In terms of requirements, that says that the dependent conformance class contains tests (by reference) for all requirements of the “included” conformance class.
-As defined in the ModSpec, one requirements +
As defined in the ModSpec, one requirements class is dependent on another if the other is included through such a reference. In this manner, requirements classes can be treated as sets of requirements (each in a single requirements class but included in others by reference to its “home” requirements class).
-In the ModSpec, each conformance requirement is separated in its own labeled -paragraph, such as Table 1 above.
+In the ModSpec, each conformance requirement is separated in its own labeled +paragraph, such as req-1 below.
-The distribution of the information in a standard is not restricted. The only +
The distribution of the information in a standard is not restricted. The only requirement is that requirements be grouped in a manner -consistent with the conformance test classes, see Table 13 and Table 14.
-The following requirements specify the rules for the content and structure of a modular standard. These requirements are also known as the core of the ModSpec.
Table 1
REQ001 | /req/core/reqs-are-testable +consistent with the conformance test classes, see Table 14 and Table 15. + 7.4. Documenting the Standard+ +NOTE: OGC Standards are written using an OGC Member approved template that is conformant with the +requirements stated in the ModSpec This form should be specified by the following descriptions: + +
In informative sections, the use of the word “will” implies that something is an implication of a requirement. The “will” statements are +not requirements, but explain the consequence of requirements. + +The ModSpec defines a “requirement” of a standard as an atomic testable +criterion. See the formal definition of requirement in Clause 4.21 + +A UML representation of important properties of this model is given in [annex-B-2]. +8. ModSpec Requirements Class: CoreThe following requirements specify the rules for the content and structure of a modular standard. These requirements are also known as the core of the ModSpec. NOTE: The following requirement is for OGC work only and will be moved to the OGC Policy statement regarding the use of the ModSpec. This move will happen once the policy is removed. Table 1
The following requirement states that every requirement is testable. Table 2
Table 2
Table 3
Table 3
Table 4
While a requirement may be referenced in more than one place in a standard, the normative definition of a requirement shall be its “home” (see Clause 7.4) and -will be the only place where full normative language is used. The following permissions relate to possible content specified in the core of a standard. Table 4
While a requirement may be referenced in more than one place in a standard, the normative definition of a requirement shall be its “home” (see Clause 6.4) and +will be the only place where full normative language is used. The following permissions relate to possible content specified in the core of a standard. Table 5
In this manner, the core requirements class and its associated contents can be +included in the core. |
In this manner, the core requirements class and its associated contents can be thought of not only as the requirements of the core conformance class, but as a form of reference model for establishing core vocabularies and schemas for the entire -standard.
Table 5
PER002 | /per/core/core-may-contain-schema-terms +standard. Table 6
Table 6
Table 7
The following states how and where vocabularies are specified in relation to a requirement or requirements class. Table 7
The following states how and where vocabularies are specified in relation to a requirement or requirements class. Table 8
Table 8
Example In the specification of a metadata service, the Dublin Core concept of a “Title” and +requirements class where that use or interpretation is used. |
Table 9
PER004 | /per/core/external-vocabs-core +Importation of external vocabularies and schemas MAY be in the core. |
Example
In the specification of a metadata service, the Dublin Core concept of a “Title” and the XML schema structure used for its specification can be in the core of the service specification. How a particular request-response pair uses the data structure to mean the title of a particular document or dataset will be specified in the requirements class in which the request-response pair is defined and set against requirements.
-The primary difficulty in speaking about standards (or candidate +
The primary difficulty in speaking about standards (or candidate standards)1 as a group is their diverse nature. Some standards use UML to define behavior, others use XML to define data structures, and others use no specific modeling language at all. However, they all @@ -2328,7 +2129,7 @@
NOTE: This “test suite” specification is a requirement for +requirements.
NOTE: This “test suite” specification is a requirement for ISO and for OGC, but is often ignored in less formal standardization efforts. In such cases, if there exists a “validation authority” for conformance, they must interpret the requirements to be tested possibly separated from the authors of the @@ -2336,7 +2137,7 @@
The assumption is that each standard has a single +
The assumption is that each standard has a single (root) standardization target type from which all extensions inherit. If this is not true, then the standard can be logically factored into parts each corresponding to a “root” standardization target type, and that the standard addresses each @@ -2344,29 +2145,29 @@
Table 9
REQ004 | /req/core/single-standardization-target + Table 10
In practice, the standardization target of the core requirements class is the root + In practice, the standardization target of the core requirements class is the root of an inheritance tree where extensions all have the core’s target as an ancestor, and thus can be considered as belonging to the same “class” or type as the core’s target. -Table 10
|