/*
 * 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('./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);
});