placement: Return new provider from POST /rps

To facilitate opaqueness of resource provider generation internals, we
need to return the (initial) generation when a provider is created. For
consistency with other APIs, we will do this by returning the entire
resource provider record (which includes the generation) from POST
/resource_providers.

Change-Id: I8624e194fe0173531c5aa2119c903e3c68b8c6cd
blueprint: generation-from-create-provider
This commit is contained in:
Eric Fried 2018-03-01 12:30:37 +00:00
parent aaf7b16f87
commit c6e16a65ca
14 changed files with 146 additions and 27 deletions

View File

@ -105,8 +105,16 @@ def create_resource_provider(req):
req.response.location = util.resource_provider_url( req.response.location = util.resource_provider_url(
req.environ, resource_provider) req.environ, resource_provider)
req.response.status = 201 if want_version.matches(min_version=(1, 20)):
req.response.content_type = None req.response.body = encodeutils.to_utf8(jsonutils.dumps(
_serialize_provider(req.environ, resource_provider, want_version)))
req.response.content_type = 'application/json'
modified = util.pick_last_modified(None, resource_provider)
req.response.last_modified = modified
req.response.cache_control = 'no-cache'
else:
req.response.status = 201
req.response.content_type = None
return req.response return req.response

View File

@ -63,6 +63,7 @@ VERSIONS = [
'1.18', # Support ?required=<traits> queryparam on GET /resource_providers '1.18', # Support ?required=<traits> queryparam on GET /resource_providers
'1.19', # Include generation and conflict detection in provider aggregates '1.19', # Include generation and conflict detection in provider aggregates
# APIs # APIs
'1.20', # Return 200 with provider payload from POST /resource_providers
] ]

View File

@ -243,3 +243,12 @@ response to be identical, and to include the ``resource_provider_generation``.
As with other generation-aware APIs, if the ``resource_provider_generation`` As with other generation-aware APIs, if the ``resource_provider_generation``
specified in the `PUT` request does not match the generation known by the specified in the `PUT` request does not match the generation known by the
server, a 409 Conflict error is returned. server, a 409 Conflict error is returned.
1.20 Return 200 with provider payload from POST /resource_providers
-------------------------------------------------------------------
The `POST /resource_providers` API, on success, returns 200 with a payload
representing the newly-created resource provider, in the same format as the
corresponding `GET /resource_providers/{uuid}` call. This is to allow the
caller to glean automatically-set fields, such as UUID and generation, without
a subsequent GET.

View File

@ -32,7 +32,7 @@ tests:
data: data:
name: $ENVIRON['RP_NAME'] name: $ENVIRON['RP_NAME']
uuid: $ENVIRON['RP_UUID'] uuid: $ENVIRON['RP_UUID']
status: 201 status: 200
response_headers: response_headers:
location: //resource_providers/[a-f0-9-]+/ location: //resource_providers/[a-f0-9-]+/

View File

@ -39,13 +39,13 @@ tests:
response_json_paths: response_json_paths:
$.errors[0].title: Not Acceptable $.errors[0].title: Not Acceptable
- name: latest microversion is 1.19 - name: latest microversion is 1.20
GET: / GET: /
request_headers: request_headers:
openstack-api-version: placement latest openstack-api-version: placement latest
response_headers: response_headers:
vary: /OpenStack-API-Version/ vary: /OpenStack-API-Version/
openstack-api-version: placement 1.19 openstack-api-version: placement 1.20
- name: other accept header bad version - name: other accept header bad version
GET: / GET: /

View File

@ -17,14 +17,14 @@ tests:
data: data:
name: rp_1 name: rp_1
uuid: 893337e9-1e55-49f0-bcfe-6a2f16fbf2f7 uuid: 893337e9-1e55-49f0-bcfe-6a2f16fbf2f7
status: 201 status: 200
- name: post new provider 2 - name: post new provider 2
POST: /resource_providers POST: /resource_providers
data: data:
name: rp_2 name: rp_2
uuid: 5202c48f-c960-4eec-bde3-89c4f22a17b9 uuid: 5202c48f-c960-4eec-bde3-89c4f22a17b9
status: 201 status: 200
- name: get by aggregates no result - name: get by aggregates no result
GET: '/resource_providers?member_of=in:83a3d69d-8920-48e2-8914-cadfd8fa2f91' GET: '/resource_providers?member_of=in:83a3d69d-8920-48e2-8914-cadfd8fa2f91'

View File

@ -27,11 +27,9 @@ tests:
data: data:
name: $ENVIRON['ALT_RP_NAME'] name: $ENVIRON['ALT_RP_NAME']
uuid: $ENVIRON['ALT_RP_UUID'] uuid: $ENVIRON['ALT_RP_UUID']
status: 201 status: 200
response_headers: response_headers:
location: //resource_providers/[a-f0-9-]+/ location: //resource_providers/[a-f0-9-]+/
response_forbidden_headers:
- content-type
- name: now 2 providers listed - name: now 2 providers listed
GET: /resource_providers GET: /resource_providers

View File

@ -40,10 +40,11 @@ tests:
response_strings: response_strings:
- admin required - admin required
- name: post new resource provider - name: post new resource provider - old microversion
POST: /resource_providers POST: /resource_providers
request_headers: request_headers:
content-type: application/json content-type: application/json
openstack-api-version: placement 1.19
data: data:
name: $ENVIRON['RP_NAME'] name: $ENVIRON['RP_NAME']
uuid: $ENVIRON['RP_UUID'] uuid: $ENVIRON['RP_UUID']
@ -53,6 +54,29 @@ tests:
response_forbidden_headers: response_forbidden_headers:
- content-type - content-type
- name: delete it
DELETE: $LOCATION
status: 204
- name: post new resource provider - new microversion
POST: /resource_providers
request_headers:
content-type: application/json
data:
name: $ENVIRON['RP_NAME']
uuid: $ENVIRON['RP_UUID']
status: 200
response_headers:
location: //resource_providers/[a-f0-9-]+/
response_json_paths:
$.uuid: $ENVIRON['RP_UUID']
$.name: $ENVIRON['RP_NAME']
$.parent_provider_uuid: null
$.generation: 0
$.links[?rel = "self"].href: /resource_providers/$ENVIRON['RP_UUID']
$.links[?rel = "inventories"].href: /resource_providers/$ENVIRON['RP_UUID']/inventories
$.links[?rel = "usages"].href: /resource_providers/$ENVIRON['RP_UUID']/usages
# On this one, don't test for which field was a duplicate because # On this one, don't test for which field was a duplicate because
# that depends on how the database reports columns. # that depends on how the database reports columns.
- name: try to create same all again - name: try to create same all again
@ -307,7 +331,12 @@ tests:
data: data:
name: parent name: parent
uuid: $ENVIRON['PARENT_PROVIDER_UUID'] uuid: $ENVIRON['PARENT_PROVIDER_UUID']
status: 201 status: 200
response_json_paths:
$.uuid: $ENVIRON['PARENT_PROVIDER_UUID']
$.name: parent
$.parent_provider_uuid: null
$.generation: 0
- name: get provider with old microversion no root provider UUID field - name: get provider with old microversion no root provider UUID field
GET: /resource_providers/$ENVIRON['PARENT_PROVIDER_UUID'] GET: /resource_providers/$ENVIRON['PARENT_PROVIDER_UUID']
@ -380,11 +409,12 @@ tests:
data: data:
name: altwparent name: altwparent
uuid: $ENVIRON['ALT_PARENT_PROVIDER_UUID'] uuid: $ENVIRON['ALT_PARENT_PROVIDER_UUID']
status: 201 status: 200
response_headers: response_headers:
location: //resource_providers/[a-f0-9-]+/ location: //resource_providers/[a-f0-9-]+/
response_forbidden_headers: response_json_paths:
- content-type $.uuid: $ENVIRON['ALT_PARENT_PROVIDER_UUID']
$.name: altwparent
- name: list all resource providers in a tree - name: list all resource providers in a tree
GET: /resource_providers?in_tree=$ENVIRON['ALT_PARENT_PROVIDER_UUID'] GET: /resource_providers?in_tree=$ENVIRON['ALT_PARENT_PROVIDER_UUID']
@ -510,7 +540,7 @@ tests:
content-type: application/json content-type: application/json
data: data:
name: cow name: cow
status: 201 status: 200
- name: try to rename that provider to existing name - name: try to rename that provider to existing name
PUT: $LOCATION PUT: $LOCATION
@ -565,7 +595,7 @@ tests:
content-type: application/json content-type: application/json
data: data:
name: a name name: a name
status: 201 status: 200
response_headers: response_headers:
location: //resource_providers/[a-f0-9-]+/ location: //resource_providers/[a-f0-9-]+/

View File

@ -23,7 +23,7 @@ tests:
data: data:
name: cn1 name: cn1
uuid: 8d830468-6395-46b0-b56a-f934a1d60bbe uuid: 8d830468-6395-46b0-b56a-f934a1d60bbe
status: 201 status: 200
- name: cn1 inventory - name: cn1 inventory
PUT: /resource_providers/8d830468-6395-46b0-b56a-f934a1d60bbe/inventories PUT: /resource_providers/8d830468-6395-46b0-b56a-f934a1d60bbe/inventories
@ -41,7 +41,7 @@ tests:
data: data:
name: cn2 name: cn2
uuid: ed6ea55d-01ce-4e11-ba97-13a4e5540b3e uuid: ed6ea55d-01ce-4e11-ba97-13a4e5540b3e
status: 201 status: 200
- name: cn2 inventory - name: cn2 inventory
PUT: /resource_providers/ed6ea55d-01ce-4e11-ba97-13a4e5540b3e/inventories PUT: /resource_providers/ed6ea55d-01ce-4e11-ba97-13a4e5540b3e/inventories
@ -65,7 +65,7 @@ tests:
data: data:
uuid: d450bd39-3b01-4355-9ea1-594f96594cf1 uuid: d450bd39-3b01-4355-9ea1-594f96594cf1
name: custom magic share name: custom magic share
status: 201 status: 200
- name: shared 1 inventory - name: shared 1 inventory
PUT: /resource_providers/d450bd39-3b01-4355-9ea1-594f96594cf1/inventories PUT: /resource_providers/d450bd39-3b01-4355-9ea1-594f96594cf1/inventories

View File

@ -313,7 +313,7 @@ resource_provider_generation_optional:
resource_provider_generation_v1_19: resource_provider_generation_v1_19:
<<: *resource_provider_generation <<: *resource_provider_generation
min_version: 1.19 min_version: 1.19
resource_provider_links: resource_provider_links: &resource_provider_links
type: array type: array
in: body in: body
required: true required: true
@ -326,6 +326,11 @@ resource_provider_links:
Traits relationship link is available starting from version 1.6. Traits relationship link is available starting from version 1.6.
Allocations relationship link is available starting from version 1.11. Allocations relationship link is available starting from version 1.11.
resource_provider_links_v1_20:
<<: *resource_provider_links
description: |
A list of links associated with the resource provider.
resource_provider_name: resource_provider_name:
type: string type: string
in: body in: body
@ -344,14 +349,20 @@ resource_provider_parent_provider_uuid: &resource_provider_parent_provider_uuid
required: false required: false
description: > description: >
The UUID of the immediate parent of the resource provider. The UUID of the immediate parent of the resource provider.
resource_provider_parent_provider_uuid_1_14: &resource_provider_parent_provider_uuid_1_14
<<: *resource_provider_parent_provider_uuid
min_version: 1.14 min_version: 1.14
resource_provider_parent_provider_uuid_required: resource_provider_parent_provider_uuid_required:
<<: *resource_provider_parent_provider_uuid <<: *resource_provider_parent_provider_uuid
required: true required: true
resource_provider_root_provider_uuid_required: resource_provider_root_provider_uuid_no_min: &resource_provider_root_provider_uuid_no_min
type: string type: string
in: body in: body
required: true required: true
description: >
UUID of the top-most provider in this provider tree.
resource_provider_root_provider_uuid_required:
<<: *resource_provider_root_provider_uuid_no_min
description: > description: >
Read-only UUID of the top-most provider in this provider tree. Read-only UUID of the top-most provider in this provider tree.
min_version: 1.14 min_version: 1.14

View File

@ -64,7 +64,7 @@ Request
- uuid: resource_provider_uuid_path - uuid: resource_provider_uuid_path
- name: resource_provider_name - name: resource_provider_name
- parent_provider_uuid: resource_provider_parent_provider_uuid - parent_provider_uuid: resource_provider_parent_provider_uuid_1_14
Request example Request example
--------------- ---------------

View File

@ -63,7 +63,8 @@ Create resource provider
Create a new resource provider. Create a new resource provider.
Normal Response Codes: 201 Normal Response Codes: 201 (microversions 1.0 - 1.19), 200 (microversions
1.20 - )
Error response codes: conflict(409) Error response codes: conflict(409)
@ -78,7 +79,7 @@ Request
- name: resource_provider_name - name: resource_provider_name
- uuid: resource_provider_uuid_opt - uuid: resource_provider_uuid_opt
- parent_provider_uuid: resource_provider_parent_provider_uuid - parent_provider_uuid: resource_provider_parent_provider_uuid_1_14
Request example Request example
--------------- ---------------
@ -86,11 +87,30 @@ Request example
.. literalinclude:: ./samples/resource_providers/create-resource_providers-request.json .. literalinclude:: ./samples/resource_providers/create-resource_providers-request.json
:language: javascript :language: javascript
Response Response (microversions 1.0 - 1.19)
-------- -----------------------------------
.. rest_parameters:: parameters.yaml .. rest_parameters:: parameters.yaml
- Location: location - Location: location
No body content is returned on a successful POST. No body content is returned on a successful POST.
Response (microversions 1.20 - )
--------------------------------
.. rest_parameters:: parameters.yaml
- Location: location
- generation: resource_provider_generation
- uuid: resource_provider_uuid
- links: resource_provider_links_v1_20
- name: resource_provider_name
- parent_provider_uuid: resource_provider_parent_provider_uuid
- root_provider_uuid: resource_provider_root_provider_uuid_no_min
Response Example (microversions 1.20 - )
----------------------------------------
.. literalinclude:: ./samples/resource_providers/create-resource_provider.json
:language: javascript

View File

@ -0,0 +1,33 @@
{
"generation": 0,
"links": [
{
"href": "/placement/resource_providers/7d2590ae-fb85-4080-9306-058b4c915e3f",
"rel": "self"
},
{
"href": "/placement/resource_providers/7d2590ae-fb85-4080-9306-058b4c915e3f/aggregates",
"rel": "aggregates"
},
{
"href": "/placement/resource_providers/7d2590ae-fb85-4080-9306-058b4c915e3f/inventories",
"rel": "inventories"
},
{
"href": "/placement/resource_providers/7d2590ae-fb85-4080-9306-058b4c915e3f/usages",
"rel": "usages"
},
{
"href": "/placement/resource_providers/7d2590ae-fb85-4080-9306-058b4c915e3f/traits",
"rel": "traits"
},
{
"href": "/placement/resource_providers/7d2590ae-fb85-4080-9306-058b4c915e3f/allocations",
"rel": "allocations"
}
],
"name": "NFS Share",
"uuid": "7d2590ae-fb85-4080-9306-058b4c915e3f",
"parent_provider_uuid": "542df8ed-9be2-49b9-b4db-6d3183ff8ec8",
"root_provider_uuid": "542df8ed-9be2-49b9-b4db-6d3183ff8ec8"
}

View File

@ -0,0 +1,9 @@
---
features:
- |
In placement API microversion 1.20, a successful `POST /resource_providers`
returns 200 with a payload representing the newly-created resource
provider. The format is the same format as the result of the corresponding
``GET /resource_providers/{uuid}`` call. This is to allow the caller to
glean automatically-set fields, such as UUID and generation, without a
subsequent GET.