package com.github.dockerjava.core.command;
import static com.github.dockerjava.core.RemoteApiVersion.VERSION_1_22;
import static com.github.dockerjava.utils.TestUtils.getVersion;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.equalTo;
import static org.hamcrest.Matchers.is;
import static org.hamcrest.Matchers.isEmptyString;
import static org.hamcrest.Matchers.not;
import java.lang.reflect.Method;
import com.github.dockerjava.core.RemoteApiVersion;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.testng.ITestResult;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;
import com.github.dockerjava.api.exception.DockerException;
import com.github.dockerjava.api.exception.NotFoundException;
import com.github.dockerjava.api.command.CreateContainerResponse;
import com.github.dockerjava.api.command.InspectContainerResponse;
import com.github.dockerjava.client.AbstractDockerClientTest;
@Test(groups = "integration")
public class StopContainerCmdImplTest extends AbstractDockerClientTest {
public static final Logger LOG = LoggerFactory.getLogger(StopContainerCmdImplTest.class);
@BeforeTest
public void beforeTest() throws Exception {
super.beforeTest();
}
@AfterTest
public void afterTest() {
super.afterTest();
}
@BeforeMethod
public void beforeMethod(Method method) {
super.beforeMethod(method);
}
@AfterMethod
public void afterMethod(ITestResult result) {
super.afterMethod(result);
}
@Test(groups = "ignoreInCircleCi")
public void testStopContainer() throws DockerException {
final RemoteApiVersion apiVersion = getVersion(dockerClient);
CreateContainerResponse container = dockerClient.createContainerCmd("busybox").withCmd("sleep", "9999").exec();
LOG.info("Created container: {}", container.toString());
assertThat(container.getId(), not(isEmptyString()));
dockerClient.startContainerCmd(container.getId()).exec();
LOG.info("Stopping container: {}", container.getId());
dockerClient.stopContainerCmd(container.getId()).withTimeout(2).exec();
InspectContainerResponse inspectContainerResponse = dockerClient.inspectContainerCmd(container.getId()).exec();
LOG.info("Container Inspect: {}", inspectContainerResponse.toString());
assertThat(inspectContainerResponse.getState().getRunning(), is(equalTo(false)));
final Integer exitCode = inspectContainerResponse.getState().getExitCode();
assertThat(exitCode, is(137));
}
@Test(expectedExceptions = NotFoundException.class)
public void testStopNonExistingContainer() throws DockerException {
dockerClient.stopContainerCmd("non-existing").withTimeout(2).exec();
}
}