Cloud Application Management for Platforms (CAMP) Test Assertions Version 1.1
Committee Specification 01
09 November 2014
Specification URIs
This version:
http://docs.oasis-open.org/camp/camp-ta/v1.1/cs01/camp-ta-v1.1-cs01.pdf (Authoritative)
http://docs.oasis-open.org/camp/camp-ta/v1.1/cs01/camp-ta-v1.1-cs01.html
http://docs.oasis-open.org/camp/camp-ta/v1.1/cs01/camp-ta-v1.1-cs01.doc
Previous version:
http://docs.oasis-open.org/camp/camp-ta/v1.1/csprd02/camp-ta-v1.1-csprd02.pdf (Authoritative)
http://docs.oasis-open.org/camp/camp-ta/v1.1/csprd02/camp-ta-v1.1-csprd02.html
http://docs.oasis-open.org/camp/camp-ta/v1.1/csprd02/camp-ta-v1.1-csprd02.doc
Latest version:
http://docs.oasis-open.org/camp/camp-spec/v1.1/camp-spec-v1.1.pdf (Authoritative)
http://docs.oasis-open.org/camp/camp-spec/v1.1/camp-spec-v1.1.html
http://docs.oasis-open.org/camp/camp-spec/v1.1/camp-spec-v1.1.doc
Technical Committee:
OASIS Cloud Application Management for Platforms (CAMP) TC
Chair:
Martin Chapman (martin.chapman@oracle.com), Oracle
Editors:
Jacques Durand (jdurand@us.fujitsu.com), Fujitsu Limited
Gilbert Pilz (gilbert.pilz@oracle.com), Oracle
Adrian Otto (adrian.otto@rackspace.com), Rackspace Hosting, Inc.
Tom Rutt (trutt@us.fujitsu.com), Fujitsu Limited
Related work:
This specification is related to:
Abstract:
This document defines the Test Assertions for version 1.1 of the OASIS Cloud Application Management for Platforms (CAMP) specification. Test Assertions are testable or measurable expressions related to normative statements in a specification for evaluating if an implementation (or part of it) conforms to this specification. These Test Assertions are intended to be used for defining precisely the conditions required by a CAMP implementation in order to conform. They support the testing activity by acting as a bridge between the normative statements in the specification and the executable test cases that are parts of a conformance test suite.
Status:
This document was last revised or approved by the OASIS Cloud Application Management for Platforms (CAMP) TC on the above date. The level of approval is also listed above. Check the “Latest version” location noted above for possible later revisions of this document. Any other numbered Versions and other technical work produced by the Technical Committee (TC) are listed at https://www.oasis-open.org/committees/tc_home.php?wg_abbrev=camp#technical.
TC members should send comments on this specification to the TC’s email list. Others should send comments to the TC’s public comment list, after subscribing to it by following the instructions at the “Send A Comment” button on the TC’s web page at https://www.oasis-open.org/committees/camp/.
For information on whether any patents have been disclosed that may be essential to implementing this specification, and any offers of patent licensing terms, please refer to the Intellectual Property Rights section of the Technical Committee web page (https://www.oasis-open.org/committees/camp/ipr.php).
Citation format:
When referencing this specification the following citation format should be used:
[CAMP-Test-Assertions-v1.1]
Cloud Application Management for Platforms (CAMP) Test Assertions Version 1.1. Edited by Jacques Durand, Gilbert Pilz, Adrian Otto, and Tom Rutt. 09 November 2014. OASIS Committee Specification 01. http://docs.oasis-open.org/camp/camp-ta/v1.1/cs01/camp-ta-v1.1-cs01.html. Latest version: http://docs.oasis-open.org/camp/camp-ta/v1.1/camp-ta-v1.1.html.
Notices
Copyright © OASIS Open 2014. All Rights Reserved.
All capitalized terms in the following text have the meanings assigned to them in the OASIS Intellectual Property Rights Policy (the "OASIS IPR Policy"). The full Policy may be found at the OASIS website.
This document and translations of it may be copied and furnished to others, and derivative works that comment on or otherwise explain it or assist in its implementation may be prepared, copied, published, and distributed, in whole or in part, without restriction of any kind, provided that the above copyright notice and this section are included on all such copies and derivative works. However, this document itself may not be modified in any way, including by removing the copyright notice or references to OASIS, except as needed for the purpose of developing any document or deliverable produced by an OASIS Technical Committee (in which case the rules applicable to copyrights, as set forth in the OASIS IPR Policy, must be followed) or as required to translate it into languages other than English.
The limited permissions granted above are perpetual and will not be revoked by OASIS or its successors or assigns.
This document and the information contained herein is provided on an "AS IS" basis and OASIS DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN WILL NOT INFRINGE ANY OWNERSHIP RIGHTS OR ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
OASIS requests that any OASIS Party or any other party that believes it has patent claims that would necessarily be infringed by implementations of this OASIS Committee Specification or OASIS Standard, to notify OASIS TC Administrator and provide an indication of its willingness to grant patent licenses to such patent claims in a manner consistent with the IPR Mode of the OASIS Technical Committee that produced this specification.
OASIS invites any party to contact the OASIS TC Administrator if it is aware of a claim of ownership of any patent claims that would necessarily be infringed by implementations of this specification by a patent holder that is not willing to provide a license to such patent claims in a manner consistent with the IPR Mode of the OASIS Technical Committee that produced this specification. OASIS may include such claims on its website, but disclaims any obligation to do so.
OASIS takes no position regarding the validity or scope of any intellectual property or other rights that might be claimed to pertain to the implementation or use of the technology described in this document or the extent to which any license under such rights might or might not be available; neither does it represent that it has made any effort to identify any such rights. Information on OASIS' procedures with respect to rights in any document or deliverable produced by an OASIS Technical Committee can be found on the OASIS website. Copies of claims of rights made available for publication and any assurances of licenses to be made available, or the result of an attempt made to obtain a general license or permission for the use of such proprietary rights by implementers or users of this OASIS Committee Specification or OASIS Standard, can be obtained from the OASIS TC Administrator. OASIS makes no representation that any information or list of intellectual property rights will at any time be complete, or that any claims in such list are, in fact, Essential Claims.
The name "OASIS" is a trademark of OASIS, the owner and developer of this specification, and should be used only to refer to the organization and its official outputs. OASIS welcomes reference to, and implementation and use of, specifications, while reserving the right to enforce its marks against misleading uses. Please see https://www.oasis-open.org/policies-guidelines/trademark for above guidance.
Table of Contents
2 Test Assertions Design and Objectives
2.3 Anatomy of a Test Assertion
2.4 Categories of Test Assertions
2.5.1 Identification scheme for Test Assertions
2.5.2 Identifying a message inside a Test Assertion
2.5.3 Identifying an attribute of a resource in a message
2.6 Coverage of the Specification
3.1.1 Basic Schema Compliance for Platform Resources, Provider Side
3.1.2 Basic Schema Compliance for Application Resources
3.1.3 Consistency of Serialization with Metadata
3.1.4 Metadata Integrity and Serialization
3.1.5 Various Model Referential and Semantic Constraints
3.1.6 Support for HTTP Methods
3.1.8 Resource Queries and HTTP
3.1.10 Resource Creation and Consistency of Representations
3.1.13 Representation Skew Semantics
3.1.14 PDP and Plan Registration
3.2.1 Basic Schema Compliance for Platform Resources, Consumer Side
3.2.2 Consistency of Serialization with Metadata
3.2.3 Various Model Referential and Semantic Constraints
3.2.5 Resource Queries and HTTP
3.2.8 PDP and Plan Registration
3.3 PDP and Plan Test Assertions
4.2 CAMP Provider Test Suite Conformance Profile
4.3 CAMP Consumer Test Suite Conformance Profile
4.4 CAMP PDP Test Suite Conformance Profile
4.5 CAMP Plan Test Suite Conformance Profile
This document defines the Test Assertions for version 1.1 of the OASIS Cloud Application Management for Platforms (CAMP) specification [CAMP]. Test Assertions are testable or measurable expressions related to normative statements in a specification for evaluating if an implementation (or part of it) conforms to this specification. These Test Assertions are intended to be used for defining precisely the conditions required by a CAMP implementation in order to conform. They support the testing activity by acting as a bridge between the normative statements in the specification and the executable test cases that are parts of a conformance test suite.
The key words “MUST”, “MUST NOT”, “REQUIRED”, “SHALL”, “SHALL NOT”, “SHOULD”, “SHOULD NOT”, “RECOMMENDED”, “MAY”, and “OPTIONAL” in this document are to be interpreted as described in [RFC2119].
[RFC2119] Bradner, S., “Key words for use in RFCs to Indicate Requirement Levels”, BCP 14, RFC 2119, March 1997. http://www.ietf.org/rfc/rfc2119.txt.
[TA-Model] Test Assertions Model Version 1.0. 15 October 2012. OASIS Standard.
http://docs.oasis-open.org/tag/model/v1.0/os/testassertionsmodel-1.0-os.html.
[CAMP] Cloud Application Management for Platforms Version 1.1, August 2014, OASIS Committee Specification Draft 05. http://docs.oasis-open.org/camp/camp-spec/v1.1/csd05/camp-spec-v1.1-csd05.pdf
[TA-guidelines] Test
Assertions Guidelines Version 1.0. June 2013. OASIS Committee Note.
http://docs.oasis-open.org/tag/guidelines/v1.0/cn02/guidelines-v1.0-cn02.pdf
A Test Assertions is a testable or measurable expression for evaluating the adherence of an implementation (or part of it) to a normative statement(s) in a specification.
The Test Assertions presented here are intended to help a precise understanding of what is expected from implementations of the CAMP specification.
They are also intended as a starting point for actual test suites. Testing for conformance to the CAMP specification occurs typically in two major contexts:
In both cases, some Consumer-Provider exchanges are executed according to some pre-defined scenarios. In both cases, these exchanges must be verified for conformance to CAMP.
There is also a 3rd context where testing for CAMP conformance is likely to occur: routine regression testing on systems in production. In this context, real business exchanges between a Consumer and a Provider are being monitored and tested for conformance. The rationale is that Cloud end-points may often be upgraded (patches, revisions) or their operational context be modified (configuration change, recovery, etc.), which might cause a deterioration of their conformance to CAMP. Since it is impractical to stop operations and undergo a full round of testing each time some end-point is upgrading, it is often sufficient to detect as early as possible a regression, whenever it occurs.
CAMP test assertions are intended to be usable by test suites designed for the various testing contexts and objectives described in the previous section. To achieve this versatility, the following design principles are used:
The structure of test assertions follows the recommendation from OASIS TAG [TA-guidelines].
The general structure used for Test Assertions is as follows:
The core elements of a Test Assertion are:
Test Assertion ID (or Identifier, or TA_Id)
The unique identifier of the test assertion. It facilitates the mapping of assertions to specification statements. It is recommended that the identifier be made universally unique.
These refer to the precise specification requirement(s) or normative statement(s) that the test assertion addresses.
The target – or test target - categorizes an implementation or a part of an implementation of the referred specification that is the main object of the test assertion and of its Normative Sources. In CAMP, the target will typically be a message exchanged between Consumer and Provider (e.g. a response to an HTTP GET), or the PDP or Plan artifact.
NOTE: the “test [assertion] target” should not be confused with the “conformance target”. The test target is the artifact or component actually subject to the particular testing described in the test assertion (e.g. a message), while the conformance target is the entity ultimately evaluated for conformance, (e.g. a CAMP Provider implementation). Of course, the test target can be traced to a conformance target.
It contains the actual conformance logic. It is worded as a fact (not as a rule or requirement – i.e. no MUST/SHOULD). A predicate asserts, in the form of an expression that evaluates to either “true” or “false”, the feature (a behavior or a property) described in the specification statement(s) referred by the Normative Sources, concerning an instance of Target. If the predicate evaluates to “true” over the test assertion Target, this means that the Target exhibits this feature. “False” means the Target does not exhibit this feature.
The following parts of a test assertion are optional:
An informal definition of the role of the test assertion, with some optional details on some of its parts. This description must not alter the general meaning of the test assertion and its parts. This description may be used to annotate the test assertion with any information useful to its understanding. It does not need to be an exhaustive description of the test assertion.
A keyword that indicates how imperative it is that the Normative Statement referred to in the Normative Source, be satisfied. Three prescription levels are used:
A test assertion Prerequisite is a logical expression (similar to a Predicate) which further qualifies the Target for undergoing the core test (expressed by the Predicate) that addresses the Normative Statement. It may include references to the outcome of other test assertions. If the Prerequisite evaluates to "false" then the Target instance is not qualified for evaluation by the Predicate. Prerequisites have also been called “preconditions”.
Test assertions may be assigned 'tags' or 'keywords', which may in turn be given values. These tags allow for categorizing the test assertions.
The above test assertion model is formally described in the OASIS test assertions standard [TA-model].
TA_Id: CAMP11-NNN
NormativeSource: <a normative TAG, and optionally a section name>
Target: A response message to a GET assembly URI message.
Predicate: the target message content satisfies the JSON “schema” for assembly resources.
PrescriptionLevel: mandatory
Tag: conformance=Provider
The above test assertion model is profiled for CAMP in the following way:
In the example below, a resource variable is defined that can take either one among four resource names (sensor, plan, assembly, or component), thus avoiding to write four different test assertions that would only differ by the name of the resource.
Var: (resource) in {
sensor,
plan,
assembly,
component
}
Target: A message (m1) of the form PUT resource URI (with no select_attr query parameter)
Four general categories of test assertions can be distinguished, depending on their conformance target (value of the conformance tag):
NOTE: Provider TAs and Consumer TAs may also contain their own tests similar to those found in PDP and Plan TAs. The difference is that these tests will target the messages containing PDPs and Plans (or referring to these) instead of directly the PDP and Plan artifacts. In such cases, the Test Assertions will have an ID that indicates their close relationship. For example:
Test Assertions are identified according to the scheme:
<specificationID> “-“ <number>
Where specificationID is here “CAMP11”, and number takes the following ranges:
When referring to an HTTP message, either request or response, the following notation is used:
“(“ messageID “)”
where messageID is a symbolic identifier typically of the form. “m1”, “m2” etc. Such an identifier is only relative to the test assertion; they are used to distinguish messages from each other in the same test assertion (i.e. this identifier does not appear in the message itself).
When referring to an attribute of a resource serialized in a message, the Courier New font is used to indicate a name proper to the CAMP model. The following notation is used:
“(“ messageID “)” <resource_type> “.” <attribute_name>
Where:
For example:
(m2)platform.assemblies_uri
In this document, only “mandatory” normative statements (SHALL / SHALL NOT) have been addressed.
These Test Assertions concern the Provider as conformance target.
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
If the Required boolean constraint for an attribute of a resource type has a value of "true", then a resource of this type SHALL have the attribute present. [RE-06]
NormativeSource: RE-70, RE-06 (section: platform_endpoints)
Target: A successful response message (HTTP code 200) to a GET platform_endpoints message.
Predicate: the target (response) message content satisfies the serialization schema (JSON ) for platform_endpoints, AND has a type attribute of value = “platform_endpoints”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
Each platform_endpoint resource SHALL refer to exactly one platform resource, and indicate the versions supported by the Platform. [RE-20]
If the Required boolean constraint for an attribute of a resource type has a value of "true", then a resource of this type SHALL have the attribute present. [RE-06]
NormativeSource: RE-70, RE-20, RE-06 (section: platform_endpoint)
Target: A successful response message (HTTP code 200) to a GET platform_endpoint message (m1).
Prerequisite: the URI used in message (m1) exists as a link in platform_endpoints.platform_endpoint_links[] as result to a previous GET platform_endpoints URI.
Predicate: the target (response) message content satisfies the serialization schema (JSON ) for platform_endpoint, AND has a type attribute of value = “platform_endpoint” AND non-empty platform_uri, implementation_version, specification_version attribute values.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
If the Required boolean constraint for an attribute of a resource type has a value of "true", then a resource of this type SHALL have the attribute present. [RE-06]
NormativeSource: RE-70, RE-06, (RE-53) (Section: platform Resource definition)
Target: A successful response message (HTTP code 200) to a GET platform message.
Predicate: the target message content satisfies the serialization schema (JSON ) for platform, AND has a type attribute of value = “platform”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
If the Required boolean constraint for an attribute of a resource type has a value of "true", then a resource of this type SHALL have the attribute present. [RE-06]
NormativeSource: RE-70, (RE-06, RE-53) (Section: service Resource definition)
Target: A successful response message (HTTP code 200) to a GET service message (m1).
Prerequisite: the URI used in message (m1) exists as a link in services.service_links where services is obtained from platform.services_uri as shown in the result to a previous GET platform URI message.
Predicate: the target (response) message content satisfies the serialization schema (JSON ) for service , AND has a type attribute of value = “service”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
If the Required boolean constraint for an attribute of a resource type has a value of "true", then a resource of this type SHALL have the attribute present. [RE-06]
NormativeSource: RE-70, RE-06, (RE-53) (Section: assembly Resource definition)
Target: A successful response message (HTTP code 200) to a GET assembly message (m1).
Prerequisite: the URI used in the message (m1) exists as a link in assemblies.assembly_links, as shown in the result to a previous GET assemblies message (obtained from platform.assemblies_uri), OR there is a POST to an assemblies that returns this URI.
Predicate: the target message content satisfies the serialization schema (JSON ) for assembly, AND has a type attribute of value = “assembly”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
If the Required boolean constraint for an attribute of a resource type has a value of "true", then a resource of this type SHALL have the attribute present. [RE-06]
NormativeSource: RE-70, RE-06, (RE-53,) (Section: component Resource definition)
Target: A successful response message (HTTP code 200) to a GET component message (m1).
Prerequisite: the URI used in the message (m1) exists as a link in assembly.components[] as shown in the result to a previous GET assembly message.
Predicate: the target message content satisfies the serialization schema (JSON ) for component AND has a link assembly to the parent assembly URI , AND has a type attribute of value = “component”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
The schema of the plan resource returned from a CAMP Provider SHALL conform to the schema for Plans described in Section 4.3, “Plan Schema”, with the following additional requirements: [RMR-07]
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
If the Required boolean constraint for an attribute of a resource type has a value of "true", then a resource of this type SHALL have the attribute present. [RE-06]
NormativeSource: RMR-07, RE-70, RE-06, (RE-53) (Section: plan Resource definition)
Target: A successful response message (HTTP code 200) to a GET plan message (m1).
Prerequisite: the URI used in the message (m1) exists in a link in plans.plan_links as shown in the result to a previous GET plans message (obtained from platform.plans_uri), OR there is a POST to an plans Resource that returns this URI.
Predicate: the target message content satisfies the serialization schema (JSON ) for plan, AND has a type attribute of value = “plan”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
Providers SHALL respond in the requested Supported Format. [PR-05]
NormativeSource: RE-70, PR-05, (section: Media Types / Supported Formats)
Var: (resource) in
{
assembly,
component,
platform,
service
}
Target: A response message (m4) to a GET resource message (m3).
Prerequisite:
Predicate: in the target message (m4), the resource data in case of a successful response message (HTTP code 200), or the error data in case of an error code (4xx or 5xx), is serialized consistently with the requested format.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The value of the name attribute in a type_definition resource SHALL match the value of the type attribute for the resource type that it describes. [RE-75]
NormativeSource: RE-75, (section: type_definition resources)
Var: (resource) in
{
assembly,
component,
platform,
service
}
Target: A response message (m4) to a GET resource message (m3).
Prerequisite:
A successful response message (m2) to a previous GET type_definitions (m1) where type_definitions is obtained from platform.type_definitions_uri.
Predicate: in the target message (m4), the resource data in case of a successful response message (HTTP code 200) shows a type attribute with a value that is same as the name attribute in one of the type_definition items in (m1), AND each attribute of the resource in (m4) is also described by an attribute_definition resource referred in the type_definition.attribute_definition_links.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
All CAMP resources SHALL inherit directly or indirectly from this resource. [MO-05]
NormativeSource: MO-05, (section: camp_resource resource)
Target: A successful response message (m2) to a previous GET type_definitions (m1) where type_definitions is obtained from platform.type_definitions_uri.
Prerequisite:
Predicate: Every link in type_definitions.type_definition_links uses an URI that refers to a type_definition resource that satisfies either condition: (the name attribute has value camp_resource OR the inherits_from attribute has a link showing same URI as the URI used in (m3).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
This boolean indicates the mutability of the attribute’s value(s). “false” indicates that the value of the attribute, once set, SHALL NOT change for the lifetime of the resource. [RE-07]
NormativeSource: RE-07, (RE-53) (section: Mutable)
Var: (resource) in {
assembly,
component,
plan
}
Target: A response message (m4) to a PUT request (m3) to a resource.
Prerequisite: The following message sequence occurred:
Predicate: the target message (m4) has an 4xx HTTP code.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
If the Required boolean constraint for an attribute of a resource type has a value of "true", then a resource of this type SHALL have the attribute present. [RE-06]
NormativeSource: RE-70, RE-06, (RE-53) (section: parameter_definitions)
Target: A successful response message (HTTP code 200)(m4) to a GET parameter_definitions message (m3).
Prerequisite: The following message sequence occurred:
Predicate: the target (response) message content satisfies the serialization schema (JSON ) for parameter_definitions, and has a type attribute of value = “parameter_definitions”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
If the Required boolean constraint for an attribute of a resource type has a value of "true", then a resource of this type SHALL have the attribute present. [RE-06]
NormativeSource: RE-70, RE-06, (RE-53,) (section: parameter_definition)
Target: A successful response message (HTTP 200) (m6) to a GET parameter_definition message (m5).
Prerequisite: The following message sequence occurred:
Predicate: the target message (m6) content satisfies the serialization schema (JSON ) for parameter_definition, AND has a type attribute of value = “parameter_definition”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
NormativeSource: RE-70 (section: formats)
Target: A successful response message (HTTP code 200) to a GET formats message (m1).
Prerequisite: the URI used in the message (m1) exists as value of a platform.supported_formats_uri attribute as result to a previous GET platform message.
Predicate: the target (response) message content satisfies the serialization schema (JSON ) for formats, and has a type attribute of value = “formats”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
NormativeSource: RE-70 (section: format)
Target: A successful response message (HTTP code 200)(m4) to a GET format message (m3).
Prerequisite: the URI used in the message (m3) exists as an item in formats.format_links as shown in a result to a previous GET formats message (m2), itself obtained from a previous GET platform message (m1) as platform.supported_formats_uri .
Predicate: the target message (m4) content satisfies the serialization schema (JSON ) for format, and has a type attribute of value = “format”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The name, mime_type, version, and documentation attribute values for the JSON Format Resource SHALL reflect the above values. [RE-42]
NormativeSource: RE-42 (section: Required JSON Format Resource)
Target: A successful response message (HTTP code 200)(m4) to a GET format message (m3) with query for “name”=”JSON”.
Prerequisite: the URI used in the message (m3) exists as an item in formats.format_links as a result to a previous GET Formats message (m2), itself obtained from a previous GET platform message (m1) as platform.supported_formats_uri .
Predicate: the target message (m4) has: "mime_type", "version", "documentation" set respectively to the expected values ("application/json", "RFC4627", "http://www.ietf.org/rfc/rfc4627.txt" ) .
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The Required JSON Format Resource SHALL be listed first in the format_links array. [RE-41]
NormativeSource: RE-41 (section: format_links)
Target: A successful response message (HTTP code 200)(m2) to a GET formats message (m1).
Prerequisite: the URI used in the message (m1) exists as platform.supported_formats_uri value, as a result to a previous GET platform message.
Predicate: the target message (m2) has its first link item with “target_name” set to “JSON”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
NormativeSource: RE-70, (RE-43) (section: type_definitions Resource)
Target: A successful response message (HTTP code 200)(m2) to a GET type_definitions message (m1).
Prerequisite: the URI used in the message (m1) exists as platform.type_definitions_uri in a result to a previous GET platform message.
Predicate: the target message (m2) content satisfies the serialization schema (JSON ) for type_definitions, AND has a type attribute of value = “type_definitions”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
NormativeSource: RE-70 (section: Resources)
Target: A successful response message (HTTP code 200) to a GET type_definition message (m1).
Prerequisite: the URI used in the message (m1) exists as an item in type_definitions. type_definitions_links as a result to a previous GET type_definitions message, itself obtained from platform.type_definitions_uri in a previous GET Platform message.
Predicate: the target (response) message content satisfies the serialization schema (JSON ) for type_definition, AND has a type attribute of value = “type_definition”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
TA_Id: CAMP11-125
NormativeSource: RE-70 (section: Resources)
Target: A successful response message (HTTP code 200)(m2) to a GET Attribute_definition message (m1).
Prerequisite: the URI used in the message (m1) exists as an item in Type_definition. attribute_definition s_links as a result to a previous GET Type_definition.
Predicate: the target message (m2) content satisfies the serialization schema (JSON ) for Attribute_definition , AND has a type attribute of value = “attribute_definition ”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The platform resource SHALL provide a Link to the type_definitions resource in the required attribute named type_definitions_uri. [RE-43]
NormativeSource: RE-43, (section: type_definitions Resource)
Target: A successful response message (HTTP code 200)(m2) to a GET platform message (m1).
Predicate: the target message (m2) content has :
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
For Platforms that implement this version of the CAMP specification, the value of this attribute SHALL be “CAMP 1.1” as defined in Section 1.8, “Specification Version”. [RE-22]
platform_endpoint resources that reference Specification Version “CAMP 1.1” Platform Resources SHALL NOT include this attribute because no previous versions are compatible. [RE-24]
NormativeSource: RE-22, RE-24 (sections: platform_endpoint Resource / specification_version, / backward_compatible_specification_versions)
Target: A successful response message (HTTP code 200)(m2) to a GET platform_endpoint message (m1).
Prerequisite: the URI used in the message (m1) exists as a link in platform_endpoints.platform_endpoint_links[] as shown in the result to a previous GET platform_endpoints URI.
Predicate: the target message (m2) content has a specification_version attribute = “CAMP 1.1” AND does not contain an backward_compatible_specification_versions attribute.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
For Platforms that implement this version of the CAMP specification, the value of this attribute SHALL be as defined in Section 1.8, “Specification Version”. [RE-26]
NormativeSource: RE-26 (section: Platform / specification_version )
Target: A successful response message (HTTP code 200)(m2) to a GET platform message (m1).
Predicate: the target message (m2) content has a specification_version attribute = “CAMP 1.1”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The value of this attribute SHALL exactly match the value of the specification_version attribute of any platform_endpoint resource that references this platform resource. [RE-27]
NormativeSource: RE-27 (section: Platform / specification_version ),
Target: A successful response message (HTTP code 200) (m4) to a GET platform message (m3).
Prerequisite: The sequence of messages occurred:
Predicate: the target (response) message (m4) content has a platform.specification_version attribute = (m2)platform_endpoint.specification_version.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The value of this attribute SHALL exactly match the value of the implementation_version attribute of any platform_endpoint resource that references this platform resource. [RE-29]
NormativeSource: RE-29 (section: Platform / implementation_version ),
Target: A successful response message (HTTP code 200) (m4) to a GET platform message (m3).
Prerequisite: The sequence of messages occurred:
Predicate: the target message (m4) content has a platform.implementation_version attribute = (m2)platform_endpoint.implementation_version.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
This attribute is an array of Links to platform_endpoint resources. This array SHALL contain at least one Link. [RE-18]
References between the resources (platform_endpoints, platform_endpoint, and platform) SHALL be self-consistent. [RE-19]
TA_Id: CAMP11-131
NormativeSource: RE-19, RE-18 (section: platform_endpoint_links),
Target: A successful response (HTTP 200) message (m2) to a GET platform message (m1)
Prerequisite: The following message sequence occurred:
Predicate: there is at least one link in platform_endpoints.platform_endpoint_links that refers to a platform_endpoint resource with platform_endpoint.platform_uri attribute value same as the URI used in (m1).AND the (m2) platform.platform_endpoints_uri value is same URI as the URI used in (m3).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The assemblies resource SHALL indirectly reference parameter_definition resources that describes the pdp_uri, plan_uri, pdp_file, and plan_file parameters. [RMR-03]
NormativeSource: RMR-03 (section: Assemblies / parameter_definitions_uri),
Target: A successful response message (HTTP code 200) (m2) to a GET assemblies message (m1), with a representation_skew=NONE.
Prerequisite: The following message sequence occurred after (m2):
Predicate: There exists at least four link items in (m4)parameter_definitions.parameter_definitions_links, that describe the “pdp_uri”, “plan_uri”, “pdp_file” and “plan_file” parameters, i.e. for which respectively a GET parameter_definition message (m5) returns a successful response (m6) with parameter_definition.name = “pdp_uri”, “plan_uri”, “pdp_file” and “plan_file”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The plans resource SHALL indirectly reference parameter_definition resources that describe the pdp_uri, plan_uri, pdp_file, and plan_file parameters. [RMR-06]
NormativeSource: RMR-06 (section: plans Resource),
Target: A successful response message (HTTP code 200) (m2) to a GET plans message (m1), with a representation_skew=NONE.
Prerequisite: The following message sequence occurred after (m2):
Predicate: There exists at least four link items in (m4)parameter_definitions.parameter_definitions_links, that describe the “pdp_uri”, “plan_uri”, “pdp_file” and “plan_file” parameters, i.e. for which respectively a GET parameter_definition message (m5) returns a successful response (m6) with Parameter_definition.name = “pdp_uri”, “plan_uri”, “pdp_file” and “plan_file”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The parameter_definitions resource referenced by this attribute SHALL define parameters to allow setting the ‘name’, ‘description’, and ‘tags’ attributes of any new resource created in the course of interacting with this resource. [RE-37]
TA_Id: CAMP11-134
NormativeSource: RE-37 (section: Service / parameter_definitions_uri),
Target: A successful response message (HTTP code 200) (m2) to a GET service message (m1), with a representation_skew=NONE.
Prerequisite: The following message sequence occurred after (m2):
Predicate: There exists link items in (m4)parameter_definitions.parameter_definitions_links, for which a GET parameter_definition message (m5) returns a successful response (m6) with parameter_definition.name = “name”, AND another (m5’) returns parameter_definition.name = “description”, AND another (m5’’) returns parameter_definition.name = “tags”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Consumers and Providers SHALL express Timestamps in UTC (Coordinated Universal Time), with the special UTC designator ("Z"). [RE-65]
TA_Id: CAMP11-136
NormativeSource: RE-65 (section: Timestamp)
Target: A successful response message (HTTP code 200)(m2) that has a resource serialization showing the “timestamp” attribute, in response to a GET message (m1).
Predicate: the Timestamp value conforms to the UTC (Universal Time Coordinated) with a “zero” timezone offset, i.e. with format terminated with the designator “Z”, of the form: yyyy '-' mm '-' dd 'T' hh ':' mm ':' ss ‘Z’ (Example: 1994-11-05T13:15:30Z)
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
If present, representation_skew SHALL have one of the following values: [RE-11]
NormativeSource: RE-11, (section: representation_skew)
Target: A successful response message (HTTP code 200) message to a GET resource message.
Prerequisite: The representation_skew attribute is present.
Predicate: the value of representation_skew is among { CREATING, NONE, UNKNOWN, DESTROYING }
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
NormativeSource: RE-70
Target: A successful response message (HTTP code 200) (m4) to a GET formats message (m3) with URI same as in (m2) platform.supported_formats_uri
Prerequisite: A successful result (m2) to a previous GET platform message (m1)
Predicate: For each link in (m4) formats.format_links, a GET format on the URI referenced in the link, returns an HTTP code 2xx AND a type attribute = “format”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
For every format that the Platform supports, there SHALL be a Format resource Link that represents such a format. [RE-40]
NormativeSource: RE-40 (section: Formats Resource / format_links)”
Target: A successful response message (HTTP code 200) (m4) to a GET message (m3) with HTTP Content-type in (m4) other than “application/json”
Prerequisite: A successful result (m2) to a previous GET platform message (m1) where this resource (m4) is defined.
Predicate: There exists a link in formats.format_links, where formats is referred to by (m2) platform.supported_formats_uri , that refers to a format resource with mime_type attribute value same as Content-type in (m4).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
If the array is non-empty, for every resource type that the Platform supports, there SHALL be a type_definition resource Link that represents such a resource type. [RE-44]
NormativeSource: RE-44 (section: type_definitions Resource / type_definitions_links)
Target: A successful response message (HTTP code 200) (m4) to a GET resource message (m3) of any kind.
Prerequisite:
A successful response message (HTTP code 200) (m2) to a GET type_definitions message (m1) with URI same as in platform.type_definitions_uri, showing a type_definition_links array with at least one link.
Predicate: There exists a link in (m2) type_definitions.type_definition_links, that references a type_definition resource with a name attribute value same as the type value in the resource returned in (m4).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Links in this array SHALL NOT either directly or transitively point to the described resource. [MO-06]
TA_Id: CAMP11-148
NormativeSource: MO-06 (section: type_definition Resource / inherits_from)
Target: A successful response message (HTTP code 200) (m4) to a GET type_definition message (m3).
Prerequisite: The type_definition URI belongs to type_definitions.type_definition_links as obtained from platform.type_definitions_uri in previous message exchanges.
Predicate: If the inherits_from link is set in (m4) then every link present in it satisfies: the link refers to a Resource of type type_definition that has an attribute "type" of value "typeDefinition" AND an attribute "name" value different from the "name" value in (m4) AND an attribute "uri" value different from the URI used in (m3).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
For every attribute of the type not inherited from its super-types, there SHALL be an AttributeLink that references the attribute_definition resource that defines that attribute. [RE-45]
NormativeSource: RE-45 (section: type_definition Resource / attribute_definition s_links)”
Target: A successful response message (HTTP code 200) (m6) to a GET type_definition message (m5), on a URI present in (m4) type_definitions.type_definitions_links
Prerequisite: A sequence of messages:
Predicate: For each attribute of the type_definition in (m6) , there exists a link in type_definition.attribute_definitions_links, for which a GET attribute_definition on the URI referenced in the link, returns an HTTP code 2xx AND a type attribute = “attribute_definition ” AND a name attribute = the attribute name
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
For every extension available, there SHALL be an extension resource Link that represents the extension. [EX-08]
NormativeSource: EX-08 (section: formats Resource / format_links)
Target: A successful response message (HTTP code 200) (m6) to a GET extension message (m5) i.e. where (m6) shows an type attribute of value “extension”.
Prerequisite: A previous sequence of messages such as:
Predicate: There exists a link in (m4) Extensions.extension_links, with a reference URI same as the URI used in (m5).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
For every extension available, there SHALL be an extension resource Link that represents the extension. [EX-08]
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
NormativeSource: EX-08, RE-70 (section: Formats Resource / format_links)
Target: A successful response message (HTTP code 200) (m4) to a GET extensions message (m3) with URI same as in (m2) platform.extensions_uri
Prerequisite: A successful result (m2) to a previous GET platform message (m1)
Predicate: For each link in (m4) extensions.extension_links, a GET extension message on the URI referenced in the link returns an HTTP code 2xx AND shows an type attribute of value “extension”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The platform resource SHALL provide a Link to the extensions resource in the required attribute named extensions_uri. [EX-09]
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
NormativeSource: EX-09, RE-70 (section: Formats Resource / format_links)
Target: a successful response message (HTTP code 200) (m4) to a GET extensions message (m3) with URI same as in (m2) platform.extensions_uri.
Prerequisite: A successful result (m2) to a previous GET platform message (m1)
Predicate: The message (m4) has HTTP code 2xx, AND the returned serialization shows a type attribute of value “extensions” AND the serialization is conforming to the extensions schema.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Entities added by an extension SHALL NOT interfere with names of existing entities, including any added by another extension. [EX-06]
NormativeSource: EX-06, (EX-08) (section: Unique Name Requirement)
Target: A successful response message (m4) to a GET extensions message (m3) with URI same as in (m2) platform.extensions_uri
Prerequisite: A successful result (m2) to a previous GET platform message (m1)
Predicate: For any pair of links in (m4) extensions.extension_links, the target_name values in these links are different AND different from any predefined resource or attribute name in the CAMP specification.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers that support the plans and plan resources SHALL advertise such support using the following extension resource: [RMR-12]
NormativeSource: RMR-12 (section: Advertising Support for the Plan Resource)
Target: A successful response message (HTTP code 200) (m4) to a GET extensions message (m3) with URI same as in (m2) platform.extensions_uri
Prerequisite: A successful result (m2) to a previous GET platform message (m1), shows an plans_uri attribute set to a valid URI.
Predicate: There exists a link in (m4) extensions.extension_links, for which a GET extension message on the URI referenced in the link returns an extension that shows a name attribute of value “CAMP Plans Extension” .
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
When supporting such a Resource, a Provider SHALL implement it and serialize it as described in the corresponding sub-section. [RE-70]
Providers SHALL support the HTTP GET, PUT, and PATCH methods on all of the resources defined in this section. [RE-53]
NormativeSource: RE-70, RE-53, (section: platform_endpoints resource)
Target: A response message to a GET platform_endpoints message.
Predicate: the target message has HTTP code 200 AND its content is valid for platform_endpoints serialization schema (JSON ).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers SHALL support the deployment of applications via HTTP POST requests on the assemblies resource as described in this section. [PR-49]
NormativeSource: PR-49 (section: Registering an Application by Reference)
Target: A response (m2) to a POST message (m1) to an assemblies URL, with a “pdp_uri” or a “plan_uri” attribute.
Predicate: the HTTP code in target (m2) is 201 “Created” AND the target message contains a location header with the URI for the new assembly resource, OR ( code = 202 “accepted” AND a subsequent GET on the returned Location header URI shows either representation_skew=CREATING or HTTP code 200 “OK”)
Predicate: the HTTP code in target (m2) is NOT 405 “Method Not Allowed”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
Providers that support the plans resource and plan resources SHALL support the registration of Plans via an HTTP POST request on the plans resource as described in this section. [PR-56]
In addition to the methods defined in Section 5.5, “HTTP Method Support”, Providers SHALL support the HTTP POST method on the plans resource as described in Section 6.12, “Registering a Plan”. [RMR-05]
NormativeSource: PR-56, RMR-05
Target: A response message (m2) to a POST plans message (m1) where (m1) contains a “pdp_uri” or a “plan_uri” attribute.
Predicate: the HTTP code in target (m2) is NOT 405 “Method Not Allowed”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
In addition to the methods defined in Section 5.5, “HTTP Method Support”, Providers SHALL support the HTTP POST method on the plans resource as described in Section 6.12, “Registering a Plan”. [RMR-05]
Providers that support the plans resource and plan resources SHALL support the registration of Plans via HTTP POST requests on the plans resource in which the entity body of the request contains the PDP or the Plan file that is being registered. [PR-61]
Var: archtype in { application/x-zip, application/x-tar, application/x-tgz, application/x-yaml }
NormativeSource: PR-61, RMR-05
Target: A response message (m2) to a POST Plans message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type = archtype.
Predicate: the HTTP code in target (m2) is NOT 405 “Method Not Allowed”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers SHALL support the deployment of applications via HTTP POST requests on the assemblies resource in which the entity body of the request contains the PDP or the Plan file that is being deployed. [PR-60]
In addition to the methods defined in Section 5.5, “HTTP Method Support”, Providers SHALL support the HTTP POST method on the assemblies resource as described in Section 6.11, “Deploying an Application”. [RMR-02]
Var: archtype in { application/x-zip, application/x-tar, application/x-tgz, application/x-yaml }
NormativeSource: PR-60, RMR-02
Target: A response message (m2) to a POST assemblies message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type = archtype.
Prerequisite: enough time elapsed to allow for the creation to complete.
Predicate: the HTTP code in target (m2) is NOT 405 “Method Not Allowed”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The Provider SHALL update the plan_links attribute of the plans resource to include a reference to the newly created plan resource. [PR-64]
NormativeSource: RE-64 (section: operation Resource)
Target: A response message to a POST operation message.
Prerequisite: the Operation URI exists as an item in operations.operation_links[] as shown in the result to a previous GET operations URI, itself obtained from a GET assembly.operations_uri.
Predicate: the HTTP code in target (m2) is NOT 405 “Method Not Allowed”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers SHALL provide representations of all available resources in JSON. [PR-01]
NormativeSource: PR-01 (section: Required Formats)
Target: A successful response message (HTTP code 200)(m2) to a GET resource message (m1) that has no HTTP “Accept” header or has one set to “application/json”.
Predicate: In the target (m2) the HTTP Content-Type value is “application/json”, AND the content if any is valid JSON.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
To support the deployment of applications via a reference to either a PDP, Plan file, or plan resource, Providers SHALL accept the "application/json" media type. [PR-68]
NormativeSource: PR-68 (section: Deploying an Application by Reference)
Target: A response message (m2) to a POST assemblies message (m1) that has no HTTP “Accept” header or has one set to “application/json” and contains a “pdp_uri” or a “plan_uri” attribute.
Predicate: The HTTP code of (m2) is NOT code 415, "Unsupported Media Type".
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
To support the registration of Plans via a reference to either a PDP or a Plan file, Providers SHALL accept the "application/json" media type. [PR-69]
NormativeSource: PR-69 (section: Registering a Plan by Reference)
Target: A response message (m2) to a POST plans message (m1) where (m1) has no HTTP “Accept” header or has one set to “application/json” and contains a “pdp_uri” or a “plan_uri” attribute.
Predicate: The HTTP code of (m2) is NOT code 415, "Unsupported Media Type".
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Consumers and Providers SHALL NOT transmit JSON objects that contain duplicate keys. [PR-02]
TA_Id: CAMP11-204
NormativeSource: PR-02 (section: Required Formats / Duplicate Keys in JSON Objects)
Target: A successful response message (m2) with JSON content (Content-Type = “application/json”) to a GET resource request (m1).
Predicate: there is no duplicate JSON keys at same level in the JSON content of the target message (m2).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
If a Consumer sends a Provider a request containing duplicate keys in a JSON object, the Provider SHOULD reject the request by sending back a ‘400 Bad Request’ status code. [PR-03]
TA_Id: CAMP11-205
NormativeSource: PR-03 (section: Required Formats / Duplicate Keys in JSON Objects)
Target: A response message (m2) to a request message (m1) with JSON content that has duplicate keys at same level.
Predicate: The HTTP code in the target (m2) is ‘400 Bad Request’.
PrescriptionLevel: preferred
Tag: conformance=Provider
Addressing normative statement:
A Provider SHALL return only those attributes of the queried resource whose name occurs in the list specified by the value of ‘select_attr’. [PR-47]
NormativeSource: PR-47 (“If a GET message is sent with a select_attr request parameter in the URI, then only the attributes of the queried resource that match these parameters must be returned.”) (derived from Section: Request parameters)
Target: A successful response message (HTTP code 200) (m4) to a GET resource query message (m3) that uses “select_attr” query parameter.
Prerequisite: A previous message (m1) of the form GET resource URI (with no select_attr query parameter) was sent with a successful response message (m2). (and assuming no “delete resource” message after m1).
Predicate: the body of the target message (m4) contains only the attributes of the resource within those returned in (m2), that match those attributes in the “select_attr” query parameter.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
If an attribute is not part of the resource, an HTTP 400 Bad Request status code SHALL be returned. [PR-09]
NormativeSource: PR-09 (section: Request Parameters)
Target: A response message (m4) to a GET resource query message (m3) that uses “select_attr ” query parameter.
Predicate: the HTTP code in the target message (m4) is 400.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement: (regular case with explicit value update)
To allow an update of a subset of a resource’s attributes, Providers SHALL support the use of the ‘select_attr’ query parameter in conjunction with the HTTP PUT method. [PR-76]
TA_Id: CAMP11-222a
NormativeSource: PR-76 (section: Partial Updates with PUT)
Target: A response message (m4) to a GET resource URI query message (m3).
Prerequisite:
Predicate: The target message (m4) is a successful response and the attributes in (m4) that also appear in the select_attr query parameter of (m1) as well as in (m1) body, show the same values as in the body of (m1).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement: (case with implicit value deletion)
To allow an update of a subset of a resource’s attributes, Providers SHALL support the use of the ‘select_attr’ query parameter in conjunction with the HTTP PUT method. [PR-76]
TA_Id: CAMP11-222b
NormativeSource: PR-76 (section: Partial Updates with PUT)
Target: A response message (m4) to a GET resource URI query message (m3).
Prerequisite:
Predicate: The target message (m4) is a successful response and the attributes that appear in the select_attr query parameter of (m1) but not in (m1) body, are absent (i.e. empty-valued) from (m4).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement: (case showing that attributes NOT present in select_attr are not affected )
To allow an update of a subset of a resource’s attributes, Providers SHALL support the use of the ‘select_attr’ query parameter in conjunction with the HTTP PUT method. [PR-76]
TA_Id: CAMP11-222c
NormativeSource: PR-76 (section: Partial Updates with PUT)
Target: A response message (m6) to a GET resource URI query message (m5).
Prerequisite:
Predicate: The target message (m6) is a successful response and shows same attribute values as in (m2) for those attributes that do not appear in the select_attr query parameter of (m3).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Upon receiving such a malformed request (see PR-12 case) the Provider SHALL respond with a 400 status code. [PR-13]
NormativeSource: PR-13 (section: Request Parameters )
Target: A response message (m4) to a PUT resource query message (m3) that uses “select_attr ” query parameter, where (m3) includes attributes in its request body that are not listed in select_attr values.
Predicate: the HTTP code in the target message (m4) is 400.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
All HTTP responses that return representation of a resource SHOULD use strong Etag response header field indicating the current value of the entity tag for the resource. [PR-20]
TA_Id: CAMP11-211
NormativeSource: PR-20 (section: Response Headers)
Target: A successful response message (HTTP code 200) (m2) to a GET resource message (m1).
Predicate: the target (m2) has an ETag HTTP header, with a valid entity tag value.
PrescriptionLevel: preferred
Tag: conformance=Provider
Addressing normative statement:
If the If-Match header field value in the request does not match the one on the server-side, the Provider SHALL send back a '412 Precondition Failed' status code. [PR-07]
TA_Id: CAMP11-212
NormativeSource: PR-07 (section: Request Headers)
Target: A response message (m2) to a PUT request message (m1) that has an empty If-Match HTTP header value.
Prerequisite: Some previous responses to GET resource messages show the use of ETag by the provider.
Predicate: the target message (m2) has HTTP code '412 Precondition Failed'.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On successfully processing an HTTP PUT request a Provider SHALL update all the Consumer-mutable attributes of the target resource, and only these, with the values of the matching attributes in the request. [PR-48]
On successfully processing the request the Provider SHALL create an assembly resource and return a 201 Created status code in the HTTP response. [PR-53]
TA_Id: CAMP11-213
NormativeSource: PR-48, RE-53 (section: Updating Resources)
Var: (resource) in {
sensor,
plan,
assembly,
component
}
Target: A successful response message (HTTP code 200)(m4) to a GET resource message (m3).
Prerequisite:
Predicate: the target message (m4) shows for consumer-mutable attributes (e.g. name. description) the same attribute values as their counterpart in the message (m1).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
If a resource attribute is present on a resource and if an HTTP PUT request omits that attribute, it SHOULD be treated by the Provider as a request to delete the attribute. [PR-25]
NormativeSource: PR-25, (section: Updating Resources)
Var: (resource) in {
sensor,
plan,
assembly,
component
}
Target: A successful response message (HTTP code 200)(m4) to a GET resource message (m3).
Prerequisite:
A previous message (m1) of the form PUT resource URI (with no select_attr query parameter) and with some consumer-mutable attribute missing (e.g. description) was sent with a successful response message (m2). (and assuming no “delete resource” message after m1).
Predicate: the target message (m4) does not show any (consumer-mutable) attribute name or value, for attribute names that were missing in (m1).
PrescriptionLevel: preferred
Tag: conformance=Provider
Addressing normative statement:
On receiving such a request the Provider SHALL generate an HTTP response with 403 HTTP status code. [PR-22]
NormativeSource: PR-22 (section: Mutability of Resources Attributes)
Var: (resource) in {
assembly,
component,
plan
}
Target: A response message (m4) to a PUT resource request (m3).
Prerequisite:
Predicate: The response (m4) has HTTP code 203
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers SHALL support the ‘add’, ‘remove’, and ‘replace’ operations. [PR-27]
Providers SHALL support the HTTP GET, PUT, and PATCH methods on all of the resources defined in this section. [RE-53]
NormativeSource: PR-27, RE-53 (section: Updating with JSON Patch)
Var: (resource) in {
assembly,
component,
plan
}
Target: A response message (m4) to a PATCH resource request (m3) that contains no other operations than ‘add’, ‘remove’, and ‘replace’.
Prerequisite:
Predicate: Target message (m4) has HTTP code 2xx .
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers SHALL support the ‘add’, ‘remove’, and ‘replace’ operations. [PR-27]
NormativeSource: PR-27, (RE-53) (section: Updating with JSON Patch)
Var: (resource) in {
assembly,
component,
plan,
service
}
Target: A successful response message (HTTP code 200)(m4) to a GET resource request message (m3).
Prerequisite:
A previous message (m1) of the form PATCH resource on same URI as (m3) was sent with a successful response message (m2). (and assuming no “delete resource” message after m1).
Predicate: the target message (m4) shows for consumer-mutable attributes the same attribute values as the message (m1) for “replace” and “add” ops, and it does not show any (consumer-mutable) attribute that was in an “remove” op in (m1).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
On successfully processing the request the Provider SHALL create a plan resource and return a 201 Created status code in the HTTP response. [PR-57]
NormativeSource: PR-57 (section: Registering a Plan by Reference)
Target: A response message (m2) to a POST plans message (m1).
Prerequisite: the target message (m2) has not an HTTP code 202 “accepted”
Predicate: the target message (m2) has HTTP code 201 “created”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statements:
On successfully processing the request the Provider SHALL create a plan resource and return a 201 Created status code in the HTTP response. [PR-57]
NormativeSource: PR-57 (section: Registering a Plan by Reference)
Target: A response message (m4) to a GET plan message (m3), with a representation_skew=NONE.
Prerequisite: A sequence of messages occurred as follows:
Predicate: the target message (m4) has HTTP code 200 AND its content satisfies the serialization schema (JSON ) for Plan, AND has a type attribute of value = “plan”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The Provider SHALL update the assembly_links attribute of the assemblies resource to include a reference to the newly created assembly resource. [PR-52]
TA_Id: CAMP11-302
NormativeSource: PR-52 (section: Deploying an Application by Reference)
Target: A response message (m4) to a GET assemblies message (m3), with a representation_skew=NONE.
Prerequisite: A sequence of messages previously occurred as follows:
Predicate: the target message (m4) has HTTP code 200 AND its assemblies.assembly_links resource contains the location URI returned by (m2).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The Provider SHALL update the assembly_links attribute of the assemblies resource to include a reference to the newly created assembly resource. [PR-55]
NormativeSource: PR-55 (PR-53, PR-54), (section: Deploying an Application by Value)
Target: A response message (m4) to a GET assemblies message (m3), with a representation_skew=NONE.
Prerequisite: A sequence of messages occurred as follows:
Predicate: the target message (m4) has HTTP code 200 AND its assemblies.assembly_links resource contains the location URI returned by (m2).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
An assembly resource SHALL have at least one reference to a component resource. [RE-39]
Providers that support Plans SHALL include this attribute (plan_uri) in all assembly resources. [RMR-04]
NormativeSource: RE-39, RMR-04
Target: A response message (m4) to a GET assembly message (m3), with a representation_skew=NONE.
Prerequisite: A sequence of messages occurred as follows:
Predicate: the target message (m4) has HTTP code 200 AND its assembly.components[] has at least one link to a Component resource, AND its assembly.plan_uri link is set to the URI used in (m1).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
If this attribute is present in the resource, Providers SHALL support the POST method on that resource in addition to the methods defined in Section 5.5, “HTTP Method Support”. [RE-38]
NormativeSource: RE-38 (section: Service Resource / parameter_definitions_uri)
Target: A response message (m2) to a POST service message (m1) that has the parameter_definitions_uri defined.
Predicate: the target message has HTTP code 201 “Created” and a location header with a URI.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
If a POST request body does not contain a value for a required parameter, a “400 Bad Request” response SHALL be returned. [PR-18]
NormativeSource: PR-18, (section: POST Body Parameters / Parameter Handling)
Var: (resource) in {
assembly,
plan,
service
}
Target: A response message (m6) to a POST resource message (m5), where (m5) is not setting a required parameter as defined in (m4).
Prerequisite:
Predicate: the target message (m6) has an HTTP error code 400 “Bad request”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
If a POST request body does not contain an acceptable value for a parameter, a “400 Bad Request” response SHALL be returned. [PR-19]
NormativeSource: PR-19, (section: POST Body Parameters / Parameter Handling)
Var: (resource) in {
assemblies,
plans,
service
}
Target: A response message (m6) to a POST resource message (m5), where (m5) is setting a parameter with a value incompatible with its parameter_type as defined in (m4).
Prerequisite:
Predicate: the target message (m6) has an HTTP error code 400 “Bad request”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
In addition to the methods defined in Section 5.5, “HTTP Method Support”, Providers SHALL support the HTTP DELETE method on the assembly resource. [RE-61]
NormativeSource: RE-61 (section: Deleting an Application Instance and a Deployed Application)
Target: A response message to a DELETE assembly message.
Prerequisite: The assembly URI exists as a link in assemblies.assembly_links obtained from platform.assemblies_uri from prior successful (HTTP code 200 “OK”) response message to a GET platform message.
Predicate: the target message has NOT an HTTP code 405 “Method Not Allowed”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On reception of a DELETE request a Provider SHALL remove the reference to the assembly resource from the assemblies resource’s assembly_links array. [RE-74]
NormativeSource: RE-74 (RE-61)(section: Deleting an Application Instance and a Deployed Application)
Target: A response message (m4) to a GET assembly URI message (m3).
Prerequisite: The following sequence of messages occurred:
Predicate: the target message (m4) has HTTP code 5xx, AND the URI does not exist anymore in a link in (m6) assemblies.assembly_links.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On reception of a DELETE request a Provider SHALL remove the assembly resource from the system along with any component resources referenced by that assembly resource. (i.e. the tree of resources that was created when the application was instantiated). [RE-73]
NormativeSource: RE-73, (RE-61)(section: assembly Resource)
Target: A response message (m6) to a GET component URI message (m5), where the component URI belongs to m2:assembly.components[] (see prerequisite).
Prerequisite: The following sequence of messages occurred prior to the target message:
Predicate: the target message (m6) has HTTP code 5xx.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
In addition to the methods defined in Section 5.5, “HTTP Method Support”, Providers SHALL support the HTTP DELETE method on the component resource. [RE-62]
NormativeSource: RE-62 (section: Component Resource)
Target: A response message (m4) to a GET component URI message (m3).
Prerequisite: The following sequence of messages occurred:
Predicate: the target message (m4) has HTTP code 5xx, AND the URI does not exist anymore as a link in (m6)assembly.components[].
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
In addition to the methods defined in Section 5.5, “HTTP Method Support”, Providers SHALL support the HTTP DELETE method on the component resource. [RE-62]
NormativeSource: RE-62 (section: Component Resource)
Target: A response message to a DELETE component message.
Prerequisite: The component URI exists as a link in an assembly.components[] as shown in a previous GET assembly message.
Predicate: the target message has NOT an HTTP code 405 “Method Not Allowed”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The following table lists the methods that SHALL be supported for each representation_skew value. [RE-12]
representation_skew value |
Methods Available |
CREATING |
GET, DELETE |
NONE |
All supported methods for that resource. |
UNKNOWN |
All supported methods for that resource. |
DESTROYING |
GET |
NormativeSource: RE-12, (RE-53) (section: representation_skew)
Var: (resource) in {
plan,
component,
assembly
}
Target: A response message (m4) to a PUT request (m3) to a resource.
Prerequisite: The following message sequence occurred:
Predicate: the target message has an 4xx HTTP code.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
(see CAMP11-329)
The following table lists the methods that SHALL be supported for each representation_skew value. [RE-12]
NormativeSource: RE-12, (RE-53) (section: representation_skew)
Var: (resource) in {
plan,
component,
assembly
}
Target: A response message (m4) to a PATCH resource message (m3).
Prerequisite: The following message sequence occurred:
Predicate: the target message has an 4xx HTTP code.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
(see CAMP11-329)
The following table lists the methods that SHALL be supported for each representation_skew value. [RE-12]
NormativeSource: RE-12, (RE-53) (section: representation_skew)
Var: (resource) in {
plan,
assembly
}
Target: A response message (m4) to a PUT resource message (m3).
Prerequisite: The following message sequence occurred:
Predicate: the target message has an 4xx HTTP code.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
(see CAMP11-329)
The following table lists the methods that SHALL be supported for each representation_skew value. [RE-12]
NormativeSource: RE-12, (RE-53) (section: representation_skew)
Var: (resource) in {
plan,
assembly
}
Target: A response message (m4) to a PATCH resource message (m3).
Prerequisite: The following message sequence occurred:
Predicate: the target message has an 4xx HTTP code.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
(see CAMP11-329)
The following table lists the methods that SHALL be supported for each representation_skew value. [RE-12]
NormativeSource: RE-12, (RE-53) (section: representation_skew)
Var: (resource) in {
plan,
assembly
}
Target: A response message (m4) to a DELETE resource message (m3).
Prerequisite: The following message sequence occurred:
Predicate: the target message has an 4xx HTTP code.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On successfully processing the request the Provider SHALL create a plan resource and return a 201 Created status code in the HTTP response. [PR-57]
NormativeSource: PR-57 (RMR-05)
Target: A response message (m2) to a POST plans message (m1) where (m1) has a “pdp_uri” attribute.
Prerequisite: the HTTP code in target (m2) is NOT 202 “accepted”.
Predicate: the HTTP code in target (m2) is 201 “Created”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On successfully processing the request the Provider SHALL create a plan resource and return a 201 Created status code in the HTTP response. [PR-57]
The Provider SHALL include the Location header in the HTTP response and the value of this header SHALL reference the newly created plan resource. [PR-58]
NormativeSource: PR-57, PR-58 (RMR-05)
Target: A response message (m2) to a POST plans message (m1) where (m1) has a “pdp_uri” attribute.
Prerequisite: the HTTP code in target (m2) is 201 “Created”.
Predicate: the target message contains a location header with the URI for the new plan resource AND this URI resolves (GET plan) to a plan resource with type attribute = “plan”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
The Provider SHALL update the plan_links attribute of the plans resource to include a reference to the newly created plan resource. [PR-59]
NormativeSource: PR-59
Target: A response message (m4) to a GET plans message (m3), with a representation_skew=NONE.
Prerequisite: A sequence of messages previously occurred as follows:
Predicate: the target message (m4) has HTTP code 200 AND its plans.plan_links attribute contains the location URI of the new plan resource returned by (m2).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On successfully processing the request the Provider SHALL create a plan resource and return a 201 Created status code in the HTTP response. [PR-62]
The Provider SHALL include the Location header in the HTTP response and the value of this header SHALL reference the newly created plan resource. [PR-63]
NormativeSource: PR-62, PR-63 (RMR-05)
Target: A response message (m2) to a POST plans message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type: application/x-zip or application/x-tar or application/x-tgz, or application/x-yaml.
Prerequisite: the HTTP code in target (m2) is 201 “Created”.
Predicate: the target message contains a location header with the URI for the new plan resource AND this URI resolves (GET plan) to a plan resource with type attribute = “plan”.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
To support the registration of Plans using a PDP, Providers SHALL accept the media types associated with the various formats as follows:
NormativeSource: PR-70, PR-71, PR-72, (RMR-05)
Target: A response message (m2) to a POST plans message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type: application/x-zip or application/x-tar or application/x-tgz.
Predicate: the HTTP code in target (m2) is 201 “Created” AND the target message contains a location header with the URI for the new plan resource, OR ( code = 202 “accepted” AND a subsequent GET on the returned Location header URI shows either representation_skew=CREATING or HTTP code 200 “OK”).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
To support the registration of Plans using a Plan file, Providers SHALL accept the use of the "application/x-yaml" media type. [PR-73]
NormativeSource: PR-73 (RMR-05)
Target: A response message (m2) to a POST plans message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type: application/x-yaml.
Predicate: the HTTP code in target (m2) is 201 “Created” AND the target message contains a location header with the URI for the new plan resource, OR ( code = 202 “accepted” AND a subsequent GET on the returned Location header URI shows either representation_skew=CREATING or HTTP code 200 “OK”).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers that support the plans resource and plan resources SHALL support the registration of Plans via HTTP POST requests on the plans resource as described in this section. [PR-75]
NormativeSource: PR-75, (RMR-05)
Target: A response message (m2) to a POST plans message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type = multipart/form-data, and the Content-Disposition header has name set to “plan_file”
Predicate: (the HTTP code in target (m2) is 201 “Created” AND the target message m2 contains a location header with the URI for the new plan resource), OR ( code = 202 “accepted” AND a subsequent GET on the returned Location header URI shows either representation_skew=CREATING or HTTP code 200 “OK”).
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers that support the plans resource and plan resources SHALL support the registration of Plans via HTTP POST requests on the plans resource as described in this section. [PR-75]
NormativeSource: PR-75, (RMR-05)
Target: A response message (m2) to a POST plans message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type = multipart/form-data, and the Content-Disposition header has name set to “pdp_file”
Predicate: (the HTTP code in target (m2) is 201 “Created” AND the target message m2 contains a location header with the URI for the new plan resource), OR ( code = 202 “accepted” AND a subsequent GET on the returned Location header URI shows either representation_skew=CREATING or HTTP code 200 “OK”) .
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers SHALL support the “https” URI scheme as defined in RFC 2818 [RFC2818]. [PDP-27]
NOTE: partial test.
NormativeSource: PDP-27 (section: ContentSpecification)
Target: A response message (m2) to a POST platform message (m1) that uses “https” scheme, and refers to a PDP or passes a PDP or a Plan by value, where some ArtifactSpecifiation element has a content element with an “href” attribute.
Prerequisite: the PDP and contained Plan are well-formed.
Predicate: the HTTP code in target message is 2xx.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers SHALL understand this delimiter and SHALL NOT resolve any content if the archive format is unsupported. [PDP-29]
NormativeSource: PDP-29 (section: ContentSpecification)
Target: A response to a POST platform message that refers to a PDP or passes a PDP or a Plan by value, where some ArtifactSpecifiation element has a content element with an “href” attribute, that uses the URI scheme “pdp”.
Prerequisite: the PDP and contained Plan are well-formed AND the archive format used in the first part of the URI path (before “!”) is known to be supported .
Predicate: the HTTP code in target is 2xx.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
A Provider SHALL support the following archive formats for a PDP:
To support the registration of Plans using a PDP, Providers SHALL accept the media types associated with the various formats as follows:
NormativeSource: PDP-02, PR-70, (RMR-02, PR-63)(section: Supported Archive Formats)
Target: A response message (m2) to a A POST platform message (m1) with no “pdp_uri” nor a “plan_uri” attribute, and with an embedded PDP of type .zip ( Content-Type: application/x-zip).
Predicate: the HTTP code in target (m2) is 201 “Created” AND the target message contains a location header with the URI for the deployed plan.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
A Provider SHALL support the following archive formats for a PDP:
To support the registration of Plans using a PDP, Providers SHALL accept the media types associated with the various formats as follows:
NormativeSource: PDP-03, PR-71 (PR-63) (section: Supported Archive Formats)
Target: A response message (m2) to a A POST platform message (m1) with no “pdp_uri” nor a “plan_uri” attribute, and with an embedded PDP of type .tar ( Content-Type: application/x-tar).
Predicate: the HTTP code in target (m2) is 201 “Created” AND the target message contains a location header with the URI for the deployed plan.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
A Provider SHALL support the following archive formats for a PDP:
To support the registration of Plans using a PDP, Providers SHALL accept the media types associated with the various formats as follows:
NormativeSource: PDP-04, PR-72 (PR-63) (section: Supported Archive Formats)
Target: A response message (m2) to a A POST platform message (m1) with no “pdp_uri” nor a “plan_uri” attribute, and with an embedded PDP of type .tar.gz ( Content-Type: application/x-tgz).
Predicate: the HTTP code in target (m2) is 201 “Created” AND the target message contains a location header with the URI for the deployed plan.
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On successfully processing the request the Provider SHALL create an assembly resource and return a 201 Created status code in the HTTP response. [PR-50]
NormativeSource: PR-50 (section: Deploying an Application by Reference)
Target: A response message (m2) to a POST assemblies message (m1) where (m1) has a either a “pdp_uri” or a “plan_uri” attribute.
Prerequisite: the target message (m2) has not an HTTP code 202 “accepted”
Predicate: the target message (m2) has HTTP code 201 “created”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On successfully processing the request the Provider SHALL create an assembly resource and return a 201 Created status code in the HTTP response. [PR-50]
The Provider SHALL include the Location header in the HTTP response and the value of this header SHALL reference the newly created assembly resource. [PR-51]
NormativeSource: PR-50, PR-51
Target: A response message (m2) to a POST assemblies message (m1) where (m1) has a either a “pdp_uri” or a “plan_uri” attribute.
Predicate: the target message contains a location header with the URI for the new assembly resource, OR ( code = 202 “accepted” AND a subsequent GET on the returned Location header URI shows either representation_skew=CREATING or HTTP code 200 “OK”.)
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On successfully processing the request the Provider SHALL create an assembly resource and return a 201 Created status code in the HTTP response. [PR-53]
Var: archtype in { application/x-zip, application/x-tar, application/x-tgz, application/x-yaml }
NormativeSource: PR-53, (PR-60), {PR-29, PR-30, PR-31, PR-32}
Target: A response message (m2) to a POST assemblies message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type = archtype.
Prerequisite: HTTP code in (m2) is NOT 202 “accepted” i.e. enough time elapsed to allow for the creation to complete.
Predicate: the HTTP code in target (m2) is 201 “Created”
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
On successfully processing the request the Provider SHALL create an assembly resource and return a 201 Created status code in the HTTP response. [PR-53]
The Provider SHALL include the Location header in the HTTP response and the value of this header SHALL reference the newly created assembly resource. [PR-54]
Var: archtype in { application/x-zip, application/x-tar, application/x-tgz, application/x-yaml }
NormativeSource: PR-53, PR-54, (PR-60), {PR-29, PR-30, PR-31, PR-32}
Target: A response message (m2) to a POST assemblies message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type = archtype.
Predicate: (the HTTP code in target (m2) is 201 “Created” AND the target message contains a location header with the URI for the new assembly resource), OR ( code = 202 “accepted” AND a subsequent GET on the returned Location header URI shows either representation_skew=CREATING or HTTP code 200 “OK”)
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Providers SHALL support the deployment of applications via HTTP POST requests on the assemblies resource as described in this section. [PR-74]
NormativeSource: PR-74, { PR-29, PR-30, PR-31, PR-32 }
Target: A response message (m2) to a POST assemblies message (m1) where (m1) does not contain a “pdp_uri” nor a “plan_uri” attribute, and contains a Content-Type = multipart/form-data.
Prerequisite: The name parameter of (m1) Content-Disposition header is set to “pdp_file”.
Predicate: (the HTTP code in target (m2) is 201 “Created” AND the target message m2 contains a location header with the URI for the new assembly resource), OR ( code = 202 “accepted” AND a subsequent GET on the returned Location header URI shows either representation_skew=CREATING or HTTP code 200 “OK”)
PrescriptionLevel: mandatory
Tag: conformance=Provider
Addressing normative statement:
Regardless of whether a Consumer attempts to create an assembly resource by POSTing to the assemblies resource or creates a plan resource by POSTing to the plans resource, a Provider that supports plans and plan resources SHALL create a plan resource for every deployed application. [RMR-11]
Providers that support Plans SHALL include this attribute (plan_uri) in all assembly resources. [RMR-04]
NormativeSource: RMR-11
Target: A response message (m4) to a GET assembly message (m3), with HTTP code 200 and with a representation_skew=NONE.
Prerequisite: A set of messages previously occurred as follows:
Predicate: the target message (m4) has its assembly.plan_uri link set to a plan Resource (a GET on that URI returns HTTP code 200 “OK”) AND the plan URI also exists in the plans.plan_links obtained from platform.plan_uris, (m2).
PrescriptionLevel: mandatory
Tag: conformance=Provider
These Test Assertions concern the Consumer as conformance target.
A Consumer SHALL serialize Resource data in its requests based on the definition of this Resource as described in the corresponding sub-section. [RE-71]
TA_Id: CAMP11-105
NormativeSource: RE-71 (section: Resources)
Var: (resource) in {
sensor,
plan,
assembly,
component
}
Target: A message (m1) of the form PUT resource URI (with no select_attr query parameter)
Predicate: the target message (m1) content satisfies the serialization schema (JSON ) for resource, AND has a type attribute of value = <resource name>.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
“false” indicates that the value(s) of the attribute SHALL NOT be changed by Consumers. [RE-09]
NormativeSource: RE-09, (RE-53) (section: Consumer-mutable)
Var: (resource) in {
assembly,
component,
platform
}
Target: A PUT request (m3) to a resource.
Prerequisite: The following message sequence occurred:
A previous message (m1) of the form GET resource URI was sent with a successful response message (m2). (and assuming no “delete resource” message after m1).
Predicate: The PUT request (m3) is providing same values as shown in (m2) for consumer-mutable=false attributes.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
Consumers and Providers SHALL express Timestamps in UTC (Coordinated Universal Time), with the special UTC designator ("Z"). [RE-65]
NormativeSource: RE-65 (section: Timestamp)
Target: A POST or PUT message that has a resource serialization showing the “timestamp” attribute.
Predicate: the Timestamp value conforms to the UTC (Universal Time Coordinated) with a “zero” timezone offset, i.e. with format terminated with the designator “Z”, of the form: yyyy '-' mm '-' dd 'T' hh ':' mm ':' ss ‘Z’ (Example: 1994-11-05T13:15:30Z)
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
Consumers and Providers SHALL NOT transmit JSON objects that contain duplicate keys. [PR-02]
NormativeSource: PR-02 (sections: Required Formats / Duplicate Keys in JSON Objects)
Target: A POST or a PUT request with JSON content to any platform resource.
Predicate: there is no duplicate JSON keys at same level in the JSON content of the target message.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
NOTE: the corresponding error handling TA (Provider side) is addressing PR-03.
Addressing normative statement:
A Consumer SHALL NOT include attributes, whose name does not occur in the list specified by the value of the ‘select_attr’ query parameter, in the entity body of a PUT request. [PR-12]
Note: Requirement about request parameters (6.5): "In order to address a subset of attributes in a resource, the client can use request parameters in PUT … When one or more request parameters are specified for a PUT request, a client shall not include attributes in the request entity body that are not specified in the request parameter."
NormativeSource: PR-12 (“If a PUT message is sent with a select_attr request parameter in the URI, then only the attributes that appear in the select_attr request parameter must be used in the body of the update message.”) (derived from section: Request parameters)
Target: A PUT request message to a resource, that uses “select_attr ” query parameter.
Predicate: every attribute present in the body of the target message also appears in the “select_attr” query parameter.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
All PUT requests that update a resource SHOULD contain the If-Match header field with a single entity tag value. [PR-06]
NormativeSource: PR-06 (section: Request Headers)
Target: A PUT request message to any resource existing in the platform.
Predicate: the target has an If-Match HTTP header.
PrescriptionLevel: preferred
Tag: conformance=Consumer
Addressing normative statement:
Consumers SHALL NOT send a request that changes the value of a resource attribute that is declared with a constraint of 'Mutable=false' or 'Consumer-mutable=false'. [PR-21]
NormativeSource: PR-21 (section: Mutability of Resources Attributes)
Var:
(resource) in {
plan,
assembly,
component
}
Target: A PUT resource request message.
Prerequisite:
A successful previous response message (m2) to a GET resource message (m1) (same resource URI as target) (and assuming no “delete resource” message after m1).
Predicate: the target message has all the consumer-immutable attributes for this resource type, as already present in the message (m2), and with same values as in (m2).
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
Providers SHALL support the HTTP PATCH method in conjunction with the “application/json-patch+json” media type with the following, additional provisions with respect to the operations defined in Section 4 of the JSON Patch specification: [PR-26]
NormativeSource: PR-26 (section: Updating with JSON Patch)
Var: (resource) in {
assembly,
component,
plan,
service
}
Target: A PATCH resource request.
Predicate: the media-type (Content-Type header) application/json-patch
is used in HTTP headers, AND the JSON content complies with JSON patch syntax (at least: an array of triples with keys “op”, “path” and “value”).
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statements:
The Plan file SHALL be located at the root of the PDP archive. [PLAN-01]
The Plan file SHALL be named “camp.yaml”. [PLAN-02]
NormativeSource: PLAN-01, PLAN-02 (section: Plan Schema)
Target: A POST message with a “pdp_uri” attribute to a plans resource (obtained from platform.plan_uris), or an assemblies resource (obtained from platform.assemblies_uri).
Predicate: the PDP identified by pdp_uri is an archive that contains at its root a file named “camp.yaml”, with a YAML structure recognizable as a Plan (same top-level attributes, and “tags”).
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
A Platform Deployment Package (PDP) SHALL contain a single Plan file. [PDP-11]
NormativeSource: PDP-11 (section: Plan Schema)
Target: A POST message with a “pdp_uri” attribute to a plans resource (obtained from platform.plan_uris, or to an assemblies resource (obtained from platform.assemblies_uri).
Predicate: the PDP identified by pdp_uri is an archive that contains at its root a file named “camp.yaml”, and does not contain any other yaml file of this name or of a structure recognizable as a plan (same top-level attributes, and “tags” ).
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statements:
The Plan file SHALL be located at the root of the PDP archive. [PLAN-01]
The Plan file SHALL be named “camp.yaml”. [PLAN-02]
NormativeSource: PLAN-01, PLAN-02, (section: Plan Schema)
Target: A POST message without a “pdp_uri” or “plan_uri” attribute, to a plans resource (obtained from platform.plan_uris, or to an assemblies resource (obtained from platform.assemblies_uri).
Predicate: the PDP in the embedded archive contains at its root a file named “camp.yaml”, with a structure recognizable as a plan (same top-level attributes, and “tags” ).
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
A Platform Deployment Package (PDP) SHALL contain a single Plan file. [PDP-11]
NormativeSource: PDP-11 (section: Plan Schema)
Target: A POST message without a “pdp_uri” or “plan_uri” attribute, to a plans resource (obtained from platform.plan_uris, or to an assemblies resource (obtained from platform.assemblies_uri)..
Predicate: the PDP in the embedded archive contains at its root a file named “camp.yaml”, and does not contain any other yaml file of this name or of a structure recognizable as a plan (same top-level attributes, and “tags” ).
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
A Plan file SHALL contain a single instance of a Plan. [PLAN-03]
NormativeSource: PLAN-03 (PDP-11) (section: Plan)
Target: A POST message to a plans URL, containing or referring to a Plan file.
Predicate: the Plan file identified in this POST contains a single yaml plan node (satisfies the yaml schema for this node).
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
For Plans that conform to this document, the value of this node (camp_version) SHALL be as defined in Section 1.8 “Specification Version”. [PLAN-05]
NormativeSource: PLAN-05 (PLAN-03) (section: campVersion)
Target: A POST message to a plans URL, containing or referring to a Plan file.
Predicate: the Plan file identified in this POST has a yaml node that has a camp_version tag with value “CAMP 1.1”.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
Plans SHALL use id values that are unique within the scope of the Plan. [PLAN-06]
NormativeSource: PLAN-06 (section: serviceSpecification)
Target: A POST message to a plans URL, containing or referring to a Plan file.
Predicate: the services array (ServiceSpecification[]) contained in the Plan file identified in this POST does NOT have two ServiceSpecification items with same id node value.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
If a Consumer includes this node in a Plan, the value of this node SHALL reference a Consumer-visible resource within the target Platform. [RMR-01]
NormativeSource: RMR-01 (section: ServiceSpecification)
Target: A POST message to a Plans URL, containing or referring to a Plan file.
Predicate: Any ServiceSpecification items that has an href node in the services array (ServiceSpecification[]) contained in the Plan file identified in this POST, has the href value resolve to an existing resource on the target platform.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
The Plan file SHALL conform to the description provided in this section. [PLAN-09]
NormativeSource: PLAN-09 (section: ContentSpecification)
Target: A POST message to a plans URL, containing or referring to a Plan file.
Predicate: in the Plan file identified in this POST , every ArtifactSpecification item (artifacts array) has a content node that has either an href node, or a data node but not both.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
The format of the manifest file and the certificate file SHALL be as defined by the OVF specification [OVF]. [PDP-10]
NormativeSource: PDP-10 (PDP-06) (section: Validating Integrity)
Target: A POST message to a plans URL, with either (a) a “pdp_uri”, or (b) a Content-Type: application/x-zip or application/x-tar or application/x-tgz.
Prerequisite: the PDP referenced in the target message contains a manifest (“camp.mf”) at its root.
Predicate: the manifest (“camp.mf”) at the root of the PDP conforms to the structure defined in OVF [DSP0243] for OVF manifest files.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
The format of the manifest file and the certificate file SHALL be as defined by the OVF specification [OVF]. [PDP-10]
NormativeSource: PDP-10 (section: Validating Integrity)
Target: A POST message to a plans URL, with either (a) a “pdp_uri”, or (b) a Content-Type: application/x-zip or application/x-tar or application/x-tgz.
Prerequisite: the PDP referenced in the target message contains a certificate (named “camp.cert”) at its root.
Predicate: the certificate (named “camp.cert”) at the root of the PDP conforms to the structure defined in OVF [DSP0243] for OVF certificate files.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statement:
Consumers SHALL follow the syntax and semantics described here when using URIs with a “pdp” scheme. [PLAN-07]
NormativeSource: PLAN-07 (section: ContentSpecification)
Target: A POST platform message that refers to a PDP or passes a PDP or a Plan by value, where some ArtifactSpecifiation element has a content element with an “href” attribute, that uses the URI scheme “pdp” and contains the “!” character.
Predicate: the URI either shows “!” just after the scheme, or just after an archive name AND the right part after “!” is a path for a file that is resolvable from the root of the archive.
PrescriptionLevel: mandatory
Tag: conformance=Consumer
Addressing normative statements:
The Plan file SHALL be located at the root of the PDP archive. [PLAN-01]
The Plan file SHALL be named “camp.yaml”. [PLAN-02]
NormativeSource: PLAN-01, PLAN-02 (section: Plan Schema)
Target: A PDP artifact.
Prerequisite: the PDP is in archive format (ZIP, TAR or GZIP).
Predicate: the PDP archive contains at its root a file named “camp.yaml”, with the YAML structure of a Plan.
PrescriptionLevel: mandatory
Tag: conformance=PDP
Addressing normative statement:
A Platform Deployment Package (PDP) SHALL contain a single Plan file. [PDP-11]
NormativeSource: PDP-11 (section: Plan Schema)
Target: A PDP artifact.
Predicate: the PDP contains (at its root if an archive) a file named “camp.yaml”, and does not contain any other yaml file of this name or of a structure recognizable as a plan.
PrescriptionLevel: mandatory
Tag: conformance=PDP
Addressing normative statement:
The format of the manifest file and the certificate file SHALL be as defined by the OVF specification [OVF]. [PDP-10]
NormativeSource: PDP-10 (PDP-06) (section: Validating Integrity)
Target: A PDP artifact.
Prerequisite: the PDP contains a manifest (“camp.mf”) at its root.
Predicate: the manifest (“camp.mf”) at the root of the PDP conforms to the structure defined in OVF [DSP0243] for OVF manifest files.
PrescriptionLevel: mandatory
Tag: conformance=PDP
Addressing normative statement:
The format of the manifest file and the certificate file SHALL be as defined by the OVF specification [OVF]. [PDP-10]
NormativeSource: PDP-10 (section: Validating Integrity)
Target: A PDP artifact.
Prerequisite: the PDP contains a certificate (named “camp.cert”) at its root.
Predicate: the certificate (named “camp.cert”) at the root of the PDP conforms to the structure defined in OVF [DSP0243] for OVF certificate files.
PrescriptionLevel: mandatory
Tag: conformance=PDP
Addressing normative statement:
A Plan file SHALL contain a single instance of a Plan. [PLAN-03]
NormativeSource: PLAN-03 (PDP-11) (section: Plan)
Target: A Plan file.
Predicate: the Plan file contains a single yaml plan node and satisfies the yaml schema for this node.
PrescriptionLevel: mandatory
Tag: conformance=Plan
Addressing normative statement:
For Plans that conform to this document, the value of this node (camp_version) SHALL be as defined in Section 1.8 “Specification Version”. [PLAN-05]
NormativeSource: PLAN-05 (PLAN-03) (section: campVersion)
Target: A Plan file.
Predicate: the Plan file has a yaml node that has a camp_version tag with value “CAMP 1.1”.
PrescriptionLevel: mandatory
Tag: conformance=Plan
Addressing normative statement:
Plans SHALL use id values that are unique within the scope of the Plan. [PLAN-06]
NormativeSource: PLAN-06 (section: ServiceSpecification)
Target: A Plan file.
Predicate: the services array (ServiceSpecification[]) contained in the Plan file does NOT have two ServiceSpecification items with same id node value.
PrescriptionLevel: mandatory
Tag: conformance=Plan
Addressing normative statement:
If a Consumer includes this node in a Plan, the value of this node SHALL reference a Consumer-visible resource within the target Platform. [RMR-01]
NormativeSource: RMR-01 (section: ServiceSpecification)
Target: A Plan file.
Prerequisite: the Plan is originating on Consumer side.
Predicate: Any ServiceSpecification items that has an href node in the services array (ServiceSpecification[]) contained in the Plan file identified in this POST, has the href value resolve to an existing resource on the target platform.
PrescriptionLevel: mandatory
Tag: conformance=Plan
Addressing normative statement:
The Plan file SHALL conform to the description provided in this section. [PLAN-09]
NormativeSource: PLAN-09 (section: ContentSpecification)
Target: A Plan file.
Predicate: in the Plan file, every ArtifactSpecification item (artifacts array) has a content node that has either an href node, or a data node but not both.
PrescriptionLevel: mandatory
Tag: conformance= Plan
Implementations of this specification are test suites that are derived from (or exercise) all or parts of the test assertions defined in this document. Such Implementations are called here CAMP test suites.
Note: Implementations of this CAMP Test Assertions specification are NOT to be confused with implementations of the CAMP specification, which are programs or parts of a system implementing the CAMP Provider functions, or the CAMP Consumer functions, or yet data artifacts such as a CAMP PDP or a CAMP Plan. However, these four types of CAMP implementations (CAMP Provider, CAMP Consumer, PDP, Plan) are useful to partition the related Test assertions, and to define related conformance profiles for test suites.
A test suite is typically composed of test cases. According to the definition in [TAG] adopted here, a test case is:
“A set of a test tools, software or files (data, programs, scripts, or instructions for manual operations) that verifies the adherence of a test assertion target to one or more normative statements in the specification.”
A test suite is said to implement a test assertion if it contains one or more test cases that exercise this test assertion, with the ability to assess whether an actual test target (i.e. an instance of the “target” of the test assertion) fulfills the associated normative CAMP requirement (as identified by the “normativeSource” of the test assertion). This means that the test case(s) related to a test assertion, must be able to either “pass” or “fail” most test targets, under expected usage conditions.
Identification of test restrictions:
Four conformance profiles are defined for CAMP test suites:
A CAMP test suite may claim conformance to more than one of the above conformance profiles.
In order to claim conformance to the CAMP Provider test suite conformance profile, a CAMP test suite MUST do both of the following:
Such a test suite is qualified for verifying conformance of a CAMP implementation to the CAMP Provider profile.
In order to claim conformance to the CAMP Consumer test suite conformance profile, a CAMP test suite MUST do both of the following:
Such a test suite is qualified for verifying conformance of a CAMP implementation to the CAMP Consumer profile.
In order to claim conformance to the CAMP PDP test suite conformance profile, a CAMP test suite MUST do both of the following:
Such a test suite is qualified for verifying conformance of a CAMP implementation to the CAMP PDP profile.
In order to claim conformance to the CAMP Plan test suite conformance profile, a CAMP test suite MUST do both of the following:
Such a test suite is qualified for verifying conformance of a CAMP implementation to the CAMP Plan profile.
This section is informative. The following individuals have participated in the creation of this specification and are gratefully acknowledged:
Participants:
Roshan Agrawal Rackspace Hosting, Inc.
Michael Behrens US Department of Defense (DoD)
Bhaskar Reddy Byreddy Software AG, Inc.
Mark Carlson Oracle
Martin Chapman Oracle
Francesco D'Andria Cloud4SOA
Jacques Durand Fujitsu Limited
Panagiotis Gouvas Cloud4SOA
Keith Grange JumpSoft
Alex Heneveld Cloudsoft Corporation Limited
Gershon Janssen Individual Member
David Jilk Standing Cloud, Inc.
Duncan Johnston-Watt Cloudsoft Corporation Limited
Anish Karmarkar Oracle
Tobias Kunze Red Hat
Eugene Luster US Department of Defense (DoD)
Ashok Malhotra Oracle
Alex McDonald NetApp
Rich Miller Cloudsoft Corporation Limited
Jeff Mischkinsky Oracle
Adrian Otto Rackspace Hosting, Inc.
Derek Palma Vnomic
Gilbert Pilz Oracle
Krishna Raman Red Hat
Tom Rutt Fujitsu Limited
Zhexuan Song Huawei Technologies Co., Ltd.
Charles Tupitza JumpSoft
Jeffrey West Oracle
Prasad Yendluri Software AG, Inc.