Fix for APPC-1286
Increased test coverage from 49% to 73% for package.
Added coverage for 4 classes that were previously at 0% coverage.
Refactored slow running code into a method that can be mocked
to speed up execution of unit tests.
Issue-ID: APPC-1286
Change-Id: I3ebe5f6bfbc59228b57d20a3c45081e40ee8e31e
Signed-off-by: Joss Armstrong <joss.armstrong@ericsson.com>
diff --git a/appc-oam/appc-oam-bundle/src/main/java/org/onap/appc/oam/processor/BaseCommon.java b/appc-oam/appc-oam-bundle/src/main/java/org/onap/appc/oam/processor/BaseCommon.java
index 47f9c9e..735116d 100644
--- a/appc-oam/appc-oam-bundle/src/main/java/org/onap/appc/oam/processor/BaseCommon.java
+++ b/appc-oam/appc-oam-bundle/src/main/java/org/onap/appc/oam/processor/BaseCommon.java
@@ -5,6 +5,8 @@
* Copyright (C) 2017-2018 AT&T Intellectual Property. All rights reserved.
* ================================================================================
* Copyright (C) 2017 Amdocs
+ * ================================================================================
+ * Modifications (C) 2018 Ericsson
* =============================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -42,6 +44,7 @@
import org.slf4j.MDC;
import java.net.InetAddress;
+import java.net.UnknownHostException;
import java.time.Instant;
import java.util.Arrays;
import java.util.Date;
@@ -129,9 +132,9 @@
try {
//!!!Don't change the following to a .getHostName() again please. It's wrong!MDC.put(MDC_SERVER_FQDN,
// InetAddress.getLocalHost().getCanonicalHostName());
- MDC.put(MDC_SERVER_FQDN, InetAddress.getLocalHost().getCanonicalHostName());
- MDC.put(MDC_SERVER_IP_ADDRESS, InetAddress.getLocalHost().getHostAddress());
- MDC.put(LoggingConstants.MDCKeys.SERVER_NAME, InetAddress.getLocalHost().getHostName());
+ MDC.put(MDC_SERVER_FQDN, getHostInfo("canonicalHostName"));
+ MDC.put(MDC_SERVER_IP_ADDRESS, getHostInfo("hostName"));
+ MDC.put(LoggingConstants.MDCKeys.SERVER_NAME, getHostInfo("hostName"));
} catch (Exception e) {
logger.error("MDC constant error", e);
}
@@ -261,4 +264,20 @@
logger.debug(String.format(message, args));
}
}
+
+ protected String getHostInfo(String type) throws UnknownHostException {
+ InetAddress inetAddress = InetAddress.getLocalHost();
+ String returnValue = "";
+ switch(type) {
+ case "canonicalHostName": returnValue = inetAddress.getCanonicalHostName();
+ break;
+ case "hostName": returnValue = inetAddress.getHostName();
+ break;
+ case "hostAddress": returnValue = inetAddress.getHostAddress();
+ break;
+ default: returnValue = "Invalid operation";
+ break;
+ }
+ return returnValue;
+ }
}
diff --git a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseActionRunnableTest.java b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseActionRunnableTest.java
index 07bb12e..a378638 100644
--- a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseActionRunnableTest.java
+++ b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseActionRunnableTest.java
@@ -5,6 +5,8 @@
* Copyright (C) 2017-2018 AT&T Intellectual Property. All rights reserved.
* ================================================================================
* Copyright (C) 2017 Amdocs
+ * ================================================================================
+ * Modifications (C) 2018 Ericsson
* =============================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -93,7 +95,7 @@
}
}
- private TestAbc testBaseAcionRunnable;
+ private TestAbc testBaseActionRunnable;
private BaseProcessor testProcessor;
private StateHelper mockStateHelper = mock(StateHelper.class);
private OperationHelper mockOperHelper = mock(OperationHelper.class);
@@ -110,126 +112,127 @@
new TestProcessor(mockLogger, mockConfigHelper, mockStateHelper, null, mockOperHelper));
Whitebox.setInternalState(testProcessor, "bundleHelper", mockBundleHelper);
- testBaseAcionRunnable = spy(new TestAbc(testProcessor));
- Whitebox.setInternalState(testBaseAcionRunnable, "commonHeader", mock(CommonHeader.class));
+ testBaseActionRunnable = spy(new TestAbc(testProcessor));
+ Whitebox.setInternalState(testBaseActionRunnable, "commonHeader", mock(CommonHeader.class));
}
@Test
public void testSetTimeoutValues() throws Exception {
- Whitebox.setInternalState(testBaseAcionRunnable, "timeoutMs", 0);
- Whitebox.setInternalState(testBaseAcionRunnable, "startTimeMs", 0);
- Whitebox.setInternalState(testBaseAcionRunnable, "doTimeoutChecking", false);
+ Whitebox.setInternalState(testBaseActionRunnable, "timeoutMs", 0);
+ Whitebox.setInternalState(testBaseActionRunnable, "startTimeMs", 0);
+ Whitebox.setInternalState(testBaseActionRunnable, "doTimeoutChecking", false);
long expectedTimeout = 10000L;
Mockito.doReturn(expectedTimeout).when(mockConfigHelper).getOAMOperationTimeoutValue(any());
- testBaseAcionRunnable.setTimeoutValues();
- Assert.assertEquals("Should set timeoutMs", expectedTimeout, testBaseAcionRunnable.timeoutMs);
- Assert.assertTrue("Should set start time MS", testBaseAcionRunnable.startTimeMs != 0);
- Assert.assertTrue("Should do check", testBaseAcionRunnable.doTimeoutChecking);
+ testBaseActionRunnable.setTimeoutValues();
+ Assert.assertEquals("Should set timeoutMs", expectedTimeout, testBaseActionRunnable.timeoutMs);
+ Assert.assertTrue("Should set start time MS", testBaseActionRunnable.startTimeMs != 0);
+ Assert.assertTrue("Should do check", testBaseActionRunnable.doTimeoutChecking);
- Whitebox.setInternalState(testBaseAcionRunnable, "timeoutMs", 0);
- Whitebox.setInternalState(testBaseAcionRunnable, "startTimeMs", 0);
- Whitebox.setInternalState(testBaseAcionRunnable, "doTimeoutChecking", false);
+ Whitebox.setInternalState(testBaseActionRunnable, "timeoutMs", 0);
+ Whitebox.setInternalState(testBaseActionRunnable, "startTimeMs", 0);
+ Whitebox.setInternalState(testBaseActionRunnable, "doTimeoutChecking", false);
expectedTimeout = 20000L;
Mockito.doReturn(expectedTimeout).when(mockConfigHelper).getOAMOperationTimeoutValue(any());
- testBaseAcionRunnable.setTimeoutValues();
- Assert.assertEquals("Should set timeoutMs", expectedTimeout, testBaseAcionRunnable.timeoutMs);
- Assert.assertTrue("Should set start time MS", testBaseAcionRunnable.startTimeMs != 0);
- Assert.assertTrue("Should do check", testBaseAcionRunnable.doTimeoutChecking);
+ testBaseActionRunnable.setTimeoutValues();
+ Assert.assertEquals("Should set timeoutMs", expectedTimeout, testBaseActionRunnable.timeoutMs);
+ Assert.assertTrue("Should set start time MS", testBaseActionRunnable.startTimeMs != 0);
+ Assert.assertTrue("Should do check", testBaseActionRunnable.doTimeoutChecking);
- Whitebox.setInternalState(testBaseAcionRunnable, "timeoutMs", 0);
- Whitebox.setInternalState(testBaseAcionRunnable, "startTimeMs", 0);
- Whitebox.setInternalState(testBaseAcionRunnable, "doTimeoutChecking", false);
+ Whitebox.setInternalState(testBaseActionRunnable, "timeoutMs", 0);
+ Whitebox.setInternalState(testBaseActionRunnable, "startTimeMs", 0);
+ Whitebox.setInternalState(testBaseActionRunnable, "doTimeoutChecking", false);
expectedTimeout = 0L;
Mockito.doReturn(expectedTimeout).when(mockConfigHelper).getOAMOperationTimeoutValue(any());
- testBaseAcionRunnable.setTimeoutValues();
- Assert.assertEquals("Should set timeoutMs", expectedTimeout, testBaseAcionRunnable.timeoutMs);
- Assert.assertTrue("Should not set start time MS", testBaseAcionRunnable.startTimeMs == 0);
- Assert.assertFalse("Should not do check", testBaseAcionRunnable.doTimeoutChecking);
+ testBaseActionRunnable.setTimeoutValues();
+ Assert.assertEquals("Should set timeoutMs", expectedTimeout, testBaseActionRunnable.timeoutMs);
+ Assert.assertTrue("Should not set start time MS", testBaseActionRunnable.startTimeMs == 0);
+ Assert.assertFalse("Should not do check", testBaseActionRunnable.doTimeoutChecking);
}
@Test
public void testRun() throws Exception {
// test doAction failed
- Whitebox.setInternalState(testBaseAcionRunnable, "doActionResult", false);
- testBaseAcionRunnable.run();
+ Whitebox.setInternalState(testBaseActionRunnable, "doActionResult", false);
+ Mockito.doReturn("SOME HOST NAME").when(testBaseActionRunnable).getHostInfo(Mockito.anyString());
+ testBaseActionRunnable.run();
Assert.assertFalse("isWaiting should still be false",
- Whitebox.getInternalState(testBaseAcionRunnable, "isWaiting"));
+ Whitebox.getInternalState(testBaseActionRunnable, "isWaiting"));
// test doAction success
- Whitebox.setInternalState(testBaseAcionRunnable, "doActionResult", true);
+ Whitebox.setInternalState(testBaseActionRunnable, "doActionResult", true);
// with checkState return true
- Mockito.doReturn(true).when(testBaseAcionRunnable).checkState();
- testBaseAcionRunnable.run();
+ Mockito.doReturn(true).when(testBaseActionRunnable).checkState();
+ testBaseActionRunnable.run();
Assert.assertFalse("isWaiting should still be false",
- Whitebox.getInternalState(testBaseAcionRunnable, "isWaiting"));
+ Whitebox.getInternalState(testBaseActionRunnable, "isWaiting"));
// with checkState return false
- Mockito.doReturn(false).when(testBaseAcionRunnable).checkState();
- testBaseAcionRunnable.run();
+ Mockito.doReturn(false).when(testBaseActionRunnable).checkState();
+ testBaseActionRunnable.run();
Assert.assertTrue("isWaiting should still be true",
- Whitebox.getInternalState(testBaseAcionRunnable, "isWaiting"));
+ Whitebox.getInternalState(testBaseActionRunnable, "isWaiting"));
// should stay
- testBaseAcionRunnable.run();
- Mockito.verify(testBaseAcionRunnable, times(1)).keepWaiting();
+ testBaseActionRunnable.run();
+ Mockito.verify(testBaseActionRunnable, times(1)).keepWaiting();
}
@Test
public void testSetAbortStatus() throws Exception {
- testBaseAcionRunnable.setAbortStatus();
+ testBaseActionRunnable.setAbortStatus();
Assert.assertEquals("Should return abort code", OAMCommandStatus.ABORT.getResponseCode(),
- testBaseAcionRunnable.status.getCode().intValue());
+ testBaseActionRunnable.status.getCode().intValue());
Assert.assertTrue("Should set abort due to execution error message",
- testBaseAcionRunnable.status.getMessage().endsWith(
- String.format(testBaseAcionRunnable.ABORT_MESSAGE_FORMAT,
- testRpc.name(), testBaseAcionRunnable.DUE_TO_EXECUTION_ERROR)));
+ testBaseActionRunnable.status.getMessage().endsWith(
+ String.format(testBaseActionRunnable.ABORT_MESSAGE_FORMAT,
+ testRpc.name(), testBaseActionRunnable.DUE_TO_EXECUTION_ERROR)));
}
@Test
public void testCheckState() throws Exception {
// 1. with isTimeout true
- Mockito.doReturn(true).when(testBaseAcionRunnable).isTimeout("checkState");
- Assert.assertTrue("Should return true", testBaseAcionRunnable.checkState());
+ Mockito.doReturn(true).when(testBaseActionRunnable).isTimeout("checkState");
+ Assert.assertTrue("Should return true", testBaseActionRunnable.checkState());
// 2. with isTimeout false and
- Mockito.doReturn(false).when(testBaseAcionRunnable).isTimeout("checkState");
+ Mockito.doReturn(false).when(testBaseActionRunnable).isTimeout("checkState");
// 2.1 with task not all done
Mockito.doReturn(false).when(mockBundleHelper).isAllTaskDone(any());
- Assert.assertFalse("Should return false", testBaseAcionRunnable.checkState());
+ Assert.assertFalse("Should return false", testBaseActionRunnable.checkState());
// 2. 2 with task all done
Mockito.doReturn(true).when(mockBundleHelper).isAllTaskDone(any());
// 2.2.1 with has bundle failure
- Mockito.doReturn(true).when(testBaseAcionRunnable).hasBundleOperationFailure();
- Assert.assertTrue("Should return true", testBaseAcionRunnable.checkState());
+ Mockito.doReturn(true).when(testBaseActionRunnable).hasBundleOperationFailure();
+ Assert.assertTrue("Should return true", testBaseActionRunnable.checkState());
// 2.2.2 with no bundle failure
- Mockito.doReturn(false).when(testBaseAcionRunnable).hasBundleOperationFailure();
+ Mockito.doReturn(false).when(testBaseActionRunnable).hasBundleOperationFailure();
Mockito.doReturn(targetState).when(mockStateHelper).getBundlesState();
- Assert.assertTrue("Should return true", testBaseAcionRunnable.checkState());
+ Assert.assertTrue("Should return true", testBaseActionRunnable.checkState());
Mockito.doReturn(AppcOamStates.Started).when(mockStateHelper).getBundlesState();
- Assert.assertFalse("Should return false", testBaseAcionRunnable.checkState());
+ Assert.assertFalse("Should return false", testBaseActionRunnable.checkState());
}
@Test
public void testPostAction() throws Exception {
Mockito.doReturn(AppcOamStates.Started).when(mockStateHelper).getCurrentOamState();
// set status to avoid NPE when using status
- testBaseAcionRunnable.setAbortStatus();
+ testBaseActionRunnable.setAbortStatus();
// test no parameter
- testBaseAcionRunnable.postAction(null);
+ testBaseActionRunnable.postAction(null);
Mockito.verify(mockOperHelper, times(1)).sendNotificationMessage(any(), any(), any());
Mockito.verify(mockStateHelper, times(0)).setState(any());
Mockito.verify(testProcessor, times(1)).cancelAsyncTask();
// test with parameter
- testBaseAcionRunnable.postAction(AppcOamStates.Error);
+ testBaseActionRunnable.postAction(AppcOamStates.Error);
Mockito.verify(mockOperHelper, times(2)).sendNotificationMessage(any(), any(), any());
Mockito.verify(mockStateHelper, times(1)).setState(any());
Mockito.verify(testProcessor, times(2)).cancelAsyncTask();
@@ -238,55 +241,56 @@
@Test
public void testIsTimeout() throws Exception {
String parentName = "testing";
- Whitebox.setInternalState(testBaseAcionRunnable, "doTimeoutChecking", false);
- Assert.assertFalse("Should not be timeout", testBaseAcionRunnable.isTimeout(parentName));
+ Whitebox.setInternalState(testBaseActionRunnable, "doTimeoutChecking", false);
+ Assert.assertFalse("Should not be timeout", testBaseActionRunnable.isTimeout(parentName));
Mockito.doReturn(AppcOamStates.Started).when(mockStateHelper).getCurrentOamState();
- Whitebox.setInternalState(testBaseAcionRunnable, "doTimeoutChecking", true);
- Whitebox.setInternalState(testBaseAcionRunnable, "timeoutMs", System.currentTimeMillis() + 100);
- Whitebox.setInternalState(testBaseAcionRunnable, "startTimeMs", 2);
- Assert.assertFalse("Should not be timeout", testBaseAcionRunnable.isTimeout(parentName));
+ Whitebox.setInternalState(testBaseActionRunnable, "doTimeoutChecking", true);
+ Whitebox.setInternalState(testBaseActionRunnable, "timeoutMs", System.currentTimeMillis() + 100);
+ Whitebox.setInternalState(testBaseActionRunnable, "startTimeMs", 2);
+ Assert.assertFalse("Should not be timeout", testBaseActionRunnable.isTimeout(parentName));
long timeoutMs = 1;
- Whitebox.setInternalState(testBaseAcionRunnable, "timeoutMs", timeoutMs);
- Whitebox.setInternalState(testBaseAcionRunnable, "startTimeMs", 2);
- Assert.assertTrue("Should be timeout", testBaseAcionRunnable.isTimeout(parentName));
- Mockito.verify(testBaseAcionRunnable, times(1)).postAction(any());
+ Whitebox.setInternalState(testBaseActionRunnable, "timeoutMs", timeoutMs);
+ Whitebox.setInternalState(testBaseActionRunnable, "startTimeMs", 2);
+ Assert.assertTrue("Should be timeout", testBaseActionRunnable.isTimeout(parentName));
+ Mockito.verify(testBaseActionRunnable, times(1)).postAction(any());
Assert.assertEquals("Should return timeout code", OAMCommandStatus.TIMEOUT.getResponseCode(),
- testBaseAcionRunnable.status.getCode().intValue());
+ testBaseActionRunnable.status.getCode().intValue());
Assert.assertTrue("Should set timeout message",
- testBaseAcionRunnable.status.getMessage().endsWith(
- String.format(testBaseAcionRunnable.TIMEOUT_MESSAGE_FORMAT, testRpc.name(), timeoutMs)));
+ testBaseActionRunnable.status.getMessage().endsWith(
+ String.format(testBaseActionRunnable.TIMEOUT_MESSAGE_FORMAT, testRpc.name(), timeoutMs)));
}
@SuppressWarnings("unchecked")
@Test
public void testHasBundleOperationFailure() throws Exception {
Mockito.when(mockBundleHelper.getFailedMetrics(anyMap())).thenReturn(Long.valueOf("0"));
- Assert.assertFalse("should return false", testBaseAcionRunnable.hasBundleOperationFailure());
+ Assert.assertFalse("should return false", testBaseActionRunnable.hasBundleOperationFailure());
Mockito.when(mockStateHelper.getCurrentOamState()).thenReturn(AppcOamStates.Restarting);
long failedNumber = 1;
Mockito.doReturn(failedNumber).when(mockBundleHelper).getFailedMetrics(anyMap());
- Assert.assertTrue("should return true", testBaseAcionRunnable.hasBundleOperationFailure());
- Mockito.verify(testBaseAcionRunnable, times(1)).setStatus(OAMCommandStatus.UNEXPECTED_ERROR,
- String.format(testBaseAcionRunnable.BUNDLE_OPERATION_FAILED_FORMAT, failedNumber));
- Mockito.verify(testBaseAcionRunnable, times(1)).postAction(AppcOamStates.Error);
+ Assert.assertTrue("should return true", testBaseActionRunnable.hasBundleOperationFailure());
+ Mockito.verify(testBaseActionRunnable, times(1)).setStatus(OAMCommandStatus.UNEXPECTED_ERROR,
+ String.format(testBaseActionRunnable.BUNDLE_OPERATION_FAILED_FORMAT, failedNumber));
+ Mockito.verify(testBaseActionRunnable, times(1)).postAction(AppcOamStates.Error);
}
@Test
public void testAbortRunnable() throws Exception {
Mockito.doReturn(AppcOamStates.Restarting).when(mockStateHelper).getCurrentOamState();
+ Mockito.doReturn("SOME HOST NAME").when(testBaseActionRunnable).getHostInfo(Mockito.anyString());
AppcOam.RPC newRpc = AppcOam.RPC.restart;
- testBaseAcionRunnable.abortRunnable(newRpc);
+ testBaseActionRunnable.abortRunnable(newRpc);
Assert.assertEquals("Should return abort code", OAMCommandStatus.ABORT.getResponseCode(),
- testBaseAcionRunnable.status.getCode().intValue());
+ testBaseActionRunnable.status.getCode().intValue());
Assert.assertTrue("Should set abort due to new request message",
- testBaseAcionRunnable.status.getMessage().endsWith(
- String.format(testBaseAcionRunnable.ABORT_MESSAGE_FORMAT, testRpc.name(),
- String.format(testBaseAcionRunnable.NEW_RPC_OPERATION_REQUEST, newRpc.name()))));
+ testBaseActionRunnable.status.getMessage().endsWith(
+ String.format(testBaseActionRunnable.ABORT_MESSAGE_FORMAT, testRpc.name(),
+ String.format(testBaseActionRunnable.NEW_RPC_OPERATION_REQUEST, newRpc.name()))));
Mockito.verify(mockOperHelper, times(1)).sendNotificationMessage(any(), any(), any());
- Mockito.verify(testBaseAcionRunnable, times(1)).resetLogProperties(false);
- Mockito.verify(testBaseAcionRunnable, times(1)).resetLogProperties(true);
+ Mockito.verify(testBaseActionRunnable, times(1)).resetLogProperties(false);
+ Mockito.verify(testBaseActionRunnable, times(1)).resetLogProperties(true);
}
}
diff --git a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseCommonTest.java b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseCommonTest.java
index 7b811e9..60d9e3c 100644
--- a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseCommonTest.java
+++ b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseCommonTest.java
@@ -5,6 +5,8 @@
* Copyright (C) 2017-2018 AT&T Intellectual Property. All rights reserved.
* ================================================================================
* Copyright (C) 2017 Amdocs
+ * ================================================================================
+ * Modifications (C) 2018 Ericsson
* =============================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -44,7 +46,6 @@
import org.powermock.modules.junit4.PowerMockRunner;
import org.powermock.reflect.Whitebox;
import org.slf4j.MDC;
-
import java.util.Map;
import static org.mockito.Mockito.mock;
@@ -115,6 +116,7 @@
Mockito.doReturn(AppcOamStates.Started).when(mockStateHelper).getCurrentOamState();
Mockito.doReturn("testRequestId").when(mockCommonHeader).getRequestId();
Mockito.doReturn("testOrigId").when(mockCommonHeader).getOriginatorId();
+ Mockito.doReturn("SOME HOST NAME").when(testBaseCommon).getHostInfo(Mockito.anyString());
String exceptionMessage = "testing";
@@ -146,6 +148,7 @@
@Test
public void testSetInitialLogProperties() throws Exception {
mockStatic(MDC.class);
+ Mockito.doReturn("SOME HOST NAME").when(testBaseCommon).getHostInfo(Mockito.anyString());
testBaseCommon.setInitialLogProperties();
PowerMockito.verifyStatic(times(5));
}
@@ -159,6 +162,7 @@
@Test
public void testResetLogProperties() throws Exception {
+ Mockito.doReturn("SOME HOST NAME").when(testBaseCommon).getHostInfo(Mockito.anyString());
testBaseCommon.setInitialLogProperties();
testBaseCommon.resetLogProperties(false);
diff --git a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseProcessorTest.java b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseProcessorTest.java
index f515418..55ae11b 100644
--- a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseProcessorTest.java
+++ b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/BaseProcessorTest.java
@@ -5,6 +5,8 @@
* Copyright (C) 2017-2018 AT&T Intellectual Property. All rights reserved.
* ================================================================================
* Copyright (C) 2017 Amdocs
+ * ================================================================================
+ * Modifications (C) 2018 Ericsson
* =============================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -94,7 +96,7 @@
testBaseProcessor = spy(
new TestAbc(null, mockConfigHelper, mockStateHelper, mockTaskHelper, mockOperHelper));
-
+ Mockito.doReturn("SOME HOST NAME").when(testBaseProcessor).getHostInfo(Mockito.anyString());
Whitebox.setInternalState(testBaseProcessor, "commonHeader", mockCommonHeader);
// to avoid operation on logger fail, mock up the logger
diff --git a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamMmodeProcessorTest.java b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamMmodeProcessorTest.java
new file mode 100644
index 0000000..73b2db9
--- /dev/null
+++ b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamMmodeProcessorTest.java
@@ -0,0 +1,116 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : APPC
+ * ================================================================================
+ * Copyright (C) 2018 Ericsson
+ * =============================================================================
+ * 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.onap.appc.oam.processor;
+
+import static org.junit.Assert.assertTrue;
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.times;
+import java.net.UnknownHostException;
+import java.util.concurrent.TimeoutException;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mockito;
+import org.onap.appc.exceptions.APPCException;
+import org.onap.appc.exceptions.InvalidInputException;
+import org.onap.appc.exceptions.InvalidStateException;
+import org.onap.appc.i18n.Msg;
+import org.onap.appc.oam.AppcOam;
+import org.onap.appc.oam.util.AsyncTaskHelper;
+import org.onap.appc.oam.util.ConfigurationHelper;
+import org.onap.appc.oam.util.OperationHelper;
+import org.onap.appc.oam.util.StateHelper;
+import org.onap.appc.statemachine.impl.readers.AppcOamStates;
+import org.opendaylight.yang.gen.v1.org.onap.appc.oam.rev170303.StartInput;
+import org.opendaylight.yang.gen.v1.org.onap.appc.oam.rev170303.common.header.CommonHeader;
+import org.powermock.reflect.Whitebox;
+import org.onap.appc.requesthandler.LCMStateManager;
+import com.att.eelf.configuration.EELFLogger;
+
+public class OamMmodeProcessorTest {
+
+ private class TestAbc extends OamMmodeProcessor {
+
+ /**
+ * Constructor
+ *
+ * @param eelfLogger for logging
+ * @param configurationHelperIn for property reading
+ * @param stateHelperIn for APP-C OAM state checking
+ * @param asyncTaskHelperIn for scheduling async task
+ * @param operationHelperIn for operational helper
+ */
+ TestAbc(EELFLogger eelfLogger,
+ ConfigurationHelper configurationHelperIn,
+ StateHelper stateHelperIn,
+ AsyncTaskHelper asyncTaskHelperIn,
+ OperationHelper operationHelperIn) {
+ super(eelfLogger, configurationHelperIn, stateHelperIn, asyncTaskHelperIn, operationHelperIn);
+
+ // must set rpc and auditMsg
+ rpc = testRpc;
+ auditMsg = Msg.OAM_OPERATION_STARTING;
+ }
+ }
+
+ private ConfigurationHelper mockConfigHelper = mock(ConfigurationHelper.class);
+ private StateHelper mockStateHelper = mock(StateHelper.class);
+ private AsyncTaskHelper mockTaskHelper = mock(AsyncTaskHelper.class);
+ private OperationHelper mockOperHelper = mock(OperationHelper.class);
+ private AppcOam.RPC testRpc = AppcOam.RPC.start;
+ private AppcOamStates currentState = AppcOamStates.Stopped;
+ private StartInput mockInput = mock(StartInput.class);
+ private CommonHeader mockCommonHeader = mock(CommonHeader.class);
+ private LCMStateManager mockLCMStateManager = mock(LCMStateManager.class);
+
+
+ // to avoid operation on logger fail, mock up the logger
+ EELFLogger mockLogger = mock(EELFLogger.class);
+ private OamMmodeProcessor oamMmodeProcessor = Mockito.spy(new TestAbc(mockLogger, mockConfigHelper, mockStateHelper, mockTaskHelper, mockOperHelper));
+
+ @Before
+ public void setup() throws UnknownHostException, APPCException {
+ Mockito.doReturn("SOME HOST NAME").when(oamMmodeProcessor).getHostInfo(Mockito.anyString());
+ Mockito.doReturn(mockCommonHeader).when(mockOperHelper).getCommonHeader(mockInput);
+ Mockito.doReturn(mockCommonHeader).when(mockInput).getCommonHeader();
+ Mockito.doReturn(mockLCMStateManager).when(mockOperHelper).getService(LCMStateManager.class);
+ Whitebox.setInternalState(oamMmodeProcessor, "commonHeader", mockCommonHeader);
+ }
+
+ @Test
+ public void testPreProcess() throws InvalidInputException, InvalidStateException, APPCException, InterruptedException, TimeoutException {
+ Mockito.doReturn(currentState).when(mockStateHelper).getCurrentOamState();
+ AppcOamStates nextState = AppcOamStates.Starting;
+ Mockito.doReturn(nextState)
+ .when(mockOperHelper).getNextState(testRpc.getAppcOperation(), currentState);
+ oamMmodeProcessor.preProcess(mockInput);
+ Mockito.verify(mockOperHelper, times(1)).isInputValid(mockInput);
+ Mockito.verify(mockOperHelper, times(1)).getNextState(testRpc.getAppcOperation(), currentState);
+ Mockito.verify(mockStateHelper, times(1)).setState(nextState);
+ }
+
+ @Test
+ public void testScheduleAsyncTask() throws Exception {
+ oamMmodeProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamMmodeProcessor, "runnable");
+ assertTrue(runnable != null);
+ }
+}
diff --git a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamRestartProcessorTest.java b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamRestartProcessorTest.java
new file mode 100644
index 0000000..880f466
--- /dev/null
+++ b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamRestartProcessorTest.java
@@ -0,0 +1,121 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : APPC
+ * ================================================================================
+ * Copyright (C) 2018 Ericsson
+ * =============================================================================
+ * 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.onap.appc.oam.processor;
+
+import static org.junit.Assert.assertTrue;
+import static org.mockito.Mockito.mock;
+import java.net.UnknownHostException;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mockito;
+import org.onap.appc.exceptions.APPCException;
+import org.onap.appc.i18n.Msg;
+import org.onap.appc.oam.AppcOam;
+import org.onap.appc.oam.AppcOam.RPC;
+import org.onap.appc.oam.util.AsyncTaskHelper;
+import org.onap.appc.oam.util.BundleHelper;
+import org.onap.appc.oam.util.ConfigurationHelper;
+import org.onap.appc.oam.util.OperationHelper;
+import org.onap.appc.oam.util.StateHelper;
+import org.onap.appc.requesthandler.LCMStateManager;
+import org.opendaylight.yang.gen.v1.org.onap.appc.oam.rev170303.RestartInput;
+import org.opendaylight.yang.gen.v1.org.onap.appc.oam.rev170303.common.header.CommonHeader;
+import org.powermock.reflect.Whitebox;
+import com.att.eelf.configuration.EELFLogger;
+
+public class OamRestartProcessorTest {
+
+ private class TestAbc extends OamRestartProcessor {
+
+ /**
+ * Constructor
+ *
+ * @param eelfLogger for logging
+ * @param configurationHelperIn for property reading
+ * @param stateHelperIn for APP-C OAM state checking
+ * @param asyncTaskHelperIn for scheduling async task
+ * @param operationHelperIn for operational helper
+ */
+ TestAbc(EELFLogger eelfLogger,
+ ConfigurationHelper configurationHelperIn,
+ StateHelper stateHelperIn,
+ AsyncTaskHelper asyncTaskHelperIn,
+ OperationHelper operationHelperIn) {
+ super(eelfLogger, configurationHelperIn, stateHelperIn, asyncTaskHelperIn, operationHelperIn);
+
+ // must set rpc and auditMsg
+ rpc = testRpc;
+ auditMsg = Msg.OAM_OPERATION_STARTING;
+ }
+ }
+
+ private ConfigurationHelper mockConfigHelper = mock(ConfigurationHelper.class);
+ private StateHelper mockStateHelper = mock(StateHelper.class);
+ private AsyncTaskHelper mockTaskHelper = mock(AsyncTaskHelper.class);
+ private OperationHelper mockOperHelper = mock(OperationHelper.class);
+ private AppcOam.RPC testRpc = AppcOam.RPC.start;
+ private RestartInput mockInput = mock(RestartInput.class);
+ private CommonHeader mockCommonHeader = mock(CommonHeader.class);
+ private LCMStateManager mockLCMStateManager = mock(LCMStateManager.class);
+
+ // to avoid operation on logger fail, mock up the logger
+ EELFLogger mockLogger = mock(EELFLogger.class);
+ private TestAbc oamRestartProcessor;
+
+ @Before
+ public void setup() throws UnknownHostException, APPCException {
+ oamRestartProcessor = Mockito.spy(new TestAbc(mockLogger, mockConfigHelper, mockStateHelper, mockTaskHelper, mockOperHelper));
+ Mockito.doReturn("SOME HOST NAME").when(oamRestartProcessor).getHostInfo(Mockito.anyString());
+ Mockito.doReturn(mockCommonHeader).when(mockOperHelper).getCommonHeader(mockInput);
+ Mockito.doReturn(mockCommonHeader).when(mockInput).getCommonHeader();
+ Mockito.doReturn(mockLCMStateManager).when(mockOperHelper).getService(LCMStateManager.class);
+ Whitebox.setInternalState(oamRestartProcessor, "commonHeader", mockCommonHeader);
+ }
+
+ @Test
+ public void testScheduleAsyncTask() throws Exception {
+ oamRestartProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamRestartProcessor, "runnable");
+ Whitebox.setInternalState(runnable, "isWaiting", true);
+ assertTrue(runnable != null);
+ }
+
+ @Test
+ public void testDoAction() throws Exception {
+ oamRestartProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamRestartProcessor, "runnable");
+ Whitebox.setInternalState(runnable, "isWaiting", true);
+ BundleHelper mockBundleHelper = mock(BundleHelper.class);
+ Mockito.doReturn(true).when(mockBundleHelper).bundleOperations(Mockito.any(RPC.class), Mockito.anyMap(), Mockito.any(AsyncTaskHelper.class), Mockito.any(BaseCommon.class));
+ Whitebox.setInternalState(oamRestartProcessor, "bundleHelper", mockBundleHelper);
+ assertTrue(runnable.doAction());
+ Mockito.verify(oamRestartProcessor).getInitialDelayMillis();
+ }
+
+ @Test
+ public void testCheckState() throws Exception {
+ oamRestartProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamRestartProcessor, "runnable");
+ assertTrue(runnable.checkState());
+ }
+}
+
diff --git a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamStartProcessorTest.java b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamStartProcessorTest.java
new file mode 100644
index 0000000..5dc8fab
--- /dev/null
+++ b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamStartProcessorTest.java
@@ -0,0 +1,121 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : APPC
+ * ================================================================================
+ * Copyright (C) 2018 Ericsson
+ * =============================================================================
+ * 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.onap.appc.oam.processor;
+
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertTrue;
+import static org.mockito.Mockito.mock;
+import java.net.UnknownHostException;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mockito;
+import org.onap.appc.exceptions.APPCException;
+import org.onap.appc.i18n.Msg;
+import org.onap.appc.oam.AppcOam;
+import org.onap.appc.oam.AppcOam.RPC;
+import org.onap.appc.oam.util.AsyncTaskHelper;
+import org.onap.appc.oam.util.BundleHelper;
+import org.onap.appc.oam.util.ConfigurationHelper;
+import org.onap.appc.oam.util.OperationHelper;
+import org.onap.appc.oam.util.StateHelper;
+import org.onap.appc.requesthandler.LCMStateManager;
+import org.opendaylight.yang.gen.v1.org.onap.appc.oam.rev170303.StartInput;
+import org.opendaylight.yang.gen.v1.org.onap.appc.oam.rev170303.common.header.CommonHeader;
+import org.powermock.reflect.Whitebox;
+import com.att.eelf.configuration.EELFLogger;
+
+public class OamStartProcessorTest {
+
+ private class TestAbc extends OamStartProcessor {
+
+ /**
+ * Constructor
+ *
+ * @param eelfLogger for logging
+ * @param configurationHelperIn for property reading
+ * @param stateHelperIn for APP-C OAM state checking
+ * @param asyncTaskHelperIn for scheduling async task
+ * @param operationHelperIn for operational helper
+ */
+ TestAbc(EELFLogger eelfLogger,
+ ConfigurationHelper configurationHelperIn,
+ StateHelper stateHelperIn,
+ AsyncTaskHelper asyncTaskHelperIn,
+ OperationHelper operationHelperIn) {
+ super(eelfLogger, configurationHelperIn, stateHelperIn, asyncTaskHelperIn, operationHelperIn);
+
+ // must set rpc and auditMsg
+ rpc = testRpc;
+ auditMsg = Msg.OAM_OPERATION_STARTING;
+ }
+ }
+
+ private ConfigurationHelper mockConfigHelper = mock(ConfigurationHelper.class);
+ private StateHelper mockStateHelper = mock(StateHelper.class);
+ private AsyncTaskHelper mockTaskHelper = mock(AsyncTaskHelper.class);
+ private OperationHelper mockOperHelper = mock(OperationHelper.class);
+ private AppcOam.RPC testRpc = AppcOam.RPC.start;
+ private StartInput mockInput = mock(StartInput.class);
+ private CommonHeader mockCommonHeader = mock(CommonHeader.class);
+ private LCMStateManager mockLCMStateManager = mock(LCMStateManager.class);
+
+ // to avoid operation on logger fail, mock up the logger
+ EELFLogger mockLogger = mock(EELFLogger.class);
+ private TestAbc oamStartProcessor;
+
+ @Before
+ public void setup() throws UnknownHostException, APPCException {
+ oamStartProcessor = Mockito.spy(new TestAbc(mockLogger, mockConfigHelper, mockStateHelper, mockTaskHelper, mockOperHelper));
+ Mockito.doReturn("SOME HOST NAME").when(oamStartProcessor).getHostInfo(Mockito.anyString());
+ Mockito.doReturn(mockCommonHeader).when(mockOperHelper).getCommonHeader(mockInput);
+ Mockito.doReturn(mockCommonHeader).when(mockInput).getCommonHeader();
+ Mockito.doReturn(mockLCMStateManager).when(mockOperHelper).getService(LCMStateManager.class);
+ Whitebox.setInternalState(oamStartProcessor, "commonHeader", mockCommonHeader);
+ }
+
+ @Test
+ public void testScheduleAsyncTask() throws Exception {
+ oamStartProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamStartProcessor, "runnable");
+ Whitebox.setInternalState(runnable, "isWaiting", true);
+ assertTrue(runnable != null);
+ }
+
+ @Test
+ public void testDoAction() throws Exception {
+ oamStartProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamStartProcessor, "runnable");
+ Whitebox.setInternalState(runnable, "isWaiting", true);
+ BundleHelper mockBundleHelper = mock(BundleHelper.class);
+ Mockito.doReturn(true).when(mockBundleHelper).bundleOperations(Mockito.any(RPC.class), Mockito.anyMap(), Mockito.any(AsyncTaskHelper.class), Mockito.any(BaseCommon.class));
+ Whitebox.setInternalState(oamStartProcessor, "bundleHelper", mockBundleHelper);
+ assertTrue(runnable.doAction());
+ Mockito.verify(oamStartProcessor).getInitialDelayMillis();
+ }
+
+ @Test
+ public void testCheckState() throws Exception {
+ oamStartProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamStartProcessor, "runnable");
+ assertFalse(runnable.checkState());
+ }
+}
diff --git a/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamStopProcessorTest.java b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamStopProcessorTest.java
new file mode 100644
index 0000000..562dd15
--- /dev/null
+++ b/appc-oam/appc-oam-bundle/src/test/java/org/onap/appc/oam/processor/OamStopProcessorTest.java
@@ -0,0 +1,121 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : APPC
+ * ================================================================================
+ * Copyright (C) 2018 Ericsson
+ * =============================================================================
+ * 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.onap.appc.oam.processor;
+
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertTrue;
+import static org.mockito.Mockito.mock;
+import java.net.UnknownHostException;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.Mockito;
+import org.onap.appc.exceptions.APPCException;
+import org.onap.appc.i18n.Msg;
+import org.onap.appc.oam.AppcOam;
+import org.onap.appc.oam.AppcOam.RPC;
+import org.onap.appc.oam.util.AsyncTaskHelper;
+import org.onap.appc.oam.util.BundleHelper;
+import org.onap.appc.oam.util.ConfigurationHelper;
+import org.onap.appc.oam.util.OperationHelper;
+import org.onap.appc.oam.util.StateHelper;
+import org.onap.appc.requesthandler.LCMStateManager;
+import org.opendaylight.yang.gen.v1.org.onap.appc.oam.rev170303.StopInput;
+import org.opendaylight.yang.gen.v1.org.onap.appc.oam.rev170303.common.header.CommonHeader;
+import org.powermock.reflect.Whitebox;
+import com.att.eelf.configuration.EELFLogger;
+
+public class OamStopProcessorTest {
+
+ private class TestAbc extends OamStopProcessor {
+
+ /**
+ * Constructor
+ *
+ * @param eelfLogger for logging
+ * @param configurationHelperIn for property reading
+ * @param stateHelperIn for APP-C OAM state checking
+ * @param asyncTaskHelperIn for scheduling async task
+ * @param operationHelperIn for operational helper
+ */
+ TestAbc(EELFLogger eelfLogger,
+ ConfigurationHelper configurationHelperIn,
+ StateHelper stateHelperIn,
+ AsyncTaskHelper asyncTaskHelperIn,
+ OperationHelper operationHelperIn) {
+ super(eelfLogger, configurationHelperIn, stateHelperIn, asyncTaskHelperIn, operationHelperIn);
+
+ // must set rpc and auditMsg
+ rpc = testRpc;
+ auditMsg = Msg.OAM_OPERATION_STARTING;
+ }
+ }
+
+ private ConfigurationHelper mockConfigHelper = mock(ConfigurationHelper.class);
+ private StateHelper mockStateHelper = mock(StateHelper.class);
+ private AsyncTaskHelper mockTaskHelper = mock(AsyncTaskHelper.class);
+ private OperationHelper mockOperHelper = mock(OperationHelper.class);
+ private AppcOam.RPC testRpc = AppcOam.RPC.start;
+ private StopInput mockInput = mock(StopInput.class);
+ private CommonHeader mockCommonHeader = mock(CommonHeader.class);
+ private LCMStateManager mockLCMStateManager = mock(LCMStateManager.class);
+
+ // to avoid operation on logger fail, mock up the logger
+ EELFLogger mockLogger = mock(EELFLogger.class);
+ private TestAbc oamStopProcessor;
+
+ @Before
+ public void setup() throws UnknownHostException, APPCException {
+ oamStopProcessor = Mockito.spy(new TestAbc(mockLogger, mockConfigHelper, mockStateHelper, mockTaskHelper, mockOperHelper));
+ Mockito.doReturn("SOME HOST NAME").when(oamStopProcessor).getHostInfo(Mockito.anyString());
+ Mockito.doReturn(mockCommonHeader).when(mockOperHelper).getCommonHeader(mockInput);
+ Mockito.doReturn(mockCommonHeader).when(mockInput).getCommonHeader();
+ Mockito.doReturn(mockLCMStateManager).when(mockOperHelper).getService(LCMStateManager.class);
+ Whitebox.setInternalState(oamStopProcessor, "commonHeader", mockCommonHeader);
+ }
+
+ @Test
+ public void testScheduleAsyncTask() throws Exception {
+ oamStopProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamStopProcessor, "runnable");
+ Whitebox.setInternalState(runnable, "isWaiting", true);
+ assertTrue(runnable != null);
+ }
+
+ @Test
+ public void testDoAction() throws Exception {
+ oamStopProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamStopProcessor, "runnable");
+ Whitebox.setInternalState(runnable, "isWaiting", true);
+ BundleHelper mockBundleHelper = mock(BundleHelper.class);
+ Mockito.doReturn(true).when(mockBundleHelper).bundleOperations(Mockito.any(RPC.class), Mockito.anyMap(), Mockito.any(AsyncTaskHelper.class), Mockito.any(BaseCommon.class));
+ Whitebox.setInternalState(oamStopProcessor, "bundleHelper", mockBundleHelper);
+ assertTrue(runnable.doAction());
+ Mockito.verify(oamStopProcessor).getInitialDelayMillis();
+ }
+
+ @Test
+ public void testCheckState() throws Exception {
+ oamStopProcessor.scheduleAsyncTask();
+ BaseActionRunnable runnable = Whitebox.getInternalState(oamStopProcessor, "runnable");
+ assertFalse(runnable.checkState());
+ }
+}