From b31b3ea0f6c155343b506ed90562a86758883668 Mon Sep 17 00:00:00 2001 From: slfan1989 <55643692+slfan1989@users.noreply.github.com> Date: Thu, 6 Oct 2022 22:13:33 +0800 Subject: [PATCH] YARN-11187. Remove WhiteBox in yarn module. (#4463) Signed-off-by: Akira Ajisaka --- .../launcher/TestContainersLauncher.java | 63 +++++++------------ 1 file changed, 22 insertions(+), 41 deletions(-) diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/launcher/TestContainersLauncher.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/launcher/TestContainersLauncher.java index f48d785569..d1b1650731 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/launcher/TestContainersLauncher.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/launcher/TestContainersLauncher.java @@ -18,7 +18,6 @@ package org.apache.hadoop.yarn.server.nodemanager.containermanager.launcher; import org.apache.hadoop.conf.Configuration; -import org.apache.hadoop.test.Whitebox; import org.apache.hadoop.yarn.api.records.ApplicationAttemptId; import org.apache.hadoop.yarn.api.records.ApplicationId; import org.apache.hadoop.yarn.api.records.ContainerId; @@ -40,8 +39,6 @@ import java.io.IOException; import java.util.ArrayList; -import java.util.Collections; -import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; @@ -123,10 +120,8 @@ public void setup() throws IllegalArgumentException, IllegalAccessException { @SuppressWarnings("unchecked") @Test public void testLaunchContainerEvent() - throws IllegalArgumentException, IllegalAccessException { - Map dummyMap = - (Map) Whitebox.getInternalState(spy, - "running"); + throws IllegalArgumentException { + Map dummyMap = spy.running; when(event.getType()) .thenReturn(ContainersLauncherEventType.LAUNCH_CONTAINER); assertEquals(0, dummyMap.size()); @@ -139,10 +134,8 @@ public void testLaunchContainerEvent() @SuppressWarnings("unchecked") @Test public void testRelaunchContainerEvent() - throws IllegalArgumentException, IllegalAccessException { - Map dummyMap = - (Map) Whitebox.getInternalState(spy, - "running"); + throws IllegalArgumentException { + Map dummyMap = spy.running; when(event.getType()) .thenReturn(ContainersLauncherEventType.RELAUNCH_CONTAINER); assertEquals(0, dummyMap.size()); @@ -159,10 +152,8 @@ public void testRelaunchContainerEvent() @SuppressWarnings("unchecked") @Test public void testRecoverContainerEvent() - throws IllegalArgumentException, IllegalAccessException { - Map dummyMap = - (Map) Whitebox.getInternalState(spy, - "running"); + throws IllegalArgumentException { + Map dummyMap = spy.running; when(event.getType()) .thenReturn(ContainersLauncherEventType.RECOVER_CONTAINER); assertEquals(0, dummyMap.size()); @@ -178,7 +169,7 @@ public void testRecoverContainerEvent() @Test public void testRecoverPausedContainerEvent() - throws IllegalArgumentException, IllegalAccessException { + throws IllegalArgumentException { when(event.getType()) .thenReturn(ContainersLauncherEventType.RECOVER_PAUSED_CONTAINER); spy.handle(event); @@ -189,16 +180,14 @@ public void testRecoverPausedContainerEvent() @Test public void testCleanupContainerEvent() throws IllegalArgumentException, IllegalAccessException, IOException { - Map dummyMap = Collections - .synchronizedMap(new HashMap()); - dummyMap.put(containerId, containerLaunch); - Whitebox.setInternalState(spy, "running", dummyMap); + spy.running.clear(); + spy.running.put(containerId, containerLaunch); when(event.getType()) .thenReturn(ContainersLauncherEventType.CLEANUP_CONTAINER); - assertEquals(1, dummyMap.size()); + assertEquals(1, spy.running.size()); spy.handle(event); - assertEquals(0, dummyMap.size()); + assertEquals(0, spy.running.size()); Mockito.verify(containerLauncher, Mockito.times(1)) .submit(Mockito.any(ContainerCleanup.class)); } @@ -206,10 +195,8 @@ public void testCleanupContainerEvent() @Test public void testCleanupContainerForReINITEvent() throws IllegalArgumentException, IllegalAccessException, IOException { - Map dummyMap = Collections - .synchronizedMap(new HashMap()); - dummyMap.put(containerId, containerLaunch); - Whitebox.setInternalState(spy, "running", dummyMap); + spy.running.clear(); + spy.running.put(containerId, containerLaunch); when(event.getType()) .thenReturn(ContainersLauncherEventType.CLEANUP_CONTAINER_FOR_REINIT); @@ -226,9 +213,6 @@ public void testCleanupContainerForReINITEvent() @Test public void testSignalContainerEvent() throws IllegalArgumentException, IllegalAccessException, IOException { - Map dummyMap = Collections - .synchronizedMap(new HashMap()); - dummyMap.put(containerId, containerLaunch); SignalContainersLauncherEvent dummyEvent = mock(SignalContainersLauncherEvent.class); @@ -238,7 +222,8 @@ public void testSignalContainerEvent() when(containerId.getApplicationAttemptId().getApplicationId()) .thenReturn(appId); - Whitebox.setInternalState(spy, "running", dummyMap); + spy.running.clear(); + spy.running.put(containerId, containerLaunch); when(dummyEvent.getType()) .thenReturn(ContainersLauncherEventType.SIGNAL_CONTAINER); when(dummyEvent.getCommand()) @@ -246,7 +231,7 @@ public void testSignalContainerEvent() doNothing().when(containerLaunch) .signalContainer(SignalContainerCommand.GRACEFUL_SHUTDOWN); spy.handle(dummyEvent); - assertEquals(1, dummyMap.size()); + assertEquals(1, spy.running.size()); Mockito.verify(containerLaunch, Mockito.times(1)) .signalContainer(SignalContainerCommand.GRACEFUL_SHUTDOWN); } @@ -254,30 +239,26 @@ public void testSignalContainerEvent() @Test public void testPauseContainerEvent() throws IllegalArgumentException, IllegalAccessException, IOException { - Map dummyMap = Collections - .synchronizedMap(new HashMap()); - dummyMap.put(containerId, containerLaunch); - Whitebox.setInternalState(spy, "running", dummyMap); + spy.running.clear(); + spy.running.put(containerId, containerLaunch); when(event.getType()) .thenReturn(ContainersLauncherEventType.PAUSE_CONTAINER); doNothing().when(containerLaunch).pauseContainer(); spy.handle(event); - assertEquals(1, dummyMap.size()); + assertEquals(1, spy.running.size()); Mockito.verify(containerLaunch, Mockito.times(1)).pauseContainer(); } @Test public void testResumeContainerEvent() throws IllegalArgumentException, IllegalAccessException, IOException { - Map dummyMap = Collections - .synchronizedMap(new HashMap()); - dummyMap.put(containerId, containerLaunch); - Whitebox.setInternalState(spy, "running", dummyMap); + spy.running.clear(); + spy.running.put(containerId, containerLaunch); when(event.getType()) .thenReturn(ContainersLauncherEventType.RESUME_CONTAINER); doNothing().when(containerLaunch).resumeContainer(); spy.handle(event); - assertEquals(1, dummyMap.size()); + assertEquals(1, spy.running.size()); Mockito.verify(containerLaunch, Mockito.times(1)).resumeContainer(); } }