aboutsummaryrefslogtreecommitdiffstats
path: root/bpmn/MSOCommonBPMN/src/test/java/org/openecomp/mso/bpmn/common/ManualHandlingTest.java
blob: a7c2d19aa09a6f5a012f8310bcb93182867add74 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/*- 
 * ============LICENSE_START======================================================= 
 * ONAP - SO 
 * ================================================================================ 
 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved. 
 * ================================================================================ 
 * 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. 
 * ============LICENSE_END========================================================= 
 */ 

package org.openecomp.mso.bpmn.common;

import static com.github.tomakehurst.wiremock.client.WireMock.aResponse;

import org.camunda.bpm.engine.TaskService;
import org.camunda.bpm.ProcessEngineService;
import org.camunda.bpm.engine.task.TaskQuery;
import org.camunda.bpm.engine.task.Task;
import org.camunda.bpm.engine.delegate.BpmnError;
import org.camunda.bpm.engine.delegate.DelegateTask;
import org.camunda.bpm.engine.runtime.Execution;

import static org.openecomp.mso.bpmn.common.BPMNUtil.executeWorkFlow;
import static org.openecomp.mso.bpmn.common.BPMNUtil.waitForWorkflowToFinish;
import static com.github.tomakehurst.wiremock.client.WireMock.containing;
import static com.github.tomakehurst.wiremock.client.WireMock.put;
import static com.github.tomakehurst.wiremock.client.WireMock.stubFor;
import static com.github.tomakehurst.wiremock.client.WireMock.urlMatching;
import static org.openecomp.mso.bpmn.common.BPMNUtil.executeWorkFlow;
import static org.openecomp.mso.bpmn.common.BPMNUtil.waitForWorkflowToFinish;
import static org.openecomp.mso.bpmn.mock.StubResponsePolicy.MockPolicyAbort;

import java.io.DataOutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;
import java.util.List;

import org.camunda.bpm.engine.RuntimeService;
import org.camunda.bpm.engine.test.Deployment;
import org.junit.Assert;
import org.junit.Test;
import org.openecomp.mso.bpmn.common.workflow.service.WorkflowResponse;
import org.openecomp.mso.bpmn.core.WorkflowException;

/**
 * Unit test for RainyDayHandler.bpmn.
 */
public class ManualHandlingTest extends WorkflowTest {
	
	@Test	
	@Deployment(resources = {			
			"subprocess/BuildingBlock/ManualHandling.bpmn"
		})
	public void  TestManualHandlingSuccess() {

		RuntimeService runtimeService = processEngineRule.getRuntimeService();				
		Map<String, Object> variables = new HashMap<>();
		variables.put("isDebugLogEnabled","true");
		variables.put("msoRequestId", "testRequestId");
		variables.put("serviceType", "X");
		variables.put("vnfType", "Y");
		variables.put("currentActivity", "BB1");		
		variables.put("workStep", "1");
		variables.put("failedActivity", "");
		variables.put("errorCode", "123");
		variables.put("errorText", "update failed");
		variables.put("validResponses", "Rollback");
		

		String businessKey = UUID.randomUUID().toString();
		invokeSubProcess("ManualHandling", businessKey, variables);
		
		try {
			Thread.sleep(5);
		} catch (Exception e) {
			
		}
		
		TaskService taskService = processEngineRule.getTaskService();
		
		TaskQuery q = taskService.createTaskQuery();		
	
		List<Task> tasks = q.orderByTaskCreateTime().asc().list();
		  int i = 0;
		  
		  for (Task task : tasks) {		  
			 
		    
		        System.out.println("TASK ID: " + task.getId());
		        System.out.println("TASK NAME: " + task.getName());
		        try {
		        	System.out.println("Completing the task");
		        	Map<String,Object> completeVariables = new HashMap<>();
		        	completeVariables.put("responseValue", "skip");
		        	taskService.complete(task.getId(), completeVariables);		        
		        }
		        catch(Exception e) {
		        	System.out.println("GOT EXCEPTION: " + e.getMessage());
		        }		        
		 	}	

		waitForProcessEnd(businessKey, 100000);

		Assert.assertTrue(isProcessEnded(businessKey));
		
	}
	
	
}