| <?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>acceptance-tests</artifactId> |
| <groupId>org.apache.servicecomb.pack</groupId> |
| <version>${revision}</version> |
| </parent> |
| <modelVersion>4.0.0</modelVersion> |
| |
| <artifactId>acceptance-pack-cluster-spring-demo</artifactId> |
| <name>Pack:Acceptance Tests::Cluster Spring</name> |
| |
| <dependencies> |
| <dependency> |
| <groupId>org.apache.servicecomb.pack</groupId> |
| <artifactId>acceptance-test-common</artifactId> |
| <type>test-jar</type> |
| </dependency> |
| </dependencies> |
| |
| <profiles> |
| <profile> |
| <id>docker</id> |
| <activation> |
| <file> |
| <exists>/var/run/docker.sock</exists> |
| </file> |
| </activation> |
| <build> |
| <plugins> |
| <plugin> |
| <groupId>io.fabric8</groupId> |
| <artifactId>docker-maven-plugin</artifactId> |
| <configuration> |
| <showLogs>true</showLogs> |
| <images> |
| <image> |
| <name>postgres</name> |
| <alias>postgres</alias> |
| <run> |
| <env> |
| <POSTGRES_DB>saga</POSTGRES_DB> |
| <POSTGRES_USER>saga</POSTGRES_USER> |
| <POSTGRES_PASSWORD>password</POSTGRES_PASSWORD> |
| </env> |
| <wait> |
| <log>database system is ready to accept connections</log> |
| <tcp> |
| <ports> |
| <port>5432</port> |
| </ports> |
| </tcp> |
| <time>60000</time> |
| </wait> |
| <ports> |
| <port>postgres.port:5432</port> |
| </ports> |
| </run> |
| </image> |
| <image> |
| <name>alpha-server:${project.version}</name> |
| <alias>alpha-1</alias> |
| <run> |
| <env> |
| <spring.profiles.active>prd,test</spring.profiles.active> |
| <alpha.spec.names>saga-db</alpha.spec.names> |
| <alpha.server.port>8080</alpha.server.port> |
| <alpha.spec.sagaa.db.cluster.enabled>true</alpha.spec.sagaa.db.cluster.enabled> |
| <management.endpoints.web.exposure.include>*</management.endpoints.web.exposure.include> |
| <management.endpoint.shutdown.enabled>true</management.endpoint.shutdown.enabled> |
| </env> |
| <links> |
| <link>postgres:postgresql.servicecomb.io</link> |
| </links> |
| <wait> |
| <log>Started [a-zA-Z]+ in [0-9.]+ seconds</log> |
| <tcp> |
| <ports> |
| <port>8080</port> |
| <port>8090</port> |
| </ports> |
| </tcp> |
| <time>120000</time> |
| </wait> |
| <ports> |
| <port>alpha-1.port:8080</port> |
| <port>alpha-1.rest.port:8090</port> |
| </ports> |
| <dependsOn> |
| <container>postgres</container> |
| </dependsOn> |
| </run> |
| </image> |
| <image> |
| <name>alpha-server:${project.version}</name> |
| <alias>alpha-2</alias> |
| <run> |
| <env> |
| <spring.profiles.active>prd,test</spring.profiles.active> |
| <alpha.spec.names>saga-db</alpha.spec.names> |
| <alpha.server.port>8081</alpha.server.port> |
| <server.port>8091</server.port> |
| <alpha.spec.sagaa.db.cluster.enabled>true</alpha.spec.sagaa.db.cluster.enabled> |
| <management.endpoints.web.exposure.include>*</management.endpoints.web.exposure.include> |
| <management.endpoint.shutdown.enabled>true</management.endpoint.shutdown.enabled> |
| </env> |
| <links> |
| <link>postgres:postgresql.servicecomb.io</link> |
| </links> |
| <wait> |
| <log>Started [a-zA-Z]+ in [0-9.]+ seconds</log> |
| <tcp> |
| <ports> |
| <port>8081</port> |
| <port>8091</port> |
| </ports> |
| </tcp> |
| <time>120000</time> |
| </wait> |
| <ports> |
| <port>alpha-2.port:8081</port> |
| <port>alpha-2.rest.port:8091</port> |
| </ports> |
| <dependsOn> |
| <container>postgres</container> |
| </dependsOn> |
| </run> |
| </image> |
| <image> |
| <name>car:${project.version}</name> |
| <alias>car</alias> |
| <run> |
| <env> |
| <JAVA_OPTS> |
| -Dorg.jboss.byteman.debug=true -Dorg.jboss.byteman.verbose=true |
| -javaagent:/maven/saga/byteman.jar=port:9092,address:0.0.0.0,listener:true |
| </JAVA_OPTS> |
| <omega.spec.names>saga</omega.spec.names> |
| <alpha.cluster.address>alpha-server-1.servicecomb.io:8080,alpha-server-2.servicecomb.io:8081</alpha.cluster.address> |
| </env> |
| <wait> |
| <log>Started [a-zA-Z]+ in [0-9.]+ seconds</log> |
| <tcp> |
| <ports> |
| <port>8080</port> |
| <port>9092</port> |
| </ports> |
| </tcp> |
| <time>120000</time> |
| </wait> |
| <links> |
| <link>alpha-1:alpha-server-1.servicecomb.io</link> |
| <link>alpha-2:alpha-server-2.servicecomb.io</link> |
| </links> |
| <ports> |
| <port>car.port:8080</port> |
| <port>car.byteman.port:9092</port> |
| </ports> |
| <dependsOn> |
| <container>alpha-1</container> |
| <contriner>alpha-2</contriner> |
| </dependsOn> |
| </run> |
| </image> |
| <image> |
| <name>hotel:${project.version}</name> |
| <alias>hotel</alias> |
| <run> |
| <env> |
| <JAVA_OPTS> |
| -Dorg.jboss.byteman.debug=true -Dorg.jboss.byteman.verbose=true |
| -javaagent:/maven/saga/byteman.jar=port:9093,address:0.0.0.0,listener:true |
| </JAVA_OPTS> |
| <omega.spec.names>saga</omega.spec.names> |
| <alpha.cluster.address>alpha-server-1.servicecomb.io:8080,alpha-server-2.servicecomb.io:8081</alpha.cluster.address> |
| </env> |
| <wait> |
| <log>Started [a-zA-Z]+ in [0-9.]+ seconds</log> |
| <tcp> |
| <ports> |
| <port>8080</port> |
| <port>9093</port> |
| </ports> |
| </tcp> |
| <time>120000</time> |
| </wait> |
| <links> |
| <link>alpha-1:alpha-server-1.servicecomb.io</link> |
| <link>alpha-2:alpha-server-2.servicecomb.io</link> |
| </links> |
| <ports> |
| <port>hotel.port:8080</port> |
| <port>hotel.byteman.port:9093</port> |
| </ports> |
| <dependsOn> |
| <container>alpha-1</container> |
| <container>alpha-2</container> |
| </dependsOn> |
| </run> |
| </image> |
| <image> |
| <name>booking:${project.version}</name> |
| <alias>booking</alias> |
| <run> |
| <env> |
| <JAVA_OPTS> |
| -Dorg.jboss.byteman.debug=true -Dorg.jboss.byteman.verbose=true |
| -javaagent:/maven/saga/byteman.jar=port:9091,address:0.0.0.0,listener:true |
| </JAVA_OPTS> |
| <omega.spec.names>saga</omega.spec.names> |
| <alpha.cluster.address>alpha-server-1.servicecomb.io:8080,alpha-server-2.servicecomb.io:8081</alpha.cluster.address> |
| <alpha.rest.address>http://alpha-server-1.servicecomb.io:8090,http://alpha-server-2.servicecomb.io:8091</alpha.rest.address> |
| </env> |
| <wait> |
| <log>Started [a-zA-Z]+ in [0-9.]+ seconds</log> |
| <tcp> |
| <ports> |
| <port>8080</port> |
| <port>9091</port> |
| </ports> |
| </tcp> |
| <time>120000</time> |
| </wait> |
| <links> |
| <link>alpha-1:alpha-server-1.servicecomb.io</link> |
| <link>alpha-2:alpha-server-2.servicecomb.io</link> |
| <link>car:car.servicecomb.io</link> |
| <link>hotel:hotel.servicecomb.io</link> |
| </links> |
| <ports> |
| <port>booking.port:8080</port> |
| <port>booking.byteman.port:9091</port> |
| </ports> |
| <dependsOn> |
| <container>alpha-1</container> |
| <container>alpha-2</container> |
| </dependsOn> |
| </run> |
| </image> |
| </images> |
| </configuration> |
| <executions> |
| <execution> |
| <id>start</id> |
| <phase>pre-integration-test</phase> |
| <goals> |
| <goal>start</goal> |
| </goals> |
| </execution> |
| <execution> |
| <id>stop</id> |
| <phase>post-integration-test</phase> |
| <goals> |
| <goal>stop</goal> |
| </goals> |
| </execution> |
| </executions> |
| </plugin> |
| <plugin> |
| <groupId>org.codehaus.gmaven</groupId> |
| <artifactId>gmaven-plugin</artifactId> |
| <executions> |
| <execution> |
| <id>add-default-properties</id> |
| <phase>initialize</phase> |
| <goals> |
| <goal>execute</goal> |
| </goals> |
| <configuration> |
| <source> |
| project.properties.setProperty('docker.hostname', 'localhost') |
| log.info("Docker hostname is " + project.properties['docker.hostname']) |
| </source> |
| </configuration> |
| </execution> |
| </executions> |
| </plugin> |
| <plugin> |
| <groupId>org.apache.maven.plugins</groupId> |
| <artifactId>maven-failsafe-plugin</artifactId> |
| <version>${maven.failsafe.version}</version> |
| <configuration> |
| <systemPropertyVariables> |
| <alpha.cluster.address> |
| http://${docker.hostname}:${alpha-1.port} |
| </alpha.cluster.address> |
| <alpha.rest.address> |
| http://${docker.hostname}:${alpha-1.rest.port},http://${docker.hostname}:${alpha-2.rest.port} |
| </alpha.rest.address> |
| <car.service.address> |
| http://${docker.hostname}:${car.port} |
| </car.service.address> |
| <hotel.service.address> |
| http://${docker.hostname}:${hotel.port} |
| </hotel.service.address> |
| <booking.service.address> |
| http://${docker.hostname}:${booking.port} |
| </booking.service.address> |
| <spring.datasource.url> |
| jdbc:postgresql://${docker.hostname}:${postgres.port}/saga?useSSL=false |
| </spring.datasource.url> |
| <byteman.address> |
| ${docker.hostname} |
| </byteman.address> |
| <car.byteman.port> |
| ${car.byteman.port} |
| </car.byteman.port> |
| <hotel.byteman.port> |
| ${hotel.byteman.port} |
| </hotel.byteman.port> |
| <booking.byteman.port> |
| ${booking.byteman.port} |
| </booking.byteman.port> |
| <info.service.uri> |
| ${info.service.uri} |
| </info.service.uri> |
| </systemPropertyVariables> |
| <argLine>${jacoco.failsafe.argLine}</argLine> |
| </configuration> |
| <executions> |
| <execution> |
| <goals> |
| <goal>integration-test</goal> |
| <goal>verify</goal> |
| </goals> |
| </execution> |
| </executions> |
| </plugin> |
| <plugin> |
| <groupId>com.ethlo.persistence.tools</groupId> |
| <artifactId>eclipselink-maven-plugin</artifactId> |
| </plugin> |
| </plugins> |
| </build> |
| </profile> |
| <profile> |
| <id>docker-machine</id> |
| <build> |
| <plugins> |
| <plugin> |
| <groupId>org.codehaus.gmaven</groupId> |
| <artifactId>gmaven-plugin</artifactId> |
| <executions> |
| <execution> |
| <id>add-dynamic-properties</id> |
| <phase>prepare-package</phase> |
| <goals> |
| <goal>execute</goal> |
| </goals> |
| <configuration> |
| <source> |
| def process = "docker-machine ip default".execute() |
| process.waitFor() |
| project.properties.setProperty('docker.hostname', process.in.text.trim()) |
| |
| log.info("Docker hostname is " + project.properties['docker.hostname']) |
| </source> |
| </configuration> |
| </execution> |
| </executions> |
| </plugin> |
| </plugins> |
| </build> |
| </profile> |
| </profiles> |
| |
| </project> |