blob: 6f2c0872afa6bf91eabc26e863b9a59ebd642cff [file] [log] [blame]
/*
* 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);
});