| <?xml version="1.0" encoding="UTF-8"?> |
| <!-- |
| ~ Licensed to the Apache Software Foundation (ASF) under one or more |
| ~ contributor license agreements. See the NOTICE file distributed with |
| ~ this work for additional information regarding copyright ownership. |
| ~ The ASF licenses this file to You 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. |
| ~ |
| --> |
| |
| |
| <project xmlns="http://maven.apache.org/POM/4.0.0" |
| xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
| xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> |
| <parent> |
| <artifactId>e2e-cluster-with-gateway</artifactId> |
| <groupId>org.apache.skywalking</groupId> |
| <version>1.0.0</version> |
| </parent> |
| <modelVersion>4.0.0</modelVersion> |
| |
| <artifactId>e2e-cluster-with-gateway-test-runner</artifactId> |
| |
| <dependencies> |
| |
| <dependency> |
| <groupId>org.apache.skywalking</groupId> |
| <artifactId>e2e-base</artifactId> |
| <version>${project.version}</version> |
| </dependency> |
| |
| <dependency> |
| <groupId>org.apache.skywalking</groupId> |
| <artifactId>e2e-cluster-with-gateway-gateway</artifactId> |
| <version>${project.version}</version> |
| </dependency> |
| |
| <dependency> |
| <groupId>org.apache.skywalking</groupId> |
| <artifactId>e2e-cluster-with-gateway-provider</artifactId> |
| <version>${project.version}</version> |
| </dependency> |
| |
| <dependency> |
| <groupId>org.apache.skywalking</groupId> |
| <artifactId>e2e-cluster-with-gateway-consumer</artifactId> |
| <version>${project.version}</version> |
| </dependency> |
| |
| </dependencies> |
| |
| <properties> |
| <provider.name>e2e-cluster-with-gateway-provider</provider.name> |
| <consumer.name>e2e-cluster-with-gateway-consumer</consumer.name> |
| <gateway.name>e2e-cluster-with-gateway-gateway</gateway.name> |
| <e2e.container.version>1.1</e2e.container.version> |
| <e2e.container.name.prefix>skywalking-e2e-container-${build.id}-cluster-with-gateway</e2e.container.name.prefix> |
| </properties> |
| |
| <build> |
| <plugins> |
| <plugin> |
| <groupId>io.fabric8</groupId> |
| <artifactId>docker-maven-plugin</artifactId> |
| <configuration> |
| <containerNamePattern>%a-%t-%i</containerNamePattern> |
| <imagePullPolicy>Always</imagePullPolicy> |
| <images> |
| <image> |
| <name>elastic/elasticsearch:${elasticsearch.version}</name> |
| <alias>${e2e.container.name.prefix}-elasticsearch</alias> |
| <run> |
| <ports> |
| <port>es.port:9200</port> |
| </ports> |
| <wait> |
| <http> |
| <url>http://localhost:${es.port}</url> |
| <method>GET</method> |
| <status>200</status> |
| </http> |
| <time>120000</time> |
| </wait> |
| <env> |
| <discovery.type>single-node</discovery.type> |
| </env> |
| </run> |
| </image> |
| <image> |
| <name>zookeeper:${zookeeper.image.version}</name> |
| <alias>${e2e.container.name.prefix}-zookeeper</alias> |
| <run> |
| <ports> |
| <port>zk.port:2181</port> |
| </ports> |
| <wait> |
| <log>binding to port</log> |
| <time>120000</time> |
| </wait> |
| </run> |
| </image> |
| <image> |
| <name>skyapm/e2e-container:${e2e.container.version}</name> |
| <alias>${e2e.container.name.prefix}</alias> |
| <run> |
| <env> |
| <MODE>cluster</MODE> |
| <ES_VERSION>${elasticsearch.version}</ES_VERSION> |
| <SW_STORAGE_ES_CLUSTER_NODES> |
| ${e2e.container.name.prefix}-elasticsearch:9200 |
| </SW_STORAGE_ES_CLUSTER_NODES> |
| <SW_CLUSTER_ZK_HOST_PORT> |
| ${e2e.container.name.prefix}-zookeeper:2181 |
| </SW_CLUSTER_ZK_HOST_PORT> |
| |
| <INSTRUMENTED_SERVICE_1> |
| ${provider.name}-${project.version}.jar |
| </INSTRUMENTED_SERVICE_1> |
| <INSTRUMENTED_SERVICE_1_OPTS> |
| -DSW_AGENT_COLLECTOR_BACKEND_SERVICES=127.0.0.1:11800 |
| -DSW_AGENT_NAME=${provider.name} |
| -Dserver.port=9090 |
| </INSTRUMENTED_SERVICE_1_OPTS> |
| |
| <INSTRUMENTED_SERVICE_2> |
| ${provider.name}-${project.version}.jar |
| </INSTRUMENTED_SERVICE_2> |
| <INSTRUMENTED_SERVICE_2_OPTS> |
| -DSW_AGENT_COLLECTOR_BACKEND_SERVICES=127.0.0.1:11801 |
| -DSW_AGENT_NAME=${provider.name} |
| -Dserver.port=9091 |
| </INSTRUMENTED_SERVICE_2_OPTS> |
| |
| <INSTRUMENTED_SERVICE_3> |
| ${consumer.name}-${project.version}.jar |
| </INSTRUMENTED_SERVICE_3> |
| <INSTRUMENTED_SERVICE_3_OPTS> |
| -DSW_AGENT_COLLECTOR_BACKEND_SERVICES=127.0.0.1:11801 |
| -DSW_AGENT_NAME=${consumer.name} |
| -Dserver.port=9092 |
| </INSTRUMENTED_SERVICE_3_OPTS> |
| </env> |
| <dependsOn> |
| <container>${e2e.container.name.prefix}-elasticsearch</container> |
| <container>${e2e.container.name.prefix}-zookeeper</container> |
| </dependsOn> |
| <ports> |
| <port>+webapp.host:webapp.port:8081</port> |
| <port>+service.host:service.port:9092</port> |
| </ports> |
| <links> |
| <link>${e2e.container.name.prefix}-elasticsearch</link> |
| <link>${e2e.container.name.prefix}-zookeeper</link> |
| </links> |
| <volumes> |
| <bind> |
| <volume>${sw.home}:/sw</volume> |
| <volume> |
| ../${gateway.name}/target/${gateway.name}-${project.version}.jar:/home/${gateway.name}-${project.version}.jar |
| </volume> |
| <volume> |
| ../${provider.name}/target/${provider.name}-${project.version}.jar:/home/${provider.name}-${project.version}.jar |
| </volume> |
| <volume> |
| ../${consumer.name}/target/${consumer.name}-${project.version}.jar:/home/${consumer.name}-${project.version}.jar |
| </volume> |
| <volume> |
| ${project.basedir}/src/docker/rc.d:/rc.d:ro |
| </volume> |
| <volume> |
| ${project.basedir}/src/docker/clusterize.awk:/clusterize.awk |
| </volume> |
| </bind> |
| </volumes> |
| <wait> |
| <log>SkyWalking e2e container is ready for tests</log> |
| <time>3000000</time> |
| </wait> |
| </run> |
| </image> |
| </images> |
| </configuration> |
| </plugin> |
| |
| <!-- set the system properties that can be used in test codes --> |
| <plugin> |
| <groupId>org.apache.maven.plugins</groupId> |
| <artifactId>maven-failsafe-plugin</artifactId> |
| <configuration> |
| <systemPropertyVariables> |
| <sw.webapp.host>${webapp.host}</sw.webapp.host> |
| <sw.webapp.port>${webapp.port}</sw.webapp.port> |
| <service.host>${service.host}</service.host> |
| <service.port>${service.port}</service.port> |
| <provider.name>${provider.name}</provider.name> |
| <consumer.name>${consumer.name}</consumer.name> |
| <gateway.name>127.0.0.1:9099</gateway.name> |
| </systemPropertyVariables> |
| </configuration> |
| <executions> |
| <execution> |
| <goals> |
| <goal>verify</goal> |
| </goals> |
| </execution> |
| </executions> |
| </plugin> |
| </plugins> |
| </build> |
| |
| </project> |