/* * Copyright © 2016-2017 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('../cucumber-common/utils/Utils.js'); /** * @module Item * @description uses item id and version id from context * @exampleFile Example_VSP.feature, Example_VLM.feature * @step I want to make sure this Item has status {string} **/ Then('I want to make sure this Item has status {string}', function (string) { let path = '/items/' + this.context.item.id + '/versions'; return util.request(this.context, 'GET', path).then(result => { assert.equal(result.data.results[0].id, this.context.item.versionId); assert.equal(result.data.results[0].status, string); }); }); /** * @module Item * @description uses item id and version id from context * @exampleFile Example_VSP.feature, Example_VLM.feature * @step I want to commit this Item **/ Then('I want to commit this Item', function () { let path = '/items/' + this.context.item.id + '/versions/' + this.context.item.versionId + '/actions'; let inputData = {action: 'Commit', commitRequest: {message: '00Behave'}}; return util.request(this.context, 'PUT', path, inputData); }); /** * @module Item * @description creates a new major version. item id and version id from context * @exampleFile Example_VLM.feature * @step I want to create a new version for this Item **/ Then('I want to create a new version for this Item', function () { let path = '/items/' + this.context.item.id + '/versions/' + this.context.item.versionId; let inputData = {description: 'Behave Version', creationMethod: 'major'}; return util.request(this.context, 'POST', path, inputData).then(result => { assert.equal(result.data.status, 'Draft'); }); }); /** * @module Item * @description reverts to a revision with a given saved property. Should be set from the revision list first * @exampleFile Example_VLM.feature * @step I want to commit this Item **/ Then('I want to revert this Item to the revision with the value from saved property {string}', function (string) { let path = '/items/' + this.context.item.id + '/versions/' + this.context.item.versionId + '/actions'; let inputData = {action: 'Revert', revisionRequest: {revisionId: this.context[string]}}; return util.request(this.context, 'PUT', path, inputData); }); /** * @module Item * @exampleFile ArchiveItem.feature * @step I want to archive this item **/ Then('I want to archive this item', function() { let path = '/items/' + this.context.item.id + '/actions' let inputData = {action: 'ARCHIVE'}; return util.request(this.context, 'PUT', path, inputData); }); /** * @module Item * @exampleFile ArchiveItem.feature * @step I want to restore this item **/ Then('I want to restore this item', function() { let path = '/items/' + this.context.item.id + '/actions' let inputData = {action: 'RESTORE'}; return util.request(this.context, 'PUT', path, inputData); });