Skip to content

Commit

Permalink
feat: Add Client API to Support object value type in Set Command
Browse files Browse the repository at this point in the history
Make the Set Command payload to allow object value type parameters.

Closes edgexfoundry#675

Signed-off-by: bruce <[email protected]>
  • Loading branch information
weichou1229 committed Oct 19, 2021
1 parent 06c8706 commit dfe6fab
Show file tree
Hide file tree
Showing 8 changed files with 64 additions and 6 deletions.
10 changes: 10 additions & 0 deletions clients/http/command.go
Original file line number Diff line number Diff line change
Expand Up @@ -76,3 +76,13 @@ func (client *CommandClient) IssueSetCommandByName(ctx context.Context, deviceNa
}
return res, nil
}

// IssueSetCommandByNameWithObject issues the specified write command and the settings supports object value type
func (client *CommandClient) IssueSetCommandByNameWithObject(ctx context.Context, deviceName string, commandName string, settings map[string]interface{}) (res dtoCommon.BaseResponse, err errors.EdgeX) {
requestPath := path.Join(common.ApiDeviceRoute, common.Name, url.QueryEscape(deviceName), url.QueryEscape(commandName))
err = utils.PutRequest(ctx, &res, client.baseUrl+requestPath, settings)
if err != nil {
return res, errors.NewCommonEdgeXWrapper(err)
}
return res, nil
}
18 changes: 18 additions & 0 deletions clients/http/command_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,3 +64,21 @@ func TestIssueIssueSetCommandByName(t *testing.T) {
require.NoError(t, err)
require.IsType(t, dtoCommon.BaseResponse{}, res)
}

func TestIssueIssueSetCommandByNameWithObject(t *testing.T) {
deviceName := "Simple-Device01"
cmdName := "SwitchButton"
settings := map[string]interface{}{
"SwitchButton": map[string]interface{}{
"kind": "button",
"value": "on",
},
}
path := path.Join(common.ApiDeviceRoute, common.Name, deviceName, cmdName)
ts := newTestServer(http.MethodPut, path, dtoCommon.BaseResponse{})
defer ts.Close()
client := NewCommandClient(ts.URL)
res, err := client.IssueSetCommandByNameWithObject(context.Background(), deviceName, cmdName, settings)
require.NoError(t, err)
require.IsType(t, dtoCommon.BaseResponse{}, res)
}
11 changes: 11 additions & 0 deletions clients/http/deviceservicecommand.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,3 +67,14 @@ func (client *deviceServiceCommandClient) SetCommand(ctx context.Context, baseUr
}
return response, nil
}

// SetCommandWithObject invokes device service's set command API and the settings supports object value type
func (client *deviceServiceCommandClient) SetCommandWithObject(ctx context.Context, baseUrl string, deviceName string, commandName string, queryParams string, settings map[string]interface{}) (dtoCommon.BaseResponse, errors.EdgeX) {
var response dtoCommon.BaseResponse
requestPath := path.Join(common.ApiDeviceRoute, common.Name, url.QueryEscape(deviceName), url.QueryEscape(commandName))
err := utils.PutRequest(ctx, &response, baseUrl+requestPath+"?"+queryParams, settings)
if err != nil {
return response, errors.NewCommonEdgeXWrapper(err)
}
return response, nil
}
19 changes: 19 additions & 0 deletions clients/http/deviceservicecommand_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -66,3 +66,22 @@ func TestSetCommand(t *testing.T) {
require.NoError(t, err)
assert.Equal(t, requestId, res.RequestId)
}

func TestSetCommandWithObject(t *testing.T) {
requestId := uuid.New().String()
expectedResponse := dtoCommon.NewBaseResponse(requestId, "", http.StatusOK)
ts := newTestServer(http.MethodPut, common.ApiDeviceRoute+"/"+common.Name+"/"+TestDeviceName+"/"+TestCommandName, expectedResponse)
defer ts.Close()
settings := map[string]interface{}{
"SwitchButton": map[string]interface{}{
"kind": "button",
"value": "on",
},
}

client := NewDeviceServiceCommandClient()
res, err := client.SetCommandWithObject(context.Background(), ts.URL, TestDeviceName, TestCommandName, "", settings)

require.NoError(t, err)
assert.Equal(t, requestId, res.RequestId)
}
2 changes: 2 additions & 0 deletions clients/interfaces/command.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,6 @@ type CommandClient interface {
IssueGetCommandByName(ctx context.Context, deviceName string, commandName string, dsPushEvent string, dsReturnEvent string) (*responses.EventResponse, errors.EdgeX)
// IssueSetCommandByName issues the specified write command referenced by the command name to the device/sensor that is also referenced by name.
IssueSetCommandByName(ctx context.Context, deviceName string, commandName string, settings map[string]string) (common.BaseResponse, errors.EdgeX)
// IssueSetCommandByNameWithObject issues the specified write command and the settings supports object value type
IssueSetCommandByNameWithObject(ctx context.Context, deviceName string, commandName string, settings map[string]interface{}) (common.BaseResponse, errors.EdgeX)
}
2 changes: 2 additions & 0 deletions clients/interfaces/deviceservicecommand.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,4 +19,6 @@ type DeviceServiceCommandClient interface {
GetCommand(ctx context.Context, baseUrl string, deviceName string, commandName string, queryParams string) (*responses.EventResponse, errors.EdgeX)
// SetCommand invokes device service's command API for issuing set(write) command
SetCommand(ctx context.Context, baseUrl string, deviceName string, commandName string, queryParams string, settings map[string]string) (common.BaseResponse, errors.EdgeX)
// SetCommandWithObject invokes device service's set command API and the settings supports object value type
SetCommandWithObject(ctx context.Context, baseUrl string, deviceName string, commandName string, queryParams string, settings map[string]interface{}) (common.BaseResponse, errors.EdgeX)
}
4 changes: 2 additions & 2 deletions dtos/deviceprofile.go
Original file line number Diff line number Diff line change
Expand Up @@ -104,9 +104,9 @@ func ValidateDeviceProfileDTO(profile DeviceProfile) error {
// deviceResources validation
dupCheck := make(map[string]bool)
for _, resource := range profile.DeviceResources {
if (resource.Properties.ValueType == common.ValueTypeBinary || resource.Properties.ValueType == common.ValueTypeObject) &&
if resource.Properties.ValueType == common.ValueTypeBinary &&
strings.Contains(resource.Properties.ReadWrite, common.ReadWrite_W) {
return errors.NewCommonEdgeX(errors.KindContractInvalid, fmt.Sprintf("write permission not support %s and %s value type for resource '%s'", common.ValueTypeBinary, common.ValueTypeObject, resource.Name), nil)
return errors.NewCommonEdgeX(errors.KindContractInvalid, fmt.Sprintf("write permission not support %s value type for resource '%s'", common.ValueTypeBinary, resource.Name), nil)
}
// deviceResource name should not duplicated
if dupCheck[resource.Name] {
Expand Down
4 changes: 0 additions & 4 deletions dtos/deviceprofile_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -97,9 +97,6 @@ func TestDeviceProfileDTOValidation(t *testing.T) {
binaryWithWritePermission := profileData()
binaryWithWritePermission.DeviceResources[0].Properties.ValueType = common.ValueTypeBinary
binaryWithWritePermission.DeviceResources[0].Properties.ReadWrite = common.ReadWrite_RW
objectWithWritePermission := profileData()
objectWithWritePermission.DeviceResources[0].Properties.ValueType = common.ValueTypeObject
objectWithWritePermission.DeviceResources[0].Properties.ReadWrite = common.ReadWrite_W

tests := []struct {
name string
Expand All @@ -112,7 +109,6 @@ func TestDeviceProfileDTOValidation(t *testing.T) {
{"mismatched resource", mismatchedResource, true},
{"invalid ReadWrite permission", invalidReadWrite, true},
{"write permission not support Binary value type", binaryWithWritePermission, true},
{"write permission not support Object value type", objectWithWritePermission, true},
}

for _, tt := range tests {
Expand Down

0 comments on commit dfe6fab

Please sign in to comment.