From 82e0ab3a2621d6b08a587e5a765d4fa973dadfec Mon Sep 17 00:00:00 2001 From: Bertrand Souville Date: Wed, 17 Aug 2016 22:12:23 +0200 Subject: Update Promise documentation JIRA: PROMISE-78 Change-Id: I3b34c124d45b50ca3324dd776a0c1c35248aa159 Signed-off-by: Bertrand Souville --- docs/userguide/feature.configguide.rst | 63 ++++ docs/userguide/feature.userguide.rst | 287 +++++++++++++++ docs/userguide/featureusage.rst | 399 --------------------- docs/userguide/images/LICENSE | 14 + docs/userguide/images/screenshot_promise.png | Bin 0 -> 101419 bytes .../images/screenshot_promise_install.png | Bin 0 -> 77709 bytes docs/userguide/index.rst | 16 +- 7 files changed, 374 insertions(+), 405 deletions(-) create mode 100644 docs/userguide/feature.configguide.rst create mode 100644 docs/userguide/feature.userguide.rst delete mode 100644 docs/userguide/featureusage.rst create mode 100644 docs/userguide/images/LICENSE create mode 100755 docs/userguide/images/screenshot_promise.png create mode 100644 docs/userguide/images/screenshot_promise_install.png (limited to 'docs/userguide') diff --git a/docs/userguide/feature.configguide.rst b/docs/userguide/feature.configguide.rst new file mode 100644 index 0000000..48082c3 --- /dev/null +++ b/docs/userguide/feature.configguide.rst @@ -0,0 +1,63 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. +.. http://creativecommons.org/licenses/by/4.0 + +Manual testing +============== + +Promise installation +-------------------- + +Install nodejs, npm and promise + +.. code-block:: bash + + curl -sL https://deb.nodesource.com/setup_4.x | sudo -E bash - + sudo apt-get install -y nodejs + sudo npm -g install npm@latest + git clone https://github.com/opnfv/promise.git + cd promise + npm install + +Please note that the last command 'npm install' will install all needed dependencies +for promise (including yangforge and mocha) + +.. figure:: images/screenshot_promise_install.png + :name: figure1 + :width: 90% + + +Validation +---------- +Please perform the following preparation steps: + +1. Set OpenStack environment parameters properly (e.g. source openrc admin demo + in DevStack) +2. Create OpenStack tenant (e.g. promise) and tenant user (e.g. promiser) +3. Create a flavor in Nova with 1 vCPU and 512 MB RAM +4. Create a private network, subnet and router in Neutron +5. Create an image in Glance + +Once done, the promise test script can be invoked as follows (as a single line +command): + +.. code-block:: bash + + NODE_ENV=mytest \ + OS_TENANT_NAME=promise \ + OS_USERNAME=promiser \ + OS_PASSWORD= \ + OS_TEST_FLAVOR= \ + OS_TEST_NETWORK= \ + OS_TEST_IMAGE= \ + npm run -s test -- --reporter json > promise-results.json + +The results of the tests will be stored in the promise-results.json file. + +The results can also be seen in the console ("npm run -s test") + +.. figure:: images/screenshot_promise.png + :name: figure2 + :width: 90% + +All 33 tests passing?! +Congratulations, promise has been successfully installed and configured. diff --git a/docs/userguide/feature.userguide.rst b/docs/userguide/feature.userguide.rst new file mode 100644 index 0000000..ac035f4 --- /dev/null +++ b/docs/userguide/feature.userguide.rst @@ -0,0 +1,287 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. +.. http://creativecommons.org/licenses/by/4.0 + +Promise description +=================== +Promise is a resource reservation and management project to identify NFV related +requirements and realize resource reservation for future usage by capacity +management of resource pools regarding compute, network and storage. + +The following are the key features provided by this module: + +* Capacity Management +* Reservation Management +* Allocation Management + +Promise capabilities and usage +============================== +The Colorado implementation of Promise is built with the YangForge data modeling +framework [#f2]_ , using a shim-layer on top of OpenStack to provide +the Promise features. This approach requires communication between +Consumers/Administrators and OpenStack to pass through the shim-layer. The +shim-layer intercepts the message flow to manage the allocation requests based +on existing reservations and available capacities in the providers. It also +extracts information from the intercepted messages in order to update its +internal databases. Furthermore, Promise provides additional intent-based APIs +to allow a Consumer or Administrator to perform capacity management (i.e. add +providers, update the capacity, and query the current capacity and utilization +of a provider), reservation management (i.e. create, update, cancel, query +reservations), and allocation management (i.e. create, destroy instances). + +Detailed information about Promise use cases, features, interface +specifications, work flows, and the underlying Promise YANG schema can be found +in the Promise requirement document [#f1]_ . + +Promise features and API usage guidelines and examples +------------------------------------------------------ +This section lists the Promise features and API implemented in OPNFV Colorado. + +Note: The listed parameters are optional unless explicitly marked as "mandatory". + +Reservation management +^^^^^^^^^^^^^^^^^^^^^^ +The reservation management allows a Consumer to request reservations for +resource capacity. Reservations can be for now or a later time window. +After the start time of a reservation has arrived, the Consumer can issue +create server instance requests against the reserved capacity. Note, a +reservation will expire after a predefined *expiry* time in case no +allocation referring to the reservation is requested. + +The implemented workflow is well aligned with the described workflow in the +Promise requirement document [#f1]_ (Section 6.1) except for the +"multi-provider" scenario as described in :ref:`multi-provider` . + +.. _create-reservation: + +*create-reservation* +"""""""""""""""""""" + +This operation allows making a request to the reservation system to reserve +resources. + +The operation takes the following input parameters: + +* start: start time of the requested reservation +* end: end time of the requested reservation +* capacity.instances: amount of instances to be reserved +* capacity.cores: amount of cores to be reserved +* capacity.ram: amount of ram in MB to be reserved + +Promise will check the available capacity in the given time window and in case +sufficient capacity exists to meet the reservation request, will mark those +resources "reserved" in its reservation map. + +*update-reservation* +"""""""""""""""""""" + +This operation allows to update the reservation details for an existing +reservation. + +It can take the same input parameters as in *create-reservation* +but in addition requires a mandatory reference to the *reservation-id* of the +reservation that shall be updated. + +*cancel-reservation* +"""""""""""""""""""" + +This operation is used to cancel an existing reservation. + +The operation takes the following input parameter: + +* reservation-id (mandatory): identifier of the reservation to be canceled. + +*query-reservation* +""""""""""""""""""" + +The operation queries the reservation system to return reservation(s) matching +the specified query filter, e.g., reservations that are within a specified +start/end time window. + +The operation takes the following input parameters to narrow down the query +results: + +* without: excludes specified collection identifiers from the result +* elements.some: query for ResourceCollection(s) that contain some or more of these element(s) +* elements.every: query for ResourceCollection(s) that contain all of these element(s) +* window.start: matches entries that are within the specified start/ +* window.end: end time window +* window.scope: if set to 'exclusive', only reservations with start AND end time + within the time window are returned. Otherwise ('inclusive'), all + reservation starting OR ending in the time windows are returned. +* show-utilization: boolean value that specifies whether to also return the + resource utilization in the queried time window or not + +Allocation management +^^^^^^^^^^^^^^^^^^^^^ + +*create-instance* +""""""""""""""""" + +This operation is used to create an instance of specified resource(s) for +immediate use utilizing capacity from the pool. *Create-instance* requests can +be issued against an existing reservation, but also allocations without a +reference to an existing reservation are allowed. In case the allocation +request specifies a reservation identifier, Promise checks if a reservation +with that ID exists, the reservation start time has arrived (i.e. the +reservation is 'active'), and the required capacity for the requested flavor is +within the available capacity of the reservation. If those conditions are met, +Promise creates a record for the allocation (VMState="INITIALIZED") and update +its databases. If no *reservation_id* was provided in the allocation request, +Promise checks whether the required capacity to meet the request can be +provided from the available, non-reserved capacity. If yes, Promise creates a +record for the allocation with an unique *instance-id* and update its +databases. In any other case, Promise rejects the *create-instance* request. + +In case the *create-instance* request is rejected, Promise responds with a +"status=rejected" providing the reason of the rejection. This will help the +Consumer to take appropriate actions, e.g., send an updated *create-instance* +request. In case the *create-instance* request was accepted and a related +allocation record has been created, the shim-layer issues a *createServer* +request to the VIM Controller (i.e. Nova) providing all information to create +the server instance. + +The operation takes the following input parameters: + +* name (mandatory): Assigned name for the instance to be created +* image (mandatory): the image to be booted in the new instance +* flavor (mandatory): the flavor of the requested server instance +* networks: the list of network uuids of the requested server instance +* provider-id: identifier of the provider where the instance shall be created +* reservation-id: identifier of a resource reservation the *create-instance* + +The Colorado implementation of Promise has the following limitations: + +* All create server instance requests shall pass through the Promise + shim-layer such that Promise can keep track of all allocation requests. This + is necessary as in the current release the sychronization between the VIM + Controller and Promise on the available capacity is not yet implemented. +* *Create-allocation* requests are limited to "simple" allocations, i.e., the + current workflow only supports the Nova compute service and + *create-allocation* requests are limited to creating one server instance at a + time +* Prioritization of reservations and allocations is yet not implemented. + Future version may allow certain policy-based conflict resolution where, + e.g., new allocation request with high priority can "forcefully" terminate + lower priority allocations. + + +*destroy-instance* +"""""""""""""""""" + +This operation request to destroy an existing server instance and release it +back to the pool. + +The operation takes the following input parameter: + +* instance-id: identifier of the server instance to be destroyed + +Capacity management +^^^^^^^^^^^^^^^^^^^ +The capacity management feature allows the Consumer or Administrator to do +capacity planning, i.e. the capacity available to the reservation management +can differ from the actual capacity in the registered provider(s). This feature +can, e.g., be used to limit the available capacity for a given time window due +to a planned downtime of some of the resources, or increase the capacity +available to the reservation system in case of a planned upgrade of the +available capacity. + +*increase/decrease-capacity* +"""""""""""""""""""""""""""" + +This operations allows to increase/decrease the total capacity that is made +available to the Promise reservation service between a specified window in +time. It does NOT increase the actual capacity of a given resource provider, +but is used for capacity management inside Promise. + +This feature can be used in different ways, like + +* Limit the capacity available to the reservation system to a value below 100% + of the available capacity in the VIM, e.g., in order to leave "buffer" in the + actual NFVI to be used outside the Promise reservation service. + +* Inform the reservation system that, from a given time in the future, + additional resources can be reserved, e.g., due to a planned upgrade of the + available capacity of the provider. + +* Similarily, the "decrease-capacity" can be used to reduce the consumable + resources in a given time window, e.g., to prepare for a planned downtime of + some of the resources. + +* Expose multiple reservation service instances to different consumers sharing + the same resource provider. + +The operation takes the following input parameters: + +* start: start time for the increased/decreased capacity +* end: end time for the increased/decreased capacity +* capacity.cores: Increased/decreased amount of cores +* capacity.ram: Increased/decreased amount of RAM +* capacity.instances: Increased/decreased amount of instances + +Note, increase/decreasing the capacity in Promise is completely transparent to +the VIM. As such, when increasing the virtual capacity in Promise (e.g. for a +planned upgrade of the capacity), it is in the responsibility of the +Consumer/Administrator to ensure sufficient resources in the VIM are available +at the appropriate time, in order to prevent allocations against reservations +to fail due to a lack of resources. Therefore, this operations should only be +used carefully. + + +*query-capacity* +"""""""""""""""" + +This operation is used to query the available capacity information of the +specified resource collection. A filter attribute can be specified to narrow +down the query results. + +The current implementation supports the following filter criteria: + +* time window: returns reservations matching the specified window + +* window scope: if set to 'exclusive', only reservations with start AND end time + within the time window are returned. Otherwise, all reservation starting OR + ending in the time windows are returned. + +* metric: query for one of the following capacity metrics: + + * 'total': resource pools + * 'reserved': reserved resources + * 'usage': resource allocations + * 'available': remaining capacity, i.e. neither reserved nor allocated + +.. _multi-provider: + +(Multi-)provider management +^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +This API towards OpenStack allows a Consumer/Administrator to add and remove +resource providers to Promise. Note, Promise supports a multi-provider +configuration, however, for Colorado, multi-provider support is not yet +fully supported. + +*add-provider* +"""""""""""""" + +This operation is used to register a new resource provider into the Promise +reservation system. + +Note, for Colorado, the add-provider operation should only be used to +register one provider with the Promise shim-layer. Further note that currently +only OpenStack is supported as a provider. + +The operation takes the following input parameters: + +* provider-type (mandatory) = 'openstack': select a specific resource provider + type. +* endpoint (mandatory): target URL endpoint for the resource provider. +* username (mandatory) +* password (mandatory) +* region: specified region for the provider +* tenant.id: id of the OpenStack tenant/project +* tenant.name: name of the OpenStack tenant/project + +.. [#f1] Promise requirement document, + http://artifacts.opnfv.org/promise/docs/requirements/index.html + +.. [#f2] YangForge framework, http://github.com/opnfv/yangforge + diff --git a/docs/userguide/featureusage.rst b/docs/userguide/featureusage.rst deleted file mode 100644 index 9c9a66d..0000000 --- a/docs/userguide/featureusage.rst +++ /dev/null @@ -1,399 +0,0 @@ -.. This work is licensed under a Creative Commons Attribution 4.0 International License. -.. http://creativecommons.org/licenses/by/4.0 - -Promise capabilities and usage -============================== - -Promise is a resource reservation and management project to identify NFV related -requirements and realize resource reservation for future usage by capacity -management of resource pools regarding compute, network and storage. - -The following are the key features provided by this module: - -* Capacity Management -* Reservation Management -* Allocation Management - -The Brahmaputra implementation of Promise is built with the YangForge data -modeling framework [#f2]_ , using a shim-layer on top of OpenStack to provide -the Promise features. This approach requires communication between -Consumers/Administrators and OpenStack to pass through the shim-layer. The -shim-layer intercepts the message flow to manage the allocation requests based -on existing reservations and available capacities in the providers. It also -extracts information from the intercepted messages in order to update its -internal databases. Furthermore, Promise provides additional intent-based APIs -to allow a Consumer or Administrator to perform capacity management (i.e. add -providers, update the capacity, and query the current capacity and utilization -of a provider), reservation management (i.e. create, update, cancel, query -reservations), and allocation management (i.e. create, destroy, query -instances). - -Detailed information about Promise use cases, features, interface -specifications, work flows, and the underlying Promise YANG schema can be found -in the Promise requirement document [#f1]_ . - - -Promise usage -------------- - -The yfc run command will load the primary application package from this -repository along with any other dependency files/assets referenced within the -YAML manifest and instantiate the opnfv-promise module and run REST/JSON -interface by default listeningon port 5000.:: - $ yfc run promise.yaml - - -You can also checkout the GIT repository (https://github.com/opnfv/promise/) or -simply download the files into your local system and run the application. - - -Promise feature and API usage guidelines and examples ------------------------------------------------------ - -This section lists the Promise features and API implemented in OPNFV Brahmaputra. - - -Note 1: In contrast to ETSI NFV specifications and the detailed interface -specification in Section 7, the Promise shim-layer implementation does not -distinguish intent interfaces per resource type, i.e. the various capacity, -reservations, etc. operations have different endpoints for each domain such as -compute, storage, and network. The current shim-layer implementation does not -separate the endpoints for performing the various operations. - -Note 2: The listed parameters are optional unless explicitly marked as -"mandatory". - - -Reservation management -^^^^^^^^^^^^^^^^^^^^^^ - -The reservation management allows a Consumer to request reservations for -resource capacity or specific resource elements. Reservations can be for now or -a later time window. After the start time of a reservation has arrived, the -Consumer can issue create server instance requests against the reserved -capacity / elements. Note, a reservation will expire after a predefined -*expiry* time in case no allocation referring to the reservation is requested. - -The implemented workflow is well aligned with the described workflow in the -Promise requirement document [#f1]_ (Clause 6.1) except for the -"multi-provider" scenario as described in :ref:`multi-provider` . - -.. _create-reservation: - -*create-reservation* -"""""""""""""""""""" - -This operation allows making a request to the reservation system to reserve -resources. The Consumer can either request to reserve a certain capacity -(*container*) or specific resource elements (*elements*), like a certain server -instance. - -The operation takes the following input parameters: - -* start: start time of the requested reservation -* end: end time of the requested reservation -* container: request for reservation of capacity - - * instances: number of instances - * cores: number of cores - * ram: size of ram (in MB) - * networks: number of networks - * addresses: number of (public) IP addresses - * ports: number of ports - * routers: number of routers - * subnets: number of subnets - * gigabytes: size of storage (in GB) - * volumes: number of volumes - * snapshots: number of snapshots - -* elements: reference to a list of 'pre-existing' resource elements that are - required for fulfillment of the resource-usage-request - - * instance-identifier: identifier of a specific resource element - -* zone: identifier of an Availability Zone - -Promise will check the available capacity in the given time window and in case -sufficient capacity exists to meet the reservation request, will mark those -resources "reserved" in its reservation map. - - -*update-reservation* -"""""""""""""""""""" - -This operation allows to update the reservation details for an existing -reservation. - -It can take the same input parameters as in *create-reservation* -but in addition requires a mandatory reference to the *reservation-id* of the -reservation that shall be updated. - - -*cancel-reservation* -"""""""""""""""""""" - -This operation is used to cancel an existing reservation. - -The operation takes the following input parameter: - -* reservation-id (mandatory): identifier of the reservation to be canceled. - - -*query-reservation* -""""""""""""""""""" - -The operation queries the reservation system to return reservation(s) matching -the specified query filter, e.g., reservations that are within a specified -start/end time window. - -The operation takes the following input parameters to narrow down the query -results: - -* zone: identifier of an Availability Zone -* without: excludes specified collection identifiers from the result -* elements: - - * some: query for ResourceCollection(s) that contain some or more of these - element(s) - * every: query for ResourceCollection(s) that contain all of these - element(s) - -* window: matches entries that are within the specified start/end time window - - * start: start time - * end: end time - * scope: if set to 'exclusive', only reservations with start AND end time - within the time window are returned. Otherwise ('inclusive'), all - reservation starting OR ending in the time windows are returned. - -* show-utilization: boolean value that specifies whether to also return the - resource utilization in the queried time window or not - - -*subscribe-reservation-events* / *notify-reservation-events* -"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" - -Subscription to receive notifications about reservation-related events, e.g. a -reservation is about to expire or a reservation is in conflict state due to a -failure in the NFVI. - -Note, this feature is not yet available in Brahmaputra release. - - - -Allocation management -^^^^^^^^^^^^^^^^^^^^^ - -*create-instance* -""""""""""""""""" - -This operation is used to create an instance of specified resource(s) for -immediate use utilizing capacity from the pool. *Create-instance* requests can -be issued against an existing reservation, but also allocations without a -reference to an existing reservation are allowed. In case the allocation -request specifies a reservation identifier, Promise checks if a reservation -with that ID exists, the reservation start time has arrived (i.e. the -reservation is 'active'), and the required capacity for the requested flavor is -within the available capacity of the reservation. If those conditions are met, -Promise creates a record for the allocation (VMState="INITIALIZED") and update -its databases. If no *reservation_id* was provided in the allocation request, -Promise checks whether the required capacity to meet the request can be -provided from the available, non-reserved capacity. If yes, Promise creates a -record for the allocation with an unique *instance-id* and update its -databases. In any other case, Promise rejects the *create-instance* request. - -In case the *create-instance* request is rejected, Promise responds with a -"status=rejected" providing the reason of the rejection. This will help the -Consumer to take appropriate actions, e.g., send an updated *create-instance* -request. In case the *create-instance* request was accepted and a related -allocation record has been created, the shim-layer issues a *createServer* -request to the VIM Controller providing all information to create the server -instance. - -The operation takes the following input parameters: - -* name (mandatory): Assigned name for the instance to be created -* image (mandatory): the image to be booted in the new instance -* flavor (mandatory): the flavor of the requested server instance -* networks: the list of network uuids of the requested server instance -* provider-id: identifier of the provider where the instance shall be created -* reservation-id: identifier of a resource reservation the *create-instance* - is issued against - -The Brahamputra implementation of Promise has the following limitations: - -* All create server instance requests shall pass through the Promise - shim-layer such that Promise can keep track of all allocation requests. This - is necessary as in the current release the sychronization between the VIM - Controller and Promise on the available capacity is not yet implemented. -* *Create-allocation* requests are limited to "simple" allocations, i.e., the - current workflow only supports the Nova compute service and - *create-allocation* requests are limited to creating one server instance at a - time -* Prioritization of reservations and allocations is yet not implemented. - Future version may allow certain policy-based conflict resolution where, - e.g., new allocation request with high priority can "forcefully" terminate - lower priority allocations. - - -*destroy-instance* -"""""""""""""""""" - -This operation request to destroy an existing server instance and release it -back to the pool. - -The operation takes the following input parameter: - -* instance-id: identifier of the server instance to be destroyed - - -*query-resource-collection* -""""""""""""""""""""""""""" - -This operation allows to query for resource collection(s) that are within the -specified start/end time window. - - -*subscribe-allocation-events* / *notify-allocation-events* -"""""""""""""""""""""""""""""""""""""""""""""""""""""""""" - -Subscription to receive notifications about allocation-related events, e.g. an -allocation towards the VIM that did not pass the Promise shim-layer - -Note, this feature is not yet available in Brahmaputra release. - - - -Capacity management -^^^^^^^^^^^^^^^^^^^ - -The capacity management feature allows the Consumer or Administrator to do -capacity planning, i.e. the capacity available to the reservation management -can differ from the actual capacity in the registered provider(s). This feature -can, e.g., be used to limit the available capacity for a given time window due -to a planned downtime of some of the resources, or increase the capacity -available to the reservation system in case of a plannes upgrade of the -available capacity. - -*increase/decrease-capacity* -"""""""""""""""""""""""""""" - -This operations allows to increase/decrease the total capacity that is made -available to the Promise reservation service between a specified window in -time. It does NOT increase the actual capacity of a given resource provider, -but is used for capacity management inside Promise. - -This feature can be used in different ways, like - -* Limit the capacity available to the reservation system to a value below 100% - of the available capacity in the VIM, e.g., in order to leave "buffer" in the - actual NFVI to be used outside the Promise reservation service. - -* Inform the reservation system that, from a given time in the future, - additional resources can be reserved, e.g., due to a planned upgrade of the - available capacity of the provider. - -* Similarily, the "decrease-capacity" can be used to reduce the consumable - resources in a given time window, e.g., to prepare for a planned downtime of - some of the resources. - -* Expose multiple reservation service instances to different consumers sharing - the same resource provider. - -The operation takes the following input parameters: - -* start: start time for the increased/decreased capacity - -* end: end time for the increased/decreased capacity - -* container: see :ref:`create-reservation` - -Note, increase/decreasing the capacity in Promise is completely transparent to -the VIM. As such, when increasing the virtual capacity in Promise (e.g. for a -planned upgrade of the capacity), it is in the responsibility of the -Consumer/Administrator to ensure sufficient resources in the VIM are available -at the appropriate time, in order to prevent allocations against reservations -to fail due to a lack of resources. Therefore, this operations should only be -used carefully. - - -*query-capacity* -"""""""""""""""" - -This operation is used to query the available capacity information of the -specified resource collection. A filter attribute can be specified to narrow -down the query results. - -The current implementation supports the following filter criteria: - -* time window: returns reservations matching the specified window - -* window scope: if set to 'exclusive', only reservations with start AND end time - within the time window are returned. Otherwise, all reservation starting OR - ending in the time windows are returned. - -* metric: query for one of the following capacity metrics: - - * 'total': resource pools - * 'reserved': reserved resources - * 'usage': resource allocations - * 'available': remaining capacity, i.e. neither reserved nor allocated - - -*subscribe-capacity-events* / *notify-capacity-events* -"""""""""""""""""""""""""""""""""""""""""""""""""""""" - -These operations enable the Consumer to subscribe to receiving notifications -about capacity-related events, e.g., increased/decreased capacity for a -provider due to a failure or upgrade of a resource pool. In order to provide -such notifications to its Consumers, Promise shim-layer has to subscribe itself -to OpenStack Aodh to be notified from the VIM about any capacity related events. - -Note, this feature is not yet available in Brahmaputra release. - - -.. _multi-provider: - -(Multi-)provider management -^^^^^^^^^^^^^^^^^^^^^^^^^^^ - -This API towards OpenStack allows an Consumer/Administrator to add and remove -resource providers to Promise. Note, Promise supports a multi-provider -configuration, however, for Brahmaputra, multi-provider support is not yet -fully supported. - -*add-provider* -"""""""""""""" - -This operation is used to register a new resource provider into the Promise -reservation system. - -Note, for Brahmaputra, the add-provider operation should only be used to -register one provider with the Promise shim-layer. Further note that currently -only OpenStack is supported as a provider. - -The operation takes the following input parameters: - -* provider-type (mandatory) = 'openstack': select a specific resource provider - type. -* endpoint (mandatory): target URL endpoint for the resource provider. -* username (mandatory) -* password (mandatory) -* region: specified region for the provider -* tenant - - * id - * name - - -*remove-provider* -""""""""""""""""" -This operation removes a resource provider from the reservation system. Note, -this feature is not yet available in Brahmaputra release. - - - -.. [#f1] Promise requirement document, - http://http://artifacts.opnfv.org/promise/docs/requirements/index.html - -.. [#f2] YangForge framework, http://github.com/opnfv/yangforge diff --git a/docs/userguide/images/LICENSE b/docs/userguide/images/LICENSE new file mode 100644 index 0000000..6a84dd4 --- /dev/null +++ b/docs/userguide/images/LICENSE @@ -0,0 +1,14 @@ +Copyright 2016 Open Platform for NFV Project, Inc. and its contributors + +Open Platform for NFV Project Documentation Licence +=================================================== +Any documentation developed by the "Open Platform for NFV Project" +is licensed under a Creative Commons Attribution 4.0 International License. +You should have received a copy of the license along with this. If not, +see . + +Unless required by applicable law or agreed to in writing, documentation +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. diff --git a/docs/userguide/images/screenshot_promise.png b/docs/userguide/images/screenshot_promise.png new file mode 100755 index 0000000..4a0cbe3 Binary files /dev/null and b/docs/userguide/images/screenshot_promise.png differ diff --git a/docs/userguide/images/screenshot_promise_install.png b/docs/userguide/images/screenshot_promise_install.png new file mode 100644 index 0000000..2cb27d9 Binary files /dev/null and b/docs/userguide/images/screenshot_promise_install.png differ diff --git a/docs/userguide/index.rst b/docs/userguide/index.rst index 6407e92..696b341 100644 --- a/docs/userguide/index.rst +++ b/docs/userguide/index.rst @@ -1,12 +1,16 @@ .. This work is licensed under a Creative Commons Attribution 4.0 International License. .. http://creativecommons.org/licenses/by/4.0 -****************** -Promise User Guide -****************** +================== +Promise user guide +================== +This user guide document provides the users with: + +1. Short description of Promise project and key features implemented in Colorado +2. Instructions to execute Promise test cases manually .. toctree:: - :numbered: - :maxdepth: 2 + :maxdepth: 3 - featureusage.rst + feature.userguide.rst + feature.configguide.rst -- cgit 1.2.3-korg