Add activity spec code
Move code from sdc repository and:
1. place according to this project structure
2. refactor DTOs and use mapstruct
3. change errorResponse to be a json instead of a string (for all workflow code)
Change-Id: Ia85590b53ab59ff7600e05b8a6d52e06b1773220
Issue-ID: SDC-1606
Signed-off-by: talig <talig@amdocs.com>
diff --git a/workflow-bdd/config.json b/workflow-bdd/config.json
index 260f285..5d38d09 100644
--- a/workflow-bdd/config.json
+++ b/workflow-bdd/config.json
@@ -16,13 +16,13 @@
"workflow" : {
"port" : 8080,
"prefix" : "wf",
- "server" : "",
+ "server": "wf.server",
"user" : "user"
},
"activity_spec" : {
"port" : 8080,
- "prefix" : "activity-spec-api/v1.0",
- "server" : "activity_spec.server",
+ "prefix": "v1.0",
+ "server": "wf.server",
"user" : "user"
}
}
diff --git a/workflow-bdd/features/ActivitySpec.feature b/workflow-bdd/features/ActivitySpec.feature
new file mode 100644
index 0000000..7d9a754
--- /dev/null
+++ b/workflow-bdd/features/ActivitySpec.feature
@@ -0,0 +1,61 @@
+Feature: Activity Spec
+
+ #SDC-6350
+ Scenario: Create
+ When I want to set the input data to file "resources/json/createActivitySpec.json"
+ Then I want to update the input property "name" with a random value
+ When I want to create an ActivitySpec
+
+ Then I want to check property "id" exists
+ And I want to check property "versionId" exists
+
+ And I want to list ActivitySpecs with status "Draft"
+ And I want to check property "total" exists
+
+ And I want to get the ActivitySpec for the current item
+ And I want to check property "status" for value "Draft"
+
+ And I want to call action "CERTIFY" on this ActivitySpec item
+ And I want to get the ActivitySpec for the current item
+ And I want to check property "status" for value "Certified"
+
+ And I want to call action "DEPRECATE" on this ActivitySpec item
+ And I want to get the ActivitySpec for the current item
+ And I want to check property "status" for value "Deprecated"
+
+ And I want to call action "DELETE" on this ActivitySpec item
+ And I want to get the ActivitySpec for the current item
+ And I want to check property "status" for value "Deleted"
+
+ Scenario: Get with invalid Id
+ Then I want to set property "item.id" to value "invalidId"
+ Then I want the following to fail with error message "No Activity Spec found for the given identifiers"
+ And I want to get the ActivitySpec for the current item
+
+ #SDC-6353
+ Scenario: Create with duplicate name - invalid
+ Given I want to set property "duplicateName" with a random value
+ And I want to set the input data to file "resources/json/createActivitySpec.json"
+ And I want to update the input property "name" with value of property "duplicateName"
+ And I want to create an ActivitySpec
+ And I want to check property "id" exists
+ And I want to check property "versionId" exists
+
+ When I want to set the input data to file "resources/json/createActivitySpec.json"
+ And I want to update the input property "name" with value of property "duplicateName"
+ Then I want the following to fail with response status code 422
+ And I want to create an ActivitySpec
+
+ #SDC-6354
+ Scenario: Create with invalid name - invalid
+ Given I want to set the input data to file "resources/json/createActivitySpec.json"
+ And I want to update the input property "name" with value "test!@"
+ Then I want the following to fail with response status code 400
+ When I want to create an ActivitySpec
+
+ #SDC-6355
+ Scenario: Create with null/blank name - invalid
+ Given I want to set the input data to file "resources/json/createActivitySpec.json"
+ And I want to update the input property "name" with value ""
+ Then I want the following to fail with response status code 400
+ When I want to create an ActivitySpec
\ No newline at end of file
diff --git a/workflow-bdd/features/ActivitySpecStatus.feature b/workflow-bdd/features/ActivitySpecStatus.feature
new file mode 100644
index 0000000..c908701
--- /dev/null
+++ b/workflow-bdd/features/ActivitySpecStatus.feature
@@ -0,0 +1,21 @@
+Feature: Activity Spec Status
+
+ Scenario: Invalid Status Transition
+ When I want to set the input data to file "resources/json/createActivitySpec.json"
+ Then I want to update the input property "name" with a random value
+ When I want to create an ActivitySpec
+ Then I want to check property "id" exists
+ And I want to check property "versionId" exists
+
+ When I want to get the ActivitySpec for the current item
+ Then I want to check property "status" for value "Draft"
+
+ Then I want the following to fail with response status code 422
+ When I want to call action "DEPRECATE" on this ActivitySpec item
+
+ Then I want the following to fail with response status code 422
+ When I want to call action "DELETE" on this ActivitySpec item
+
+ When I want to call action "CERTIFY" on this ActivitySpec item
+ Then I want the following to fail with response status code 422
+ When I want to call action "CERTIFY" on this ActivitySpec item
\ No newline at end of file
diff --git a/workflow-bdd/features/examples/ResponseDataChecks.feature b/workflow-bdd/features/examples/ResponseDataChecks.feature
index 2f8ff52..7956e65 100644
--- a/workflow-bdd/features/examples/ResponseDataChecks.feature
+++ b/workflow-bdd/features/examples/ResponseDataChecks.feature
@@ -35,7 +35,7 @@
}
"""
# printing out for test purposes
- Then I want to print the context data
+ #Then I want to print the context data
# running the different options of checking the respone data
Then I want to check property "field1" for value "string field"
diff --git a/workflow-bdd/resources/json/createActivitySpec.json b/workflow-bdd/resources/json/createActivitySpec.json
new file mode 100644
index 0000000..bf1b601
--- /dev/null
+++ b/workflow-bdd/resources/json/createActivitySpec.json
@@ -0,0 +1,23 @@
+{
+ "name": "RANDOM",
+ "description": "Start Server",
+ "categoryList": [
+ "Server"
+ ],
+ "inputs": [
+ {
+ "name": "host",
+ "type": "string",
+ "value": "10.1.2.3"
+ }
+ ],
+ "outputs": [
+ {
+ "name": "status",
+ "type": "string",
+ "value": "started"
+ }
+ ],
+ "type": "string",
+ "content": "test"
+}
\ No newline at end of file
diff --git a/workflow-bdd/stepDefinitions/ActivitySpec_steps.js b/workflow-bdd/stepDefinitions/ActivitySpec_steps.js
new file mode 100644
index 0000000..7fe8ddf
--- /dev/null
+++ b/workflow-bdd/stepDefinitions/ActivitySpec_steps.js
@@ -0,0 +1,47 @@
+/*
+ * Copyright © 2016-2018 European Support Limited
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * 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.
+ */
+
+const {Then, When} = require('cucumber');
+const assert = require('assert');
+const util = require('./Utils.js');
+const _ = require('lodash');
+
+When('I want to create an ActivitySpec', function () {
+ let path = '/activity-spec';
+ return util.request(this.context, 'POST', path, this.context.inputData, false, 'activity_spec').then((result)=> {
+ this.context.item = {id : result.data.id, versionId: result.data.versionId};
+ this.context.activityspec = {id : result.data.id, versionId: result.data.versionId};
+ });
+});
+
+When('I want to list ActivitySpecs with status {string}', function (string) {
+ let path = '/activity-spec?status='+string;
+ return util.request(this.context, 'GET', path, null, false, 'activity_spec').then((result)=> {
+ this.context.listCount = result.data.listCount;
+ });
+});
+
+When('I want to get the ActivitySpec for the current item', function () {
+ let path = '/activity-spec/'+ this.context.item.id+'/versions/'+this.context.item.versionId ;
+ return util.request(this.context, 'GET', path, null, false, 'activity_spec').then((result)=> {
+ });
+});
+
+Then('I want to call action {string} on this ActivitySpec item', function(string) {
+ let path = '/activity-spec/'+ this.context.item.id+'/versions/'+this.context.item.versionId+'/actions' ;
+ let inputData = JSON.parse('{"action" : "' +string+ '"}');
+ return util.request(this.context, 'PUT', path, inputData, false, 'activity_spec')
+});
\ No newline at end of file
diff --git a/workflow-bdd/stepDefinitions/General_Steps.js b/workflow-bdd/stepDefinitions/General_Steps.js
index 69a703c..5968d40 100644
--- a/workflow-bdd/stepDefinitions/General_Steps.js
+++ b/workflow-bdd/stepDefinitions/General_Steps.js
@@ -81,6 +81,16 @@
});
/**
+ * @module ContextData
+ * @description sets context property to a random value
+ * @exampleFile Example_Rest_Calls.feature
+ * @step I want to update the input property {string} with a random value
+ **/
+Then('I want to set property {string} with a random value', function (string) {
+ _.set(this.context, string, util.random());
+});
+
+/**
* @module ResponseData
* @description Will check the output data for a property and a value. property can be a path (example: results[0].id)
* @exampleFile ResponseDataChecks.feature
diff --git a/workflow-bdd/stepDefinitions/Utils.js b/workflow-bdd/stepDefinitions/Utils.js
index 6f8a7a5..9f39816 100644
--- a/workflow-bdd/stepDefinitions/Utils.js
+++ b/workflow-bdd/stepDefinitions/Utils.js
@@ -17,7 +17,7 @@
const fs = require('fs');
require('node-zip');
-function _request(context, method, path, data, isBinary=false, type='onboarding') {
+function _request(context, method, path, data, isBinary=false, type='workflow') {
let server = context.getUrlForType(type);
let options = {
@@ -106,7 +106,7 @@
});
}
-function download(context, path, filePath, callback, type='onboarding') {
+function download(context, path, filePath, callback, type='workflow') {
let server = context.getUrlForType(type);
let options = {
method: 'GET',
diff --git a/workflow-bdd/stepDefinitions/world.js b/workflow-bdd/stepDefinitions/world.js
index cf749e6..4c50b0c 100644
--- a/workflow-bdd/stepDefinitions/world.js
+++ b/workflow-bdd/stepDefinitions/world.js
@@ -70,7 +70,7 @@
var _server = context.server;
var _config = config;
return function(type) {
- let typeData = _config["workflow"];
+ let typeData = _config[type];
let _url = _config.protocol + '://' +
typeData.server + ':' +
typeData.port + '/' +