How to use resetThreadContextData method of com.testsigma.automator.runners.TestcaseStepRunner class

Best Testsigma code snippet using com.testsigma.automator.runners.TestcaseStepRunner.resetThreadContextData

Source:TestcaseStepRunner.java Github

copy

Full Screen

...58 }59 private void populateThreadContextData(TestCaseStepEntity testCaseStepEntity) {60 ThreadContext.put("TEST_STEP", testCaseStepEntity.getId() + "");61 }62 private void resetThreadContextData() {63 ThreadContext.put("TEST_STEP", "");64 }65 public TestCaseStepResult run(TestCaseStepEntity testCaseStepEntity, TestCaseStepResult testCaseStepResult,66 Map<Long, TestCaseStepResult> testCaseStepResultMap, TestCaseResult testCaseResult,67 HashMap<Long, TestCaseStepResult> parentStatus, boolean failedToProcess,68 boolean isGroupStep, ScreenCaptureUtil screenCaptureUtil) {69 resetThreadContextData();70 populateThreadContextData(testCaseStepEntity);71 log.info("Executing step - " + testCaseStepEntity.getId());72 //TODO: check test data type and update value for run time data.73 //For all other types data ll be updated on server side74 ExecutionLabType executionLabType = EnvironmentRunner.getRunnerEnvironmentEntity().getExecutionLabType();75 TestPlanRunSettingEntity testPlanRunSettingEntity = EnvironmentRunner.getRunnerEnvironmentEntity().getTestPlanSettings();76 Long envRunId = EnvironmentRunner.getRunnerEnvironmentRunResult().getId();77 TestDeviceSettings testDeviceSettings = EnvironmentRunner.getRunnerEnvironmentEntity().getEnvSettings();78 testCaseStepResult.setEnvRunId(envRunId);79 testCaseStepResult.setTestCaseResultId(testCaseResult.getId());80 testCaseStepResult.setStartTime(new Timestamp(System.currentTimeMillis()));81 testCaseStepResult.setTestCaseId(testCaseStepEntity.getTestCaseId());82 testCaseStepResult.setStepGroupId(testCaseStepEntity.getStepGroupId());83 testCaseStepResult.setParentId(testCaseStepEntity.getParentId());84 testCaseStepResult.setConditionType(testCaseStepEntity.getConditionType());85 testCaseStepResult.setTestCaseStepType(testCaseStepEntity.getType());86 testCaseStepResult.setStepDetails(testCaseStepEntity.getStepDetails());87 testCaseStepResult.setAddonTestData(testCaseStepEntity.getAddonTestData());88 testCaseStepResult.setAddonElements(testCaseStepEntity.getAddonElements());89 testCaseStepResult.setWaitTime(testCaseStepEntity.getWaitTime());90 testCaseStepResult.setTestPlanRunSettingEntity(testPlanRunSettingEntity);91 testCaseStepResult.setPriority(testCaseStepEntity.getPriority());92 Map<String, String> envDetails = new HashMap<String, String>();93 envDetails.put("testcaseId", testCaseResult.getTestCaseId() + "");94 envDetails.put("iteration", testCaseResult.getTestDataSetName());95 envDetails.put("envRunId", envRunId + "");96 envDetails.put(EnvSettingsConstants.KEY_USERNAME, testDeviceSettings.getUserName());97 Integer pageTimeOut = testPlanRunSettingEntity.getPageTimeOut();98 if (pageTimeOut != null)99 envDetails.put(EnvSettingsConstants.PAGE_LOAD_TIMEOUT, testPlanRunSettingEntity.getPageTimeOut().toString());100 envDetails.put("jwtApiKey", testDeviceSettings.getJwtApiKey());101 if (testDeviceSettings.getEnvironmentParamId() != null) {102 envDetails.put(EnvSettingsConstants.KEY_ENVIRONMENT_PARAM_ID,103 testDeviceSettings.getEnvironmentParamId() + "");104 }105 ResultConstant status = ResultConstant.SUCCESS;106 if (testCaseStepEntity.getConditionType() != null &&107 (testCaseStepEntity.getConditionType() == ConditionType.CONDITION_ELSE) && !testCaseStepResult.getSkipExe()) {108 setConditionResult(testCaseStepEntity, testCaseStepResult, parentStatus);109 testCaseStepResult.setEndTime(new Timestamp(System.currentTimeMillis()));110 return testCaseStepResult;111 }112 try {113 TestCaseStepResult preReqResult = testCaseStepResultMap.get(testCaseStepEntity.getPreRequisite());114 boolean hasPreReq = (testCaseStepEntity.getPreRequisite() != null) && (testCaseStepEntity.getPreRequisite() > 0);115 if (hasPreReq) {116 log.debug("Test Step Prerequisite - " + testCaseStepEntity.getPreRequisite());117 log.debug("Test Step Prerequisite Result - " + objectMapperService.convertToJson(preReqResult));118 } else {119 log.debug("Test Step Has No Prerequisite");120 }121 boolean preReqFailed = hasPreReq && ((preReqResult == null) || (preReqResult.getResult() != ResultConstant.SUCCESS));122 boolean isRunning = ExecutionEnvironmentRunner.isRunning();123 boolean isStepGroup = (testCaseStepEntity.getStepGroupId() != null) && (testCaseStepEntity.getStepGroupId() > 0);124 if (!isRunning) {125 log.debug("Found execution environment / test case as stopped...skipping test case step execution");126 status = ResultConstant.STOPPED;127 testCaseStepResult.setMessage(AutomatorMessages.MSG_USER_ABORTED_EXECUTION);128 } else if (testCaseStepResult.getSkipExe()) {129 log.debug("Found execution skip flag to be set...setting appropriate message");130 status = ResultConstant.NOT_EXECUTED;131 testCaseStepResult.setMessage(testCaseStepResult.getSkipMessage());132 } else if (failedToProcess) {133 log.debug("Found failed to process to be set...setting appropriate message");134 status = ResultConstant.NOT_EXECUTED;135 testCaseStepResult.setMessage(testCaseStepResult.getSkipMessage());136 } else if (preReqFailed) {137 log.debug("Found prerequisite failed flag to be set...setting appropriate message");138 status = ResultConstant.FAILURE;139 testCaseStepResult.setMessage(AutomatorMessages.MSG_STEP_PRE_REQUISITE_FAILED);140 boolean skipExe = (testPlanRunSettingEntity.getOnStepPreRequisiteFail() == RecoverAction.Run_Next_Testcase);141 if (skipExe) {142 testCaseResult.setResult(status);143 testCaseResult.setMessage(AutomatorMessages.MSG_STEP_PRE_REQUISITE_FAILED);144 }145 testCaseStepResult.setSkipExe(skipExe);146 testCaseStepResult.setSkipMessage(AutomatorMessages.MSG_STEP_PRE_REQUISITE_FAILED);147 }148 if (testCaseStepEntity.getType() != null && testCaseStepEntity.getType() == TestStepType.FOR_LOOP) {149 log.debug("For loop execution starts:" + testCaseStepEntity.getId() + " With Iteration:" + testCaseStepEntity.getIteration());150 status = executeForLoop(testCaseStepEntity, testCaseStepResult, testCaseStepResultMap, testCaseResult, parentStatus,151 failedToProcess, screenCaptureUtil, status);152 } else if (testCaseStepEntity.getType() != null && testCaseStepEntity.getType() == TestStepType.WHILE_LOOP) {153 log.debug("While loop execution starts:" + testCaseStepEntity.getId());154 status = executeWhileLoop(testCaseStepEntity, testCaseStepResult,155 testCaseStepResultMap, testCaseResult, parentStatus,156 failedToProcess, screenCaptureUtil, status);157 } else if (isStepGroup) {158 log.debug("Step type is Step Group. Executing Test Component with ID - " + testCaseStepEntity.getStepGroupId());159 status = executeStepGroup(testCaseStepEntity, testCaseStepResult, testCaseStepResultMap, testCaseResult, parentStatus,160 failedToProcess, screenCaptureUtil, status);161 } else if (isRunning && !testCaseStepResult.getSkipExe() && !preReqFailed) {162 setTestDataValue(testCaseStepEntity, envDetails, testCaseResult, testCaseStepResult);163 testCaseStepResult.setElementDetails(testCaseStepEntity.getElementsMap());164 testCaseStepResult.setTestDataDetails(testCaseStepEntity.getTestDataMap());165 log.debug("Step type is normal. Executing normal Action step");166 execute(envDetails, testCaseStepResult, testCaseStepEntity, testCaseResult);167 ObjectMapper mapper = new ObjectMapper();168 mapper.disable(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);169 Map<String, Object> metadata = mapper.convertValue(testCaseStepEntity, Map.class);170 Map<String, Object> oldMetadata = mapper.convertValue(testCaseStepResult.getMetadata(), Map.class);171 oldMetadata.putAll(metadata);172 StepResultMetadataEntity metadataEntity = mapper.convertValue(oldMetadata, StepResultMetadataEntity.class);173 testCaseStepResult.setMetadata(metadataEntity);174 testCaseStepResult.getMetadata().setTestStep(testCaseStepEntity);175 takeScreenshot(workspaceType, testCaseStepEntity, testCaseStepResult,176 testPlanRunSettingEntity.getScreenshot(), screenCaptureUtil);177 if (testCaseStepEntity.getConditionType() != null && (testCaseStepEntity.getConditionType() != ConditionType.NOT_USED)) {178 setConditionResult(testCaseStepEntity, testCaseStepResult, parentStatus);179 status = (testCaseStepResult.getResult() != ResultConstant.SUCCESS) ? testCaseStepResult.getResult() : status;180 } else {181 status = (testCaseStepResult.getResult() != ResultConstant.SUCCESS) ? testCaseStepResult.getResult() : status;182 if ((status == ResultConstant.SUCCESS) && StringUtils.isBlank(testCaseStepResult.getMessage())) {183 testCaseStepResult.setMessage(AutomatorMessages.MSG_STEP_SUCCESS);184 } else if (StringUtils.isBlank(testCaseStepResult.getMessage())) {185 testCaseStepResult.setMessage(AutomatorMessages.MSG_STEP_FAILURE);186 }187 }188 log.debug("Test Step Result - " + status);189 }190 log.debug("Test Step Result [2] - " + status);191 boolean majorFailure = (status != ResultConstant.SUCCESS && status != ResultConstant.ABORTED) &&192 (testCaseStepEntity.getPriority() == TestStepPriority.MAJOR &&193 testPlanRunSettingEntity.getRecoveryAction() == RecoverAction.Run_Next_Testcase);194 boolean hasToAbortTestcase = (majorFailure && !isGroupStep && !isStepGroup);195 if (!testCaseStepResult.getSkipExe() && hasToAbortTestcase) {196 setFailedMessage(testCaseStepResult, testCaseResult, testCaseStepEntity.getStepDetails().getIgnoreStepResult());197 }198 //Add Loop level result199 if (testCaseStepEntity.getType() == TestStepType.BREAK_LOOP && status == ResultConstant.SUCCESS) {200 testCaseStepResult.setIsBreakLoop(true);201 } else if (testCaseStepEntity.getType() == TestStepType.CONTINUE_LOOP && status == ResultConstant.SUCCESS) {202 testCaseStepResult.setIsContinueLoop(true);203 }204 } catch (UnreachableBrowserException e) {205 status = ResultConstant.FAILURE;206 testCaseStepResult.setErrorCode(com.testsigma.automator.constants.ErrorCodes.BROWSER_CLOSED);207 testCaseStepResult.setMessage(String.format(BROWSER_UNREACHABLE));208 } catch (NoSuchSessionException e) {209 status = ResultConstant.FAILURE;210 testCaseStepResult.setMessage(String.format(INVALID_SESSION));211 } catch (Exception e) {212 log.error(e.getMessage(), e);213 status = ResultConstant.FAILURE;214 testCaseStepResult.setErrorCode(com.testsigma.automator.constants.ErrorCodes.UNKNOWN_PROBLEM);215 if(testCaseStepResult.getMessage()==null)216 testCaseStepResult.setMessage(e.getMessage());217 }218 resetThreadContextData();219 testCaseStepResult.setResult(status);220 testCaseStepResult.setEndTime(new Timestamp(System.currentTimeMillis()));221 log.debug("Finished Executing Test Case Step - " + testCaseStepResult.getTestCaseStepId());222 return testCaseStepResult;223 }224 protected ResultConstant executeStepGroup(TestCaseStepEntity testCaseStepEntity, TestCaseStepResult testCaseStepResult,225 Map<Long, TestCaseStepResult> testCaseStepResultMap, TestCaseResult testCaseResult,226 HashMap<Long, TestCaseStepResult> parentStatus, boolean failedToProcess,227 ScreenCaptureUtil screenCaptureUtil, ResultConstant currentStatus) throws Exception {228 executeGroup(testCaseStepEntity, testCaseStepResult, testCaseStepResultMap, testCaseResult, parentStatus, failedToProcess, screenCaptureUtil);229 if (testCaseStepEntity.getConditionType() != null && (testCaseStepEntity.getConditionType() != ConditionType.NOT_USED)) {230 setConditionResult(testCaseStepEntity, testCaseStepResult, parentStatus);231 }232 ResultConstant status = (testCaseStepResult.getResult() != ResultConstant.SUCCESS) ? testCaseStepResult.getResult() : currentStatus;233 if ((status == ResultConstant.SUCCESS)) {234 testCaseStepResult.setMessage(AutomatorMessages.MSG_STEP_GROUP_SUCCESS);235 } else if (StringUtils.isBlank(testCaseStepResult.getMessage())) {236 testCaseStepResult.setMessage(AutomatorMessages.MSG_STEP_GROUP_FAILURE);237 }238 return status;239 }240 protected ResultConstant executeForLoop(TestCaseStepEntity testCaseStepEntity, TestCaseStepResult forLoopResultObj,241 Map<Long, TestCaseStepResult> testCaseStepResultMap, TestCaseResult tresult,242 HashMap<Long, TestCaseStepResult> parentStatus, boolean failedToProcess,243 ScreenCaptureUtil screenCaptureUtil, ResultConstant currentStatus) throws Exception {244 log.debug("Step type is FOR_LOOP. Executing it:" + testCaseStepEntity);245 //In for loop , if there is a continue step encountered in prev iteration, we should not skip execution or loop.246 TestCaseStepResult previousLoopResultIfAny = testCaseStepResultMap.get(testCaseStepEntity.getId());247 if (previousLoopResultIfAny != null && previousLoopResultIfAny.getIsContinueLoop()) {248 forLoopResultObj.setSkipExe(false);249 } else if (previousLoopResultIfAny != null && previousLoopResultIfAny.getIsBreakLoop()) {250 forLoopResultObj.setSkipExe(true);251 }252 executeGroup(testCaseStepEntity, forLoopResultObj, testCaseStepResultMap, tresult, parentStatus, failedToProcess, screenCaptureUtil);253 //previous loop encountered a break ,We need to disable skipExe, else further testcases(After loop) will not be executed.254 if (previousLoopResultIfAny != null && previousLoopResultIfAny.getIsBreakLoop()) {255 forLoopResultObj.setIsBreakLoop(true);256 forLoopResultObj.setSkipExe(false);//If skip is true, execution will not be continued after the loop.257 forLoopResultObj.setResult(ResultConstant.SUCCESS);258 }259 forLoopResultObj.setIndex(testCaseStepEntity.getIndex());260 forLoopResultObj.setIteration(testCaseStepEntity.getIteration());261 forLoopResultObj.setTestDataProfileName(testCaseStepEntity.getTestDataProfileName());262 ResultConstant status = (currentStatus.getId() < forLoopResultObj.getResult().getId()) ? forLoopResultObj.getResult() : currentStatus;263 if ((forLoopResultObj.getResult() == ResultConstant.SUCCESS)) {264 forLoopResultObj.setMessage(AutomatorMessages.getMessage(AutomatorMessages.MSG_ITERATION_SUCCESS, testCaseStepEntity.getIndex()));265 } else if (StringUtils.isBlank(forLoopResultObj.getMessage())) {266 forLoopResultObj.setMessage(AutomatorMessages.getMessage(AutomatorMessages.MSG_ITERATION_FAILURE, testCaseStepEntity.getIndex()));267 }268 return status;269 }270 protected ResultConstant executeWhileLoop(TestCaseStepEntity testcaseStep, TestCaseStepResult whileLoopResultObj, Map<Long, TestCaseStepResult> mapStepResult,271 TestCaseResult tresult, HashMap<Long, TestCaseStepResult> parentStatus,272 boolean failedToProcess, ScreenCaptureUtil screenCaptureUtil, ResultConstant currentStatus) throws Exception {273 Long envRunId = EnvironmentRunner.getRunnerEnvironmentRunResult().getId();274 log.debug("Executing while loop:" + testcaseStep);275 TestCaseStepEntity whileConditionStep = testcaseStep.getTestCaseSteps().get(0);276 List<TestCaseStepResult> whileLoopIterationResults = new ArrayList<>();277 boolean breakLoop = false;278 ResultConstant whileLoopResult = ResultConstant.SUCCESS;279 boolean conditionFailed = false;280 int noOfIterationsCompleted = 0;281 //Iterations loop, we are limiting max loop count to ActionConstants.WHILE_LOOP_MAX_LIMIT282 for (int i = 1; i <= NaturalTextActionConstants.WHILE_LOOP_MAX_LIMIT; i++) {283 if (breakLoop) {284 break;285 }286 TestCaseStepResult whileConditionStepResult = new TestCaseStepResult();287 whileConditionStepResult.setEnvRunId(envRunId);288 whileConditionStepResult.setTestCaseResultId(tresult.getId());289 whileConditionStepResult.setTestCaseStepId(whileConditionStep.getId());290 whileConditionStepResult.setSkipExe(whileLoopResultObj.getSkipExe());291 whileConditionStepResult.setSkipMessage(whileLoopResultObj.getSkipMessage());292 whileConditionStepResult.setParentResultId(whileLoopResultObj.getId());293 whileConditionStepResult.setTestCaseStepType(whileConditionStep.getType());294 whileConditionStepResult.setStepDetails(whileConditionStep.getStepDetails());295 whileConditionStepResult.setIndex(i);296 setScreenshotPathsForIteration(whileConditionStep, i);297 TestStepType type = whileConditionStep.getType();298 TestcaseStepRunner testcaseStepRunner = new TestcaseStepRunnerFactory().getRunner(workspaceType, os, type);299 testcaseStepRunner.run(whileConditionStep, whileConditionStepResult, mapStepResult, tresult, parentStatus, failedToProcess, false, screenCaptureUtil);300 if (whileConditionStepResult.getResult() != ResultConstant.SUCCESS) {301 whileConditionStepResult.setSkipExe(true);302 if (whileConditionStepResult.getResult() == ResultConstant.FAILURE) {303 whileConditionStepResult.setSkipMessage(String.format("%s<br>%s", AutomatorMessages.MSG_WHILE_CONDITION_FAILED, whileConditionStepResult.getMessage()));304 conditionFailed = true;305 }306 }307 mapStepResult.put(whileConditionStep.getId(), whileConditionStepResult);308 log.debug("While condition result :::: " + objectMapperService.convertToJson(whileConditionStepResult));309 executeGroup(whileConditionStep, whileConditionStepResult, mapStepResult, tresult, parentStatus, failedToProcess, screenCaptureUtil);310 //Update Iteration result to SUCCESS if break or continue is executed311 if (whileConditionStepResult.getIsBreakLoop() || whileConditionStepResult.getIsContinueLoop()) {312 whileConditionStepResult.setResult(ResultConstant.SUCCESS);313 }314 //If condition is passed, and while executing the group of steps inside condition, if there is a failure in group, parent status will be skipped315 if (whileConditionStepResult.getResult() == ResultConstant.SUCCESS && whileConditionStepResult.getSkipExe()) {316 whileLoopResult = ResultConstant.FAILURE;317 whileLoopResultObj.setSkipExe(true);318 }319 //While loop break condition.320 if (whileConditionStepResult.getIsBreakLoop() || whileConditionStepResult.getSkipExe()) {321 breakLoop = true;322 }323 whileLoopIterationResults.add(whileConditionStepResult);324 whileLoopResult = (whileLoopResult.getId() < whileConditionStepResult.getResult().getId()) ? whileConditionStepResult.getResult() : whileLoopResult;325 //If condition step is failed, we should not fail while loop status326 if (conditionFailed) {327 whileLoopResult = ResultConstant.SUCCESS;328 }329 noOfIterationsCompleted = i;330 }331 //Add all iteration results to parent LOOP step332 whileLoopResultObj.setStepResults(whileLoopIterationResults);333 if (whileLoopResultObj.getResult() == null) {334 whileLoopResultObj.setResult(whileLoopResult);335 }336 ResultConstant status = (currentStatus.getId() < whileLoopResultObj.getResult().getId()) ? whileLoopResultObj.getResult() : currentStatus;337 if ((whileLoopResultObj.getResult() == ResultConstant.SUCCESS)) {338 if (noOfIterationsCompleted == NaturalTextActionConstants.WHILE_LOOP_MAX_LIMIT) {339 status = ResultConstant.FAILURE;340 whileLoopResultObj.setResult(ResultConstant.FAILURE);341 whileLoopResultObj.setMessage(AutomatorMessages.MSG_WHILE_LOOP_ITERATIONS_EXHAUSTED);342 } else {343 whileLoopResultObj.setMessage(AutomatorMessages.MSG_WHILE_LOOP_SUCCESS);344 }345 } else if (whileLoopResultObj.getResult() == ResultConstant.FAILURE) {346 whileLoopResultObj.setMessage(AutomatorMessages.MSG_WHILE_LOOP_FAILURE);347 }348 return status;349 }350 protected void setScreenshotPathsForIteration(TestCaseStepEntity testStepEntity, int iterationNumber) {351 String key = String.format("%s_%s", iterationNumber, testStepEntity.getIndex());352 Map<String, String> conditionStepScreenshots = testStepEntity.getAdditionalScreenshotPaths();353 testStepEntity.setScreenshotPath(conditionStepScreenshots.get(key));354 if (testStepEntity.getTestCaseSteps() != null && testStepEntity.getTestCaseSteps().size() > 0) {355 for (TestCaseStepEntity childStep : testStepEntity.getTestCaseSteps()) {356 setScreenshotPathsForIteration(childStep, iterationNumber);357 }358 }359 }360 private void executeGroup(TestCaseStepEntity testcaseStep, TestCaseStepResult result, Map<Long, TestCaseStepResult> mapStepResult,361 TestCaseResult tresult, HashMap<Long, TestCaseStepResult> parentStatus,362 boolean failedToProcess, ScreenCaptureUtil ScreenCaptureUtil) throws Exception {363 ExecutionLabType exeType = EnvironmentRunner.getRunnerEnvironmentEntity().getExecutionLabType();364 TestPlanRunSettingEntity settings = EnvironmentRunner.getRunnerEnvironmentEntity().getTestPlanSettings();365 Long envRunId = EnvironmentRunner.getRunnerEnvironmentRunResult().getId();366 List<TestCaseStepResult> stepResults = new ArrayList<>();367 result.setStepResults(stepResults);368 ResultConstant status = ResultConstant.SUCCESS;369 Boolean skipExe = result.getSkipExe();370 String message = result.getSkipMessage();371 boolean isMajorStepGroupFailure =372 (testcaseStep.getPriority().equals(TestStepPriority.MAJOR) &&373 settings.getRecoveryAction() == RecoverAction.Run_Next_Testcase);374 boolean isStepGroup = (testcaseStep.getStepGroupId() != null && testcaseStep.getStepGroupId() > 0);375 boolean breakLoopStepExecuted = false;376 boolean continueLoopStepExecuted = false;377 for (TestCaseStepEntity childStep : testcaseStep.getTestCaseSteps()) {378 populateThreadContextData(childStep);379 log.debug("Executing group step:" + childStep.getId());380 if (breakLoopStepExecuted || continueLoopStepExecuted) {381 log.debug(String.format("Skip execution due to break/continue loop:stepGroupId=%s", childStep.getId()));382 skipExe = true;383 }384 TestCaseStepResult childStepResult = new TestCaseStepResult();385 childStepResult.setEnvRunId(envRunId);386 childStepResult.setTestCaseResultId(tresult.getId());387 childStepResult.setTestCaseStepId(childStep.getId());388 childStepResult.setSkipExe(skipExe);389 childStepResult.setSkipMessage(message);390 TestCaseStepResult parentResult = parentStatus.get(childStep.getParentId());391 childStepResult.setParentResultId(parentResult != null ? parentResult.getId() : null);392 childStepResult.setTestCaseStepType(childStep.getType());393 childStepResult.setStepDetails(childStep.getStepDetails());394 RunnerUtil util = new RunnerUtil();395 TestStepType type = childStep.getType();396 TestcaseStepRunner testcaseStepRunner = new TestcaseStepRunnerFactory().getRunner(workspaceType, os, type);397 boolean isFailure =398 (399 //this check is used to skip loop child steps check.400 //because loop step result is set only after loop is finished401 !util.isLoopSteps(isStepGroup, testcaseStep, childStep)402 && (util.canSkipNormalStep(parentResult, childStep, childStepResult)403 || util.canSkipIfElse(parentResult, childStep, childStepResult)404 || util.nestedConditionalStep(parentResult, childStep, childStepResult)405 || util.canSkipIfElseIf(parentResult, childStep, childStepResult)406 || util.canSkipElseIfElseIf(parentResult, childStep, childStepResult)407 || util.canSkipElseIfElse(parentResult, childStep, childStepResult)408 || util.canSkipIfCondition(parentResult, childStep, childStepResult)409 || util.canSkipForLoop(parentResult, childStep, childStepResult)))410 //This check for updating loop steps if loop parent is failed411 || util.canSkipForLoopTopSteps(isStepGroup, parentResult, testcaseStep, childStep, childStepResult);412 if (!skipExe && !failedToProcess && isFailure) {413 testcaseStepRunner.run(childStep, childStepResult, mapStepResult, tresult, parentStatus, false, isStepGroup, ScreenCaptureUtil);414 mapStepResult.put(childStep.getId(), childStepResult);415 stepResults.add(childStepResult);416 parentStatus.put(childStep.getId(), childStepResult);417 continue;418 }419 testcaseStepRunner.run(childStep, childStepResult, mapStepResult, tresult, parentStatus, failedToProcess, isStepGroup, ScreenCaptureUtil);420 mapStepResult.put(childStep.getId(), childStepResult);421 stepResults.add(childStepResult);422 log.debug("Result in Step Group :::: " + objectMapperService.convertToJson(childStepResult));423 if ((childStep.getConditionType() == null || childStep.getConditionType() == ConditionType.NOT_USED ||424 ConditionType.LOOP_FOR == (childStep.getConditionType()))&& (!childStep.getStepDetails().getIgnoreStepResult())) {425 status = (status.getId() < childStepResult.getResult().getId()) ? childStepResult.getResult() : status;426 }427 boolean isMajorStepFailure = isStepGroup && isStepGroupFailure(testcaseStep, childStep, childStepResult);428 if (!skipExe && isMajorStepFailure && isMajorStepGroupFailure) {429 result.setResult(ResultConstant.FAILURE);430 String majorMessage = new StringBuffer(AutomatorMessages.MSG_STEP_MAJOR_STEP_FAILURE)431 .append((childStepResult.getMessage() != null) ? childStepResult.getMessage() + "." : "")432 .append(AutomatorMessages.MSG_CHECK_FOR_MORE_DETAILS).toString();433 result.setMessage(majorMessage);434 setFailedMessage(childStepResult, tresult, testcaseStep.getStepDetails().getIgnoreStepResult());435 }436 skipExe = childStepResult.getSkipExe();437 message = childStepResult.getSkipMessage();438 //Set break loop and continue loop to group results439 if (childStepResult.getResult() == ResultConstant.SUCCESS440 && (childStepResult.getIsBreakLoop() || childStepResult.getIsContinueLoop())) {441 continueLoopStepExecuted = childStepResult.getIsContinueLoop();442 breakLoopStepExecuted = childStepResult.getIsBreakLoop();443 populateLoopConditionResult(result, childStepResult, testcaseStep);444 log.debug("Is Break loop step executed successfully:" + breakLoopStepExecuted);445 log.debug("Is Continue loop step executed successfully:" + continueLoopStepExecuted);446 }447 result.setSkipExe(skipExe);448 result.setSkipMessage(message);449 }450 if (result.getResult() == null) {451 result.setResult(status);452 }453 //If current loop encounters a continue OR current loop encountered a break.454 // We need to disable skipExe, else further testcases(After loop) will not be executed.455 if (result.getIsContinueLoop() || result.getIsBreakLoop()) {456 result.setSkipExe(false);//If skip is true, execution will not be continued after the loop.457 result.setResult(ResultConstant.SUCCESS);458 }459 resetThreadContextData();460 }461 protected void populateLoopConditionResult(TestCaseStepResult parentLoopResult, TestCaseStepResult childStepResult, TestCaseStepEntity parentLoopStep) {462 if (parentLoopStep.getConditionType() == ConditionType.LOOP_WHILE463 || parentLoopStep.getConditionType() == ConditionType.LOOP_FOR464 || parentLoopStep.getStepGroupId() != null) {465 if (childStepResult.getIsBreakLoop()) {466 parentLoopResult.setIsBreakLoop(childStepResult.getIsBreakLoop());467 } else if (childStepResult.getIsContinueLoop()) {468 parentLoopResult.setIsContinueLoop(childStepResult.getIsContinueLoop());469 }470 }471 }472 private void setFailedMessage(TestCaseStepResult result, TestCaseResult testCaseResult, Boolean ignoreStepResult) throws AutomatorException {473 result.setSkipExe(true);...

Full Screen

Full Screen

Source:TestcaseRunner.java Github

copy

Full Screen

...61 private void populateThreadContextData() {62 ThreadContext.put("TEST_CASE", testCaseEntity.getId() + "");63 ThreadContext.put("TEST_CASE_RESULT", testCaseResult.getId() + "");64 }65 private void resetThreadContextData() {66 ThreadContext.put("TEST_CASE", "");67 ThreadContext.put("TEST_CASE_RESULT", "");68 }69 public TestCaseResult run() throws Exception {70 resetThreadContextData();71 populateThreadContextData();72 log.info("Running testcase - " + testCaseEntity.getTestCaseName());73 if (testDeviceEntity.getCreateSessionAtCaseLevel()) {74 startSession();75 } else {76 restartCurrentSession();77 }78 environmentRunResult.setSessionCreatedOn(new Timestamp(System.currentTimeMillis()));79 ResultConstant result = ResultConstant.SUCCESS;80 List<TestCaseStepEntity> stepList = testCaseEntity.getTestSteps();81 List<TestCaseStepResult> testCaseStepsResult = new ArrayList<>();82 testCaseResult.setTestCaseStepResults(testCaseStepsResult);83 testCaseResult.setIsStepGroup(testCaseEntity.getIsStepGroup());84 testCaseResult.setDataDriven(testCaseEntity.getIsDataDriven());85 testCaseResult.setTestPlanResultId(testDeviceEntity.getExecutionRunId());86 testCaseResult.setTestCaseName(testCaseEntity.getTestCaseName());87 try {88 HashMap<Long, TestCaseStepResult> parentStatus = new HashMap<>();89 int currentIndex = 0;90 testCaseResult.setCurrentIndex(currentIndex);91 int lastStep = stepList.size() - 1;92 ScreenCaptureUtil screenCaptureUtil = new ScreenCaptureUtil(new ArrayList<>());93 for (int i = 0; i < stepList.size(); i++) {94 TestCaseStepEntity testCaseStepEntity = stepList.get(i);95 TestCaseStepResult testCaseStepResult = new TestCaseStepResult();96 testCaseStepResult.setTestCaseStepId(testCaseStepEntity.getId());97 testCaseStepResult.setSkipExe(skipExecution);98 testCaseStepResult.setSkipMessage(resultFailureMessage);99 /* if (!skipExecution && (workspaceType.equals(WorkspaceType.WebApplication) || workspaceType100 .equals(WorkspaceType.MobileWeb))) {101 url = getUrl();102 }*/103 boolean skipGetUrl = false;104 if (testCaseStepEntity.getAction() != null) {105 skipGetUrl = Arrays.asList(SKIP_GETURL).stream().filter(action -> testCaseStepEntity.getAction().contains(action)).count() > 0;106 }107 TestStepType type = testCaseStepEntity.getType();108 TestcaseStepRunner testcaseStepRunner =109 new TestcaseStepRunnerFactory().getRunner(this.workspaceType, testDeviceSettings.getOs(), type);110 TestCaseStepResult parentResult = parentStatus.get(testCaseStepEntity.getParentId());111 RunnerUtil util = new RunnerUtil();112 boolean isFailure =113 util.canSkipNormalStep(parentResult, testCaseStepEntity, testCaseStepResult)114 || util.nestedConditionalStep(parentResult, testCaseStepEntity, testCaseStepResult)115 || util.canSkipIfElse(parentResult, testCaseStepEntity, testCaseStepResult)116 || util.canSkipIfElseIf(parentResult, testCaseStepEntity, testCaseStepResult)117 || util.canSkipElseIfElseIf(parentResult, testCaseStepEntity, testCaseStepResult)118 || util.canSkipElseIfElse(parentResult, testCaseStepEntity, testCaseStepResult)119 || util.canSkipIfCondition(parentResult, testCaseStepEntity, testCaseStepResult)120 || util.canSkipForLoop(parentResult, testCaseStepEntity, testCaseStepResult);121 log.info(new ObjectMapperService().convertToJson(testCaseStepEntity));122 int stepResultUpdateSize = 10;123 if (!skipExecution && isFailure) {124 parentStatus.put(testCaseStepEntity.getId(), testCaseStepResult);125 testCaseStepResult.setResult(ResultConstant.NOT_EXECUTED);126 int processedSteps = processedStepCount(testCaseStepsResult);127 if (processedSteps % stepResultUpdateSize == 0) {128 testCaseResult.setTestCaseStepResults(testCaseStepsResult);129 postTestcaseResult();130 currentIndex = +stepResultUpdateSize;131 processedSteps = 0;132 testCaseStepsResult = new ArrayList<>();133 testCaseResult.setCurrentIndex(currentIndex);134 }135 if (screenCaptureUtil.screenshots.size() > 0 && (lastStep == i)) {136 log.debug("Screenshots task for :::" + testCaseStepResult);137 final String requestId = ThreadContext.get("X-Request-Id");138 UploadThreadPool.getInstance().upload(new ScreenshotUploadTask(screenCaptureUtil.screenshots, requestId, testDeviceEntity));139 screenCaptureUtil.screenshots = new ArrayList<>();140 }141 testCaseStepResult = testcaseStepRunner142 .run(testCaseStepEntity, testCaseStepResult, mapStepResult, testCaseResult, parentStatus,143 false, false, screenCaptureUtil);144 testCaseStepsResult.add(testCaseStepResult);145 mapStepResult.put(testCaseStepEntity.getId(), testCaseStepResult);146 continue;147 }148 testCaseStepResult = testcaseStepRunner149 .run(testCaseStepEntity, testCaseStepResult, mapStepResult, testCaseResult, parentStatus,150 false, false, screenCaptureUtil);151 if (screenCaptureUtil.screenshots.size() == SAVE_BATCH_IMAGES || (lastStep == i)) {152 final String requestId = ThreadContext.get("X-Request-Id");153 UploadThreadPool.getInstance().upload(new ScreenshotUploadTask(screenCaptureUtil.screenshots, requestId, testDeviceEntity));154 screenCaptureUtil.screenshots = new ArrayList<>();155 }156 skipExecution = testCaseStepResult.getSkipExe();157 resultFailureMessage = testCaseStepResult.getSkipMessage();158 testCaseStepsResult.add(testCaseStepResult);159 mapStepResult.put(testCaseStepEntity.getId(), testCaseStepResult);160 TestCaseStepEntity stepGroup = null;161 TestCaseStepResult stepGroupResult = null;162 if (testCaseStepEntity.getStepGroupId() != null) {163 stepGroup = ((testCaseStepEntity.getTestCaseSteps() != null) && (testCaseStepEntity.getTestCaseSteps().size() > 0)) ?164 testCaseStepEntity.getTestCaseSteps().get(0) : null;165 stepGroupResult = ((testCaseStepResult.getStepResults() != null) && (testCaseStepResult.getStepResults().size() > 0)) ?166 testCaseStepResult.getStepResults().get(0) : null;167 }168 if (i == 0 && ((workspaceType == WorkspaceType.WebApplication) || (workspaceType169 == WorkspaceType.MobileWeb)) && (getUrl() != null) && !skipGetUrl && ((testCaseStepEntity.getStepGroupId() != null && stepGroup != null170 && (stepGroup.getStepGroupId() != null && !stepGroup.getAction().contains(AutomatorMessages.KEYWORD_GO_TO) && stepGroupResult171 .getResult() == ResultConstant.SUCCESS)) ||172 (testCaseStepEntity.getAction() != null && !testCaseStepEntity.getAction()173 .contains(AutomatorMessages.KEYWORD_GO_TO) && testCaseStepResult.getResult() == ResultConstant.SUCCESS))174 ) {175 } else if (i == (stepList.size() - 1) && !skipGetUrl && testCaseStepResult.getResult() == ResultConstant.SUCCESS176 && (workspaceType.equals(WorkspaceType.WebApplication) || workspaceType.equals(WorkspaceType.MobileWeb))) {177 ExecutionEnvironmentRunner.addUrl(testPlanId, testCaseEntity.getId(), getUrl());178 }179 //TODO:use check based step type180 if ((testCaseStepEntity.getConditionType() == null || testCaseStepEntity.getConditionType() == ConditionType.NOT_USED181 || ConditionType.LOOP_FOR == testCaseStepEntity.getConditionType()) && (!testCaseStepEntity.getStepDetails().getIgnoreStepResult()) ) {182 result = (result.getId() < testCaseStepResult.getResult().getId()) ? testCaseStepResult.getResult() : result;183 }184 int processedSteps = processedStepCount(testCaseStepsResult);185 if (processedSteps % stepResultUpdateSize == 0) {186 testCaseResult.setTestCaseStepResults(testCaseStepsResult);187 postTestcaseResult();188 currentIndex = +stepResultUpdateSize;189 processedSteps = 0;190 testCaseStepsResult = new ArrayList<>();191 testCaseResult.setCurrentIndex(currentIndex);192 }193 }194 testCaseResult.setTestCaseStepResults(testCaseStepsResult);195 } catch (Exception e) {196 log.error(e.getMessage(), e);197 }198 testCaseResult.setResult(ObjectUtils.defaultIfNull(testCaseResult.getResult(), result));199 testCaseResult.setEndTime(new Timestamp(System.currentTimeMillis()));200 if ((testCaseResult.getResult() == ResultConstant.SUCCESS) && (result == ResultConstant.SUCCESS)) {201 testCaseResult.setMessage(AutomatorMessages.MSG_TEST_CASE_SUCCESS);202 } else if (StringUtils.isBlank(testCaseResult.getMessage())) {203 testCaseResult.setMessage(AutomatorMessages.MSG_TEST_CASE_FAILURE);204 }205 // check for browser closed condition206 if (testCaseResult.getResult() != ResultConstant.SUCCESS) {207 if (ErrorCodes.BROWSER_CLOSED.equals(testCaseResult.getErrorCode())) {208 DriverManager.getDriverManager().setRestartDriverSession(Boolean.TRUE);209 }210 }211 if (testDeviceEntity.getCreateSessionAtCaseLevel()) {212 endSession();213 }214 resetThreadContextData();215 return testCaseResult;216 }217 private boolean startNewDriverSession() {218 boolean shouldStart = false;219 DriverManager driverManager = DriverManager.getDriverManager();220 String capabilityStr = hasDriverSession();221 String currentSessionId = DriverManager.getDriverManager().getDriver().getRemoteWebDriver().getSessionId().toString();222 if (driverManager != null) {223 shouldStart = driverManager.getRestartDriverSession() || currentSessionId == null224 || (currentSessionId != null && capabilityStr == null);225 }226 return shouldStart;227 }228 public String getUrl() {...

Full Screen

Full Screen

resetThreadContextData

Using AI Code Generation

copy

Full Screen

1import com.testsigma.automator.runners.TestcaseStepRunner;2public class 2 {3 public static void main(String[] args) {4 TestcaseStepRunner.resetThreadContextData();5 }6}7import com.testsigma.automator.runners.TestcaseStepRunner;8public class 3 {9 public static void main(String[] args) {10 TestcaseStepRunner.resetThreadContextData();11 }12}13import com.testsigma.automator.runners.TestcaseStepRunner;14public class 4 {15 public static void main(String[] args) {16 TestcaseStepRunner.resetThreadContextData();17 }18}19import com.testsigma.automator.runners.TestcaseStepRunner;20public class 5 {21 public static void main(String[] args) {22 TestcaseStepRunner.resetThreadContextData();23 }24}25import com.testsigma.automator.runners.TestcaseStepRunner;26public class 6 {27 public static void main(String[] args) {28 TestcaseStepRunner.resetThreadContextData();29 }30}31import com.testsigma.automator.runners.TestcaseStepRunner;32public class 7 {33 public static void main(String[] args) {34 TestcaseStepRunner.resetThreadContextData();35 }36}37import com.testsigma.automator.runners.TestcaseStepRunner;38public class 8 {39 public static void main(String[] args) {40 TestcaseStepRunner.resetThreadContextData();41 }42}43import

Full Screen

Full Screen

resetThreadContextData

Using AI Code Generation

copy

Full Screen

1import com.testsigma.automator.runners.TestcaseStepRunner;2public class TestcaseStepRunnerResetThreadContextData {3public static void main(String[] args) {4TestcaseStepRunner.resetThreadContextData();5}6}7import com.testsigma.automator.runners.TestcaseStepRunner;8public class TestcaseStepRunnerGetThreadContextData {9public static void main(String[] args) {10System.out.println(TestcaseStepRunner.getThreadContextData());11}12}13import com.testsigma.automator.runners.TestcaseStepRunner;14public class TestcaseStepRunnerSetThreadContextData {15public static void main(String[] args) {16TestcaseStepRunner.setThreadContextData("test");17}18}19import com.testsigma.automator.runners.TestcaseStepRunner;20public class TestcaseStepRunnerGetThreadContextData {21public static void main(String[] args) {22System.out.println(TestcaseStepRunner.getThreadContextData());23}24}25import com.testsigma.automator.runners.TestcaseStepRunner;26public class TestcaseStepRunnerGetThreadContextData {27public static void main(String[] args) {28System.out.println(TestcaseStepRunner.getThreadContextData());29}30}31import com.testsigma.automator.runners.TestcaseStepRunner;32public class TestcaseStepRunnerSetThreadContextData {33public static void main(String[] args) {34TestcaseStepRunner.setThreadContextData("test");35}36}37import com.testsigma.automator.runners.TestcaseStepRunner;38public class TestcaseStepRunnerGetThreadContextData {39public static void main(String[] args) {40System.out.println(TestcaseStepRunner.get

Full Screen

Full Screen

resetThreadContextData

Using AI Code Generation

copy

Full Screen

1import com.testsigma.automator.runners.TestcaseStepRunner;2public class 2{3 public static void main(String[] args) {4 TestcaseStepRunner.resetThreadContextData();5 }6}7import com.testsigma.automator.runners.TestcaseStepRunner;8public class 3{9 public static void main(String[] args) {10 TestcaseStepRunner.resetThreadContextData();11 }12}13import com.testsigma.automator.runners.TestcaseStepRunner;14public class 4{15 public static void main(String[] args) {16 TestcaseStepRunner.resetThreadContextData();17 }18}19import com.testsigma.automator.runners.TestcaseStepRunner;20public class 5{21 public static void main(String[] args) {22 TestcaseStepRunner.resetThreadContextData();23 }24}25import com.testsigma.automator.runners.TestcaseStepRunner;26public class 6{27 public static void main(String[] args) {28 TestcaseStepRunner.resetThreadContextData();29 }30}31import com.testsigma.automator.runners.TestcaseStepRunner;32public class 7{33 public static void main(String[] args) {34 TestcaseStepRunner.resetThreadContextData();35 }36}37import com.testsigma.automator.runners.TestcaseStepRunner;

Full Screen

Full Screen

resetThreadContextData

Using AI Code Generation

copy

Full Screen

1import com.testsigma.automator.runners.TestcaseStepRunner;2import com.testsigma.automator.util.ThreadContextData;3public class 2 {4 public static void main(String[] args) {5 TestcaseStepRunner runner = new TestcaseStepRunner();6 runner.resetThreadContextData();7 System.out.println(ThreadContextData.getThreadContextData().get("key1"));8 }9}10import com.testsigma.automator.util.ThreadContextData;11public class 3 {12 public static void main(String[] args) {13 ThreadContextData.resetThreadContextData();14 System.out.println(ThreadContextData.getThreadContextData().get("key1"));15 }16}

Full Screen

Full Screen

resetThreadContextData

Using AI Code Generation

copy

Full Screen

1import com.testsigma.automator.runners.TestcaseStepRunner;2import com.testsigma.automator.common.TestContext;3TestcaseStepRunner.resetThreadContextData();4import com.testsigma.automator.runners.TestcaseStepRunner;5import com.testsigma.automator.common.TestContext;6TestcaseStepRunner.resetThreadContextData();7import com.testsigma.automator.runners.TestcaseStepRunner;8import com.testsigma.automator.common.TestContext;9TestcaseStepRunner.resetThreadContextData();10import com.testsigma.automator.runners.TestcaseStepRunner;11import com.testsigma.automator.common.TestContext;12TestcaseStepRunner.resetThreadContextData();13import com.testsigma.automator.runners.TestcaseStepRunner;14import com.testsigma.automator.common.TestContext;15TestcaseStepRunner.resetThreadContextData();16import com.testsigma.automator.runners.TestcaseStepRunner;17import com.testsigma.automator.common.TestContext;18TestcaseStepRunner.resetThreadContextData();19import com.testsigma.automator.runners.TestcaseStepRunner;20import com.testsigma.automator.common.TestContext;21TestcaseStepRunner.resetThreadContextData();22import

Full Screen

Full Screen

resetThreadContextData

Using AI Code Generation

copy

Full Screen

1import com.testsigma.automator.runners.TestcaseStepRunner;2public class 2 {3 public static void main(String[] args) throws Exception {4 TestcaseStepRunner.resetThreadContextData();5 }6}7import com.testsigma.automator.runners.TestcaseStepRunner;8public class 3 {9 public static void main(String[] args) throws Exception {10 TestcaseStepRunner.resetThreadContextData();11 }12}13import com.testsigma.automator.runners.TestcaseStepRunner;14public class 4 {15 public static void main(String[] args) throws Exception {16 TestcaseStepRunner.resetThreadContextData();17 }18}19import com.testsigma.automator.runners.TestcaseStepRunner;20public class 5 {21 public static void main(String[] args) throws Exception {22 TestcaseStepRunner.resetThreadContextData();23 }24}25import

Full Screen

Full Screen

resetThreadContextData

Using AI Code Generation

copy

Full Screen

1import com.testsigma.automator.runners.TestcaseStepRunner;2TestcaseStepRunner.resetThreadContextData();3import com.testsigma.automator.runners.TestcaseStepRunner;4TestcaseStepRunner.resetThreadContextData();5import com.testsigma.automator.runners.TestcaseStepRunner;6TestcaseStepRunner.resetThreadContextData();7import com.testsigma.automator.runners.TestcaseStepRunner;8TestcaseStepRunner.resetThreadContextData();9import com.testsigma.automator.runners.TestcaseStepRunner;10TestcaseStepRunner.resetThreadContextData();

Full Screen

Full Screen

Automation Testing Tutorials

Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful