Redefine set/unset command devref

Now we have some use cases about set/unset properties,
try to redefine devref to find out a best and easiest
solution to keep commands simple and clearly.

Five use cases exist in property action, "append",
"update", "remove", "clean", "override", the following
rules can cover all these use cases:

1. append   ==> "set --property new-key=value"
2. update   ==> "set --property existed-key=new-value"
3. remove   ==> "unset --property existed-key"
4. clean    ==> "set --no-property"
5. clean    ==> "unset --all-property"
6. override ==> "set --no-property --property new-key=value"

Related blueprint support-no-property-in-aggregate and
blueprint allow-overwrite-set-options.
Change-Id: If86daf6989d8e0ad0dc6e590d7636be7d5203a18
This commit is contained in:
Rui Chen 2016-09-23 15:26:48 +08:00
parent 762f2f2c34
commit 29f78500db

View File

@ -118,12 +118,12 @@ Some options can be repeated to build a collection of values for a property.
Adding a value to the collection must be provided via the ``set`` action. Adding a value to the collection must be provided via the ``set`` action.
Removing a value from the collection must be provided via an ``unset`` action. Removing a value from the collection must be provided via an ``unset`` action.
As a convenience, removing all values from the collection may be provided via a As a convenience, removing all values from the collection may be provided via a
``--no`` option on the ``set`` and ``unset`` actions. If both ``--no`` option ``--no`` option on the ``set`` action and a ``--all`` option on ``unset``
and option are specified, the values specified on the command would overwrite action. If both ``--no`` option and option are specified, the values specified
the collection property instead of appending on the ``set`` action. The on the command would overwrite the collection property instead of appending on
``--no`` option must be part of a mutually exclusive group with the related the ``set`` action. The ``--all`` option must be part of a mutually exclusive
property option on the ``unset`` action, overwrite case don't exist in group with the related property option on the ``unset`` action, overwrite case
``unset`` action. don't exist in ``unset`` action.
An example behavior for ``set`` action: An example behavior for ``set`` action:
@ -165,7 +165,9 @@ An example parser declaration for `set` action:
'--no-example-property', '--no-example-property',
dest='no_example_property', dest='no_example_property',
action='store_true', action='store_true',
help=_('Remove all example properties for this <resource>'), help=_('Remove all example properties for this <resource> '
'(specify both --example-property and --no-example-property'
' to overwrite the current example properties)'),
) )
An example handler in `take_action()` for `set` action: An example handler in `take_action()` for `set` action:
@ -194,8 +196,8 @@ An example parser declaration for `unset` action:
'(repeat option to remove multiple properties)'), '(repeat option to remove multiple properties)'),
) )
example_property_group.add_argument( example_property_group.add_argument(
'--no-example-property', '--all-example-property',
dest='no_example_property', dest='all_example_property',
action='store_true', action='store_true',
help=_('Remove all example properties for this <resource>'), help=_('Remove all example properties for this <resource>'),
) )
@ -208,7 +210,7 @@ An example handler in `take_action()` for `unset` action:
kwargs['example_property'] = \ kwargs['example_property'] = \
list(set(resource_example_property) - \ list(set(resource_example_property) - \
set(parsed_args.example_property)) set(parsed_args.example_property))
if parsed_args.no_example_property: if parsed_args.all_example_property:
kwargs['example_property'] = [] kwargs['example_property'] = []
Required Options Required Options