== Basic Example After having a _Docker_ server installed we can start using *Arquillian Cube*. In this case we are going to use a very simple example using a _Docker_ image with _Apache Tomcat_ and we are going to test a _Servlet_ on it. [source, java] .HelloWorldServlet.java ---- @WebServlet("/HelloWorld") public class HelloWorldServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { PrintWriter writer = resp.getWriter(); writer.println("Hello World"); } } ---- [source, java] .HelloWorldServletTest.java ---- @RunWith(Arquillian.class) public class HelloWorldServletTest { @Deployment(testable=false) //<1> public static WebArchive create() { return ShrinkWrap.create(WebArchive.class, "hello.war").addClass(HelloWorldServlet.class); //<2> } @Test public void should_parse_and_load_configuration_file(@ArquillianResource URL resource) throws IOException { //<3> URL obj = new URL(resource, "HelloWorld"); HttpURLConnection con = (HttpURLConnection) obj.openConnection(); con.setRequestMethod("GET"); BufferedReader in = new BufferedReader( new InputStreamReader(con.getInputStream())); String inputLine; StringBuffer response = new StringBuffer(); while ((inputLine = in.readLine()) != null) { response.append(inputLine); } in.close(); assertThat(response.toString(), is("Hello World"));//<4> } } ---- <1> In this case we are running the test as a client. So in fact this test is executed against the container instead of inside the container. <2> No changes in this part, we need to create a deployable file, and because we are testing against _Tomcat_, a _war_ file is created. <3> Because the test is run as client, we can use +@ArquillianResource+ to get the URL where the file is deployed. Note that this will be the URL to access _Tomcat_ running inside the _Docker_ container. <4> Typical jUnit assertion of servlet response. Now this test could be run in any container, there is nothing that ties this to _Docker_. Next step is adding some dependencies apart from the typical _Arquillian_ dependencies. [source, xml] .pom.xml ---- org.arquillian.cube arquillian-cube-docker ${project.version} test org.jboss.arquillian.container arquillian-tomcat-remote-7 1.0.0.CR7 test ---- <1> Adds *Arquillian Cube* dependency. <2> From the point of view of _Arquillian_, _Tomcat_ is being executed in a remote host (in fact this is true because _Tomcat_ is running inside _Docker_ which is external to _Arquillian_), so we need to add the remote adapter. And finally we need to configure _Tomcat_ remote adapter and *Arquillian Cube* in +arquillian.xml+ file. [source, xml] .arquillian.xml ---- 1.12 http://localhost:2375 CUBE tomcat: image: tutum/tomcat:7.0 exposedPorts: [8089/tcp] await: strategy: polling env: [TOMCAT_PASS=mypass, JAVA_OPTS=-Dcom.sun.management.jmxremote.port=8089 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false] portBindings: [8089/tcp, 8080/tcp] localhost 8080 admin mypass ---- <1> *Arquillian Cube* extension is registered. <2> _Docker_ server version is required. <3> _Docker_ server URI is required. In case you are using a remote _Docker_ host or _Boot2Docker_ here you need to set the remote host ip, but in this case _Docker_ server is on same machine. <4> A _Docker_ container contains a lot of parameters that can be configured. To avoid having to create one XML property for each one, a YAML content can be embedded directly as property. <5> Configuration of _Tomcat_ remote adapter. Cube will start the _Docker_ container when it is ran in the same context as an _Arquillian_ container with the same name. <6> Host can be _localhost_ because there is a port forwarding between container and _Docker_ server. <7> Port is exposed as well. <8> User and password are required to deploy the war file to remote _Tomcat_. Notice that in this case you are using _CUBE_ format as orchestration definition but you'll see in next sections that you can use *docker_compose* too. Read more at <> section and <>. And that's all. Now you can run your test and you will see how _tutum/tomcat:7.0_ image is downloaded and started. Ports 8080 (Tomcat standard port) and 8089(JMX port used by Arquillian) are exposed. Finally in _env_ section, environment variables are set. Read next link to understand why this is required https://docs.jboss.org/author/display/ARQ/Tomcat+7.0+-+Remote == Standalone Example In previous example you have seen how to to start a Docker container, deploy an _Shrinkwrap_ element using `@Deployment` to finally execute the test inside Docker container, get the results and stops everything. But this is not the only way of using Arquillian Cube. Sometimes you already have your container image created and you want to test that it starts, that exposes correctly the ports and of course that for example the deployment file is in the correct place. This is known as *Container tests*. Notice that in this case you don't need `@Deployment` method since the image is already created and you don't want to modify anything. The only thin g that you want is start the container, run the test (as client) and if everything works, then just stop the container. Let's see how to do it: First major change is in dependencies: [source, xml] .pom.xml ---- org.arquillian.cube arquillian-cube-docker test org.jboss.arquillian.junit arquillian-junit-standalone test ---- <1> Instead of setting a container, you set arquillian in standalone mode Than you can define in your `arquillian.xml` or `docker-compose.xml` containers. For example: [source, yml] .docker-compose.yml ---- planetstest: extends: file: ../docker-compose.yml service: planets image: lordofthejars/starwars:1.0.1 #1 ---- <1>Image with WAR file already bundled inside server And finally the test: [source, java] .PlanetServiceAPIContainerTest.java ---- @RunWith(Arquillian.class) public class PlanetServiceAPIContainerTest { @HostIp private String ip; @HostPort(containerName = "planetstest", value = 8080) int planetsPort; @Test public void shouldReturnAverage() { URL url = new URL("http://" + ip + ":" + planetsPort + "/starwars/"); final String average = RestAssured.get(url.toExternalForm() + "rest/planet/orbital/average").asString(); assertThat(average, is("1699.42")); } ---- Notice that in this case there is no `@Deployment` method because the full application is already bundled in the docker image that is being used. This test basically validates that the image can be started, and finally that from outside you can communicate with it and it returns something valid.