From e97a484e53494aff52a8266bd82ab81c5f478c3f Mon Sep 17 00:00:00 2001 From: Manuel Finelli Date: Tue, 10 Dec 2024 18:55:16 +0000 Subject: [PATCH] [WFLY-19337] The GitHub Action to test ejb-txn-remote-call is now working --- .../kubernetes/core/overridable-functions.sh | 124 +++++++++- .../core/run-quickstart-test-on-kubernetes.sh | 68 +----- .../overridable-functions.sh | 231 ++++++++++++++++-- ejb-txn-remote-call/README-source.adoc | 11 +- ejb-txn-remote-call/client/client-cr.yaml | 6 +- ejb-txn-remote-call/client/pom.xml | 121 +++------ .../client/scripts/cli.local.properties | 2 + .../client/scripts/cli.openshift.properties | 6 +- .../client/scripts/remoting-configuration.cli | 59 +++-- .../application-roles.properties | 0 .../application-users.properties | 0 ejb-txn-remote-call/server/pom.xml | 88 +++---- ejb-txn-remote-call/server/server-cr.yaml | 6 +- 13 files changed, 448 insertions(+), 274 deletions(-) rename ejb-txn-remote-call/server/{ => extra-content/standalone}/configuration/application-roles.properties (100%) rename ejb-txn-remote-call/server/{ => extra-content/standalone}/configuration/application-users.properties (100%) diff --git a/.github/workflows/scripts/kubernetes/core/overridable-functions.sh b/.github/workflows/scripts/kubernetes/core/overridable-functions.sh index 21544287da..fc3e021799 100644 --- a/.github/workflows/scripts/kubernetes/core/overridable-functions.sh +++ b/.github/workflows/scripts/kubernetes/core/overridable-functions.sh @@ -9,6 +9,7 @@ # # Parameters # 1 - the name of the qs directory (not the full path) +# function applicationName() { echo "${1}" } @@ -20,6 +21,7 @@ function applicationName() { # # Parameters # 1 - the name of the qs directory +# function namespace() { application="${1}" # Uncomment to make the tests run in the 'testing' namespace @@ -32,6 +34,7 @@ function namespace() { # # Parameters # 1 - application name +# function installPrerequisites() { application="${1}" @@ -43,12 +46,35 @@ function installPrerequisites() # # Parameters # 1 - application name +# function cleanPrerequisites() { application="${1}" echo "No prerequisites to clean for ${application}" } +# Provision server and push imagestream +# The current directory is the quickstart directory +# +# Parameters +# 1 - application name +# 2 - quickstart dir +# +function provisionServer() +{ + application="${1}" + qs_dir="${2}" + + echo "Building application and provisioning server image..." + mvn -B package -Popenshift wildfly:image -DskipTests + + echo "Tagging image and pushing to registry..." + export root_image_name="localhost:5000/${application}" + export image="${root_image_name}:latest" + docker tag ${qs_dir} ${image} + docker push ${image} +} + # Performs the 'helm install' command. # The current directory is the quickstart directory # Parameters @@ -61,15 +87,33 @@ function cleanPrerequisites() # * helm_install_timeout - the adjusted timeout for the helm install # function helmInstall() { - application="${1}" - helm_set_arguments="$2" - - # '--wait' waits until the pods are ready - # `--timeout` sets the timeout for the wait. - # https://helm.sh/docs/helm/helm_install/ has more details - # Don't quote ${helm_set_arguments} since then it fails when there are none - helm install "${application}" wildfly/wildfly -f charts/helm.yaml --wait --timeout=${helm_install_timeout} ${helm_set_arguments} - echo "$?" + application="${1}" + helm_set_arg_prefix="${2}" + helm_install_timeout="${3}" + + # Helm install, waiting for the pods to come up + helm_set_arguments=" --set ${helm_set_arg_prefix}build.enabled=false --set ${helm_set_arg_prefix}deploy.route.enabled=false --set ${helm_set_arg_prefix}image.name=${root_image_name}" + + additional_arguments="No additional arguments" + if [ -n "${helm_set_arguments}" ]; then + additional_arguments="Additional arguments: ${helm_set_arguments}" + fi + + echo "Performing Helm install and waiting for completion.... (${additional_arguments})" + + # '--wait' waits until the pods are ready + # `--timeout` sets the timeout for the wait. + # https://helm.sh/docs/helm/helm_install/ has more details + # Don't quote ${helm_set_arguments} since then it fails when there are none + helm install "${application}" wildfly/wildfly -f charts/helm.yaml --wait --timeout=${helm_install_timeout} ${helm_set_arguments} + + echo "ret: $?" + if [ "$?" != "0" ]; then + echo "Helm install failed!" + echo "Dumping the application pod(s)" + kubectl logs deployment/"${application}" + helmInstallFailed + fi } # Commands to run once the Helm install has completed @@ -106,10 +150,70 @@ function helmInstallFailed() { echo "" } +# Port forward to test the quickstart +# Parameters +# 1 - application name +# +function portForward() { + application="${1}" + + kubectl port-forward service/${application} 8080:8080 & + kubectl_fwd_pid=$! + echo "${kubectl_fwd_pid}" +} + +# Running tests of the quickstart +# Parameters +# 1 - application name +# 2 - server protocol +# 3 - extra maven argument for the verify target +# +function runningTests() { + application="${1}" + server_protocol="${2}" + extraMvnVerifyArguments="${3}" + + route="localhost:8080" + + mvnVerifyArguments="-Dserver.host=${server_protocol}://${route} " + if [ -n "${extraMvnVerifyArguments}" ]; then + mvnVerifyArguments="${mvnVerifyArguments} ${extraMvnVerifyArguments}" + fi + if [ "${QS_DEBUG_TESTS}" = "1" ]; then + mvnVerifyArguments="${mvnVerifyArguments} -Dmaven.failsafe.debug=true" + fi + + echo "Verify Arguments: ${mvnVerifyArguments}" + + mvn -B verify -Pintegration-testing ${mvnVerifyArguments} + + test_status="$?" + + if [ "$?" != "0" ]; then + test_status=1 + echo "Tests failed!" + echo "Dumping the application pod(s)" + kubectl logs deployment/"${application}" + testsFailed + fi + + echo "${test_status}" +} + +# Performs the 'helm uninstall' command. +# Parameters +# 1 - application name +# +function helmUninstall() { + application="${1}" + + helm uninstall "${application}" --wait --timeout=10m0s +} + # More output when the tests have failed # Parameters # 1 - application name # function testsFailed() { echo "" -} \ No newline at end of file +} diff --git a/.github/workflows/scripts/kubernetes/core/run-quickstart-test-on-kubernetes.sh b/.github/workflows/scripts/kubernetes/core/run-quickstart-test-on-kubernetes.sh index 1c6baa2acb..6515f5d5f3 100755 --- a/.github/workflows/scripts/kubernetes/core/run-quickstart-test-on-kubernetes.sh +++ b/.github/workflows/scripts/kubernetes/core/run-quickstart-test-on-kubernetes.sh @@ -76,49 +76,23 @@ fi ################################################################################################ # Install any pre-requisites. Function is from overridable-functions.sh + echo "Checking if we need to install pre-requisites" installPrerequisites "${application}" ################################################################################################ # Provision server and push imagestream -echo "Building application and provisioning server image..." -mvn -B package -Popenshift wildfly:image -DskipTests - -echo "Tagging image and pushing to registry..." -export root_image_name="localhost:5000/${application}" -export image="${root_image_name}:latest" -docker tag ${qs_dir} ${image} -docker push ${image} +provisionServer "${application}" "${qs_dir}" ################################################################################################ -# Helm install, waiting for the pods to come up -helm_set_arguments=" --set ${helm_set_arg_prefix}build.enabled=false --set ${helm_set_arg_prefix}deploy.route.enabled=false --set ${helm_set_arg_prefix}image.name=${root_image_name}" - -additional_arguments="No additional arguments" -if [ -n "${helm_set_arguments}" ]; then - additional_arguments="Additional arguments: ${helm_set_arguments}" -fi -echo "Performing Helm install and waiting for completion.... (${additional_arguments})" # helmInstall is from overridable-functions.sh -helm_install_ret=$(helmInstall "${application}" "${helm_set_arguments}") - -# For some reason the above sometimes becomes a multi-line string. actual The exit code will be -# on the last line -helm_install_ret=$(echo "${helm_install_ret}"| tail -n 1) - -echo "ret: ${helm_install_ret}" -if [ "${helm_install_ret}" != "0" ]; then - echo "Helm install failed!" - echo "Dumping the application pod(s)" - kubectl logs deployment/"${application}" - helmInstallFailed -fi +helmInstall "${application}" "${helm_set_arg_prefix}" "${helm_install_timeout}" -kubectl port-forward service/${application} 8080:8080 & -kubectl_fwd_pid=$! -echo "Process ID of kubect port-forward: ${kubectl_fwd_pid}" +echo "Performing Port Forward and waiting for completion...." +kubectl_fwd_pids=$(portForward "${application}") +echo "Process ID(s) of kubect port-forward: ${kubectl_fwd_pids}" ################################################################################################ # Run any post install @@ -130,35 +104,15 @@ runPostHelmInstallCommands echo "running the tests" pwd -route="localhost:8080" - -mvnVerifyArguments="-Dserver.host=${server_protocol}://${route} " -extraMvnVerifyArguments="$(getMvnVerifyExtraArguments)" -if [ -n "${extraMvnVerifyArguments}" ]; then - mvnVerifyArguments="${mvnVerifyArguments} ${extraMvnVerifyArguments}" -fi -if [ "${QS_DEBUG_TESTS}" = "1" ]; then - mvnVerifyArguments="${mvnVerifyArguments} -Dmaven.failsafe.debug=true" -fi - -echo "Verify Arguments: ${mvnVerifyArguments}" - -mvn -B verify -Pintegration-testing ${mvnVerifyArguments} - -if [ "$?" != "0" ]; then - test_status=1 - echo "Tests failed!" - echo "Dumping the application pod(s)" - kubectl logs deployment/"${application}" - testsFailed -fi +runningTests "${application}" "${server_protocol}" "$(getMvnVerifyExtraArguments)" +test_status=$? -kill -9 ${kubectl_fwd_pid} +kill -9 ${kubectl_fwd_pids} ################################################################################################ # Helm uninstall echo "Running Helm uninstall" -helm uninstall "${application}" --wait --timeout=10m0s +helmUninstall "${application}" ################################################################################################ # Clean pre-requisites (cleanPrerequisites is fromm overridable-functions.sh) @@ -187,4 +141,4 @@ end=$SECONDS duration=$((end - start)) echo "${application} tests run in $(($duration / 60))m$(($duration % 60))s." -exit ${test_status} \ No newline at end of file +exit ${test_status} diff --git a/.github/workflows/scripts/kubernetes/qs-overrides/ejb-txn-remote-call/overridable-functions.sh b/.github/workflows/scripts/kubernetes/qs-overrides/ejb-txn-remote-call/overridable-functions.sh index 0e93b5dc24..9d81fed485 100644 --- a/.github/workflows/scripts/kubernetes/qs-overrides/ejb-txn-remote-call/overridable-functions.sh +++ b/.github/workflows/scripts/kubernetes/qs-overrides/ejb-txn-remote-call/overridable-functions.sh @@ -68,32 +68,221 @@ function installPrerequisites() cd $CURRENT_FOLDER || return } +function provisionServer() { + application="${1}" + + echo "Packaging the 'client' provisioned server..." + cd client || return 1 + mvn -B -fae clean package -Popenshift,provisioned-server wildfly:image -DskipTests -DpostgresqlUsername="test" -DpostgresqlPassword="test" + + export client_image_name="${application}-client" + export client_image_location="localhost:5000/${client_image_name}" + export image="${client_image_location}:latest" + + echo "Building and tagging the 'client' image..." + docker build --load -t ${image} ./target + echo "...and pushing to registry." + docker push ${image} + + cd ../server || return 1 + echo "Packaging the 'server' provisioned server..." + mvn -B -fae clean package wildfly:image -DskipTests -DpostgresqlUsername="test" -DpostgresqlPassword="test" + + export server_image_name="${application}-server" + export server_image_location="localhost:5000/${server_image_name}" + export image="${server_image_location}:latest" + + echo "Building and tagging 'server' image..." + docker build --load -t ${image} ./target + echo "...and pushing to registry." + docker push ${image} + + # Let's go back to the root of the quickstart + cd .. +} + function helmInstall() { - helm_set_arguments="$2" - - # TODO https://issues.redhat.com/browse/WFLY-18574 remove this when persistence is working - # This seems to work with my postgresql.yaml :fingers_crossed - # helm_set_arguments="${helm_set_arguments} --set postgresql.primary.persistence.enabled=false" - - # Don't quote ${helm_set_arguments} as it breaks the command when empty, and seems to work without - helm install client -f charts/client.yaml wildfly/wildfly --wait --timeout="${helm_install_timeout}" ${helm_set_arguments} - echo "$?" - # TODO: should we check when the build is done? - helm install server -f charts/server.yaml wildfly/wildfly --wait --timeout="${helm_install_timeout}" ${helm_set_arguments} - echo "$?" - # TODO: should we check when the build is done? + echo "helmInstall() nothing to do" + #helm_set_arguments="$2" + + # TODO https://issues.redhat.com/browse/WFLY-18574 remove this when persistence is working + # This seems to work with my postgresql.yaml :fingers_crossed + # helm_set_arguments="${helm_set_arguments} --set postgresql.primary.persistence.enabled=false" + + # Don't quote ${helm_set_arguments} as it breaks the command when empty, and seems to work without + #helm install client -f charts/client.yaml wildfly/wildfly --wait --timeout="${helm_install_timeout}" ${helm_set_arguments} + #echo "$?" + # TODO: should we check when the build is done? + #helm install server -f charts/server.yaml wildfly/wildfly --wait --timeout="${helm_install_timeout}" ${helm_set_arguments} + #echo "$?" + # TODO: should we check when the build is done? + + # Make sure that view permissions are granted to the default system account. + # kubectl policy add-role-to-user view system:serviceaccount:$(oc project -q):default -n $(oc project -q) + + seconds=60 + + kubectl create -f client/client-cr.yaml + + now=$(date +%s) + end=$(($seconds + $now)) + + echo "Waiting for 1 minutes that the 'ejb-txn-remote-call-client' pod is in 'Running' status." + + while [ $now -lt $end ]; do + sleep 5 + + if [[ $(kubectl get pods --field-selector=status.phase==Running -l app.kubernetes.io/name=ejb-txn-remote-call-client | awk '{ if ($3 == "Running" && $2 == "1/1") { print } }') ]]; then + break + fi + + now=$(date +%s) + done + + kubectl create -f server/server-cr.yaml + + now=$(date +%s) + end=$(($seconds + $now)) + + echo "Waiting for 1 minutes that the 'ejb-txn-remote-call-server' pods are in 'Running' status." + + while [ $now -lt $end ]; do + sleep 5 + + if [[ $(kubectl get pods --field-selector=status.phase==Running -l app.kubernetes.io/name=ejb-txn-remote-call-server | awk '{ if ($3 == "Running" && $2 == "1/1") { print } }') ]]; then + break + fi + + now=$(date +%s) + done } -# Commands to run once the Helm install has completed -function runPostHelmInstallCommands() { +# Port forward to test the quickstart +# Parameters +# 1 - application name +# +function portForward() { + + seconds=60 - # Make sure that view permissions are granted to the default system account. - # kubectl policy add-role-to-user view system:serviceaccount:$(oc project -q):default -n $(oc project -q) + # Start the first port-forward process for the client + nohup kubectl port-forward service/${application}-client-headless 8080:8080 > /dev/null 2>&1 & + kubectl_fwd_pid_client=$! - kubectl create -f client/client-cr.yaml - # TODO: should we check when the deployment is completed? - kubectl create -f server/server-cr.yaml - # TODO: should we check when the deployment is completed? + now=$(date +%s) + end=$(($seconds + $now)) + localhost="localhost" + port="8080" + endpoint="/client/remote-outbound-stateless" + + while [ $now -lt $end ]; do + sleep 5 + + if [[ $(curl --silent --write-out "%{http_code}" --output /dev/null "http://${localhost}:${port}${endpoint}") -eq 200 ]]; then + break + fi + + now=$(date +%s) + done + + # Start the second port-forward process for the server + nohup kubectl port-forward service/${application}-server-headless 8180:8080 > /dev/null 2>&1 & + kubectl_fwd_pid_server=$! + + now=$(date +%s) + end=$(($seconds + $now)) + localhost="localhost" + port="8180" + endpoint="/server/commits" + + while [ $now -lt $end ]; do + sleep 5 + + if [[ $(curl --silent --write-out "%{http_code}" --output /dev/null "http://${localhost}:${port}${endpoint}") -eq 200 ]]; then + break + fi + + now=$(date +%s) + done + + echo "${kubectl_fwd_pid_client} ${kubectl_fwd_pid_server}" +} + +# Running tests of the quickstart +# Parameters +# 1 - server protocol +# 2 - extra maven argument for the verify target +# +function runningTests() { + application="${1}" + server_protocol="${2}" + extraMvnVerifyArguments="${3}" + + cd client || return 1 + route="localhost:8080" + + mvnVerifyArguments="-Dserver.host=${server_protocol}://${route} " + if [ -n "${extraMvnVerifyArguments}" ]; then + mvnVerifyArguments="${mvnVerifyArguments} ${extraMvnVerifyArguments}" + fi + if [ "${QS_DEBUG_TESTS}" = "1" ]; then + mvnVerifyArguments="${mvnVerifyArguments} -Dmaven.failsafe.debug=true" + fi + + echo "Verify Arguments: ${mvnVerifyArguments}" + + mvn -B verify -Pintegration-testing ${mvnVerifyArguments} + + client_test_status="$?" + + if [ "$?" != "0" ]; then + client_test_status=1 + echo "Tests failed!" + echo "Dumping the application pod" + kubectl logs deployment/"${application}-client-0" + testsFailed + fi + + cd ../server || return 1 + route="localhost:8180" + + mvnVerifyArguments="-Dserver.host=${server_protocol}://${route} " + if [ -n "${extraMvnVerifyArguments}" ]; then + mvnVerifyArguments="${mvnVerifyArguments} ${extraMvnVerifyArguments}" + fi + if [ "${QS_DEBUG_TESTS}" = "1" ]; then + mvnVerifyArguments="${mvnVerifyArguments} -Dmaven.failsafe.debug=true" + fi + + echo "Verify Arguments: ${mvnVerifyArguments}" + + mvn -B verify -Pintegration-testing ${mvnVerifyArguments} + + server_test_status="$?" + + if [ "$?" != "0" ]; then + server_test_status=1 + echo "Tests failed!" + echo "Dumping the application pods" + kubectl logs deployment/"${application}-server-0" + kubectl logs deployment/"${application}-server-1" + testsFailed + fi + + if (( client_test_status == 1 || server_test_status == 1 )); then + result=1 + else + result=0 + fi + + return "${result}" +} + +# Performs the 'helm uninstall' command. +# Parameters +# 1 - application name +function helmUninstall() { + echo "helmUninstall() nothing to do" } # Cleans any prerequisites after doing the Helm uninstall. diff --git a/ejb-txn-remote-call/README-source.adoc b/ejb-txn-remote-call/README-source.adoc index 6f6e3c0caf..eb9fc2b53b 100644 --- a/ejb-txn-remote-call/README-source.adoc +++ b/ejb-txn-remote-call/README-source.adoc @@ -63,6 +63,7 @@ include::../shared-doc/system-requirements.adoc[leveloffset=+1] The EJB remote call propagates transaction from `client` application to `server` application. The remote call hits one of the two servers where the `server` application is deployed. +[[_running_in_a_bare_metal_environment]] == Running in a bare metal environment First of all, an environment variable should be defined to point to this quickstart's root folder. @@ -239,13 +240,15 @@ will be executed on `server1`. [source,sh,subs="+quotes,attributes+",options="nowrap"] ---- cd ${jbossHomeName}_1; \ -./bin/jboss-cli.sh -DremoteServerUsername='quickstartUser' -DremoteServerPassword='quickstartPwd1!' \ +./bin/jboss-cli.sh --connect -DremoteServerUsername='quickstartUser' -DremoteServerPassword='quickstartPwd1!' \ --file=${PATH_TO_QUICKSTART_DIR}/client/scripts/remoting-configuration.cli \ --properties=${PATH_TO_QUICKSTART_DIR}/client/scripts/cli.local.properties ---- NOTE: For Windows, use the `bin\jboss-cli.bat` script. +After executing the CLI script, stop `server1` by pressing the keys `CRTL+C` in the terminal where it is running. + Running `remoting-configuration.cli` results in the creation of: * A `remote outbound socket` that points to the port on `server2`/`server3` where EJB remoting endpoints can be reached @@ -293,7 +296,7 @@ the `client` and `server` application can be deployed [source,sh,subs="+quotes,attributes+",options="nowrap"] ---- cd ${PATH_TO_QUICKSTART_DIR}/ -mvn clean package +mvn clean package -P '!provisioned-server' ---- + . Then, the `client` application can be deployed using the following commands: @@ -568,9 +571,7 @@ Instead of using a standard {productName} server distribution, the three {produc [source,sh,subs="+quotes,attributes+",options="nowrap"] ---- cd ${PATH_TO_QUICKSTART_DIR}/client; -mvn clean package \ - -DremoteServerUsername="quickstartUser" -DremoteServerPassword='quickstartPwd1!' \ - -DpostgresqlUsername="test" -DpostgresqlPassword="test" +mvn clean package -DpostgresqlUsername="test" -DpostgresqlPassword="test" ---- [source,sh,subs="+quotes,attributes+",options="nowrap"] ---- diff --git a/ejb-txn-remote-call/client/client-cr.yaml b/ejb-txn-remote-call/client/client-cr.yaml index f3cf259f26..f606f68a93 100644 --- a/ejb-txn-remote-call/client/client-cr.yaml +++ b/ejb-txn-remote-call/client/client-cr.yaml @@ -1,7 +1,7 @@ apiVersion: wildfly.org/v1alpha1 kind: WildFlyServer metadata: - name: client + name: ejb-txn-remote-call-client spec: env: - name: POSTGRESQL_DATABASE @@ -12,5 +12,5 @@ spec: value: test - name: POSTGRESQL_USER value: test - applicationImage: "client:latest" - replicas: 1 \ No newline at end of file + applicationImage: "localhost:5000/ejb-txn-remote-call-client:latest" + replicas: 1 diff --git a/ejb-txn-remote-call/client/pom.xml b/ejb-txn-remote-call/client/pom.xml index 149f2b400c..2e99047aa7 100644 --- a/ejb-txn-remote-call/client/pom.xml +++ b/ejb-txn-remote-call/client/pom.xml @@ -42,9 +42,13 @@ 35.0.0.Beta1 ${version.server} + 8.0.0.Final + 7.0.2.Final 5.1.0.Beta2 42.7.2 + + scripts/cli.local.properties @@ -242,97 +246,42 @@ ${postgresqlUsername} ${postgresqlPassword} - - - - package - package - - package - - - - ${version.server} - - false - - postgresql - - - - - - run-script - package - - execute-commands - - - true - ${project.build.directory}/server + + + org.wildfly:wildfly-galleon-pack:${version.server} + + + org.wildfly.cloud:wildfly-cloud-galleon-pack:${version.pack.cloud} + + + org.wildfly:wildfly-datasources-galleon-pack:${version.pack.datasources} + + + + ${version.server} + + false + + postgresql + + + + - - scripts/cli.local.properties - - - ${remoteServerUsername} - ${remoteServerPassword} - - - - - - - - - - openshift - - - - org.wildfly.plugins - wildfly-maven-plugin + + ${property.file} + + + + false + - package - package package - - - ${version.server} - - false - cloud - - postgresql - - - - - - run-script - package - - execute-commands - - - true - ${project.build.directory}/server - - - - - scripts/cli.openshift.properties - - - ${remoteServerUsername} - ${remoteServerPassword} - - @@ -350,6 +299,12 @@ + + openshift + + scripts/cli.openshift.properties + + integration-testing diff --git a/ejb-txn-remote-call/client/scripts/cli.local.properties b/ejb-txn-remote-call/client/scripts/cli.local.properties index dc57508214..59ab29efc3 100644 --- a/ejb-txn-remote-call/client/scripts/cli.local.properties +++ b/ejb-txn-remote-call/client/scripts/cli.local.properties @@ -1,5 +1,7 @@ remoteServerHost=127.0.0.1 remoteServerPort=8180 remoteDeploymentName=server +remoteServerUsername=quickstartUser +remoteServerPassword=quickstartPwd1! postgresqlServerName=localhost serverConfig=standalone.xml diff --git a/ejb-txn-remote-call/client/scripts/cli.openshift.properties b/ejb-txn-remote-call/client/scripts/cli.openshift.properties index 69457dba19..a380a0b480 100644 --- a/ejb-txn-remote-call/client/scripts/cli.openshift.properties +++ b/ejb-txn-remote-call/client/scripts/cli.openshift.properties @@ -1,6 +1,8 @@ -remoteServerHost=server-0.server-headless +remoteServerHost=ejb-txn-remote-call-server-headless remoteServerPort=8080 remoteDeploymentName=server +remoteServerUsername=quickstartUser +remoteServerPassword=quickstartPwd1! # This is the service's name of the PostgreSQL database on OpenShift postgresqlServerName=postgresql -serverConfig=standalone.xml \ No newline at end of file +serverConfig=standalone.xml diff --git a/ejb-txn-remote-call/client/scripts/remoting-configuration.cli b/ejb-txn-remote-call/client/scripts/remoting-configuration.cli index 14e99a4845..8a2c070629 100644 --- a/ejb-txn-remote-call/client/scripts/remoting-configuration.cli +++ b/ejb-txn-remote-call/client/scripts/remoting-configuration.cli @@ -6,49 +6,46 @@ set remoteServerUsername=${remoteServerUsername} set remoteServerPassword=${remoteServerPassword} set serverConfig=${serverConfig} -# running embeded server with server config -embed-server --server-config=$serverConfig - -# we assume that if one of the sys properties exists then server was configured already +# It is assumed that in case one of the system properties exists then this script was already executed if (outcome != success) of /system-property=remote.server.host:read-resource -/system-property=remote.server.host:add(value=$remoteServerHost) -/system-property=remote.server.port:add(value=$remoteServerPort) -/system-property=remote.server.username:add(value=$remoteServerUsername) -/system-property=remote.server.password:add(value=$remoteServerPassword) -/system-property=remote.deployment.name:add(value=$remoteDeploymentName) + /system-property=remote.server.host:add(value=$remoteServerHost) + /system-property=remote.server.port:add(value=$remoteServerPort) + /system-property=remote.server.username:add(value=$remoteServerUsername) + /system-property=remote.server.password:add(value=$remoteServerPassword) + /system-property=remote.deployment.name:add(value=$remoteDeploymentName) -echo "System properties defined" + echo "System properties defined" -/socket-binding-group=standard-sockets/remote-destination-outbound-socket-binding=server2:add(host=${remote.server.host}, port=${remote.server.port}) + /socket-binding-group=standard-sockets/remote-destination-outbound-socket-binding=server2:add(host=${remote.server.host}, port=${remote.server.port}) -echo "Outbound socket binding 'server2' created" + echo "Outbound socket binding 'server2' created" -# adding password realm where secret is password 'quickstartUser' converted to base64 format -# reload # when would be run not in embed mode + # adding password realm where secret is password 'quickstartUser' converted to base64 format + # reload # when would be run not in embed mode -/subsystem=elytron/authentication-configuration=auth_config:add(authentication-name=quickstartUser,authorization-name=quickstartUser, credential-reference={clear-text=quickstartPwd1!}, realm="ApplicationRealm", sasl-mechanism-selector="DIGEST-MD5") -/subsystem=elytron/authentication-context=auth_context:add(match-rules=[{authentication-configuration=auth_config}]) + /subsystem=elytron/authentication-configuration=auth_config:add(authentication-name=quickstartUser,authorization-name=quickstartUser, credential-reference={clear-text=quickstartPwd1!}, realm="ApplicationRealm", sasl-mechanism-selector="DIGEST-MD5") + /subsystem=elytron/authentication-context=auth_context:add(match-rules=[{authentication-configuration=auth_config}]) -/subsystem=remoting/remote-outbound-connection=remote-ejb-connection:add(outbound-socket-binding-ref=server2, authentication-context=auth_context) -/subsystem=remoting/remote-outbound-connection=remote-ejb-connection/property=SASL_POLICY_NOANONYMOUS:add(value=false) -/subsystem=remoting/remote-outbound-connection=remote-ejb-connection/property=SSL_ENABLED:add(value=false) -/subsystem=remoting/remote-outbound-connection=remote-ejb-connection/property=SASL_DISALLOWED_MECHANISMS:add(value=JBOSS-LOCAL-USER) + /subsystem=remoting/remote-outbound-connection=remote-ejb-connection:add(outbound-socket-binding-ref=server2, authentication-context=auth_context) + /subsystem=remoting/remote-outbound-connection=remote-ejb-connection/property=SASL_POLICY_NOANONYMOUS:add(value=false) + /subsystem=remoting/remote-outbound-connection=remote-ejb-connection/property=SSL_ENABLED:add(value=false) + /subsystem=remoting/remote-outbound-connection=remote-ejb-connection/property=SASL_DISALLOWED_MECHANISMS:add(value=JBOSS-LOCAL-USER) -echo "Remote outbound connection 'remote-ejb-connection' created" + echo "Remote outbound connection 'remote-ejb-connection' created" -# for transaction manager could be asked for recovery to be started the listener at port has to be enabled (JVM restart needed) -/subsystem=transactions:write-attribute(name=recovery-listener,value=true) -echo "Transaction recovery listener enabled" -# the recovery listener is normally bound at port 4712, you can verify it with: -# /socket-binding-group=standard-sockets/socket-binding=txn-recovery-environment:read-attribute(name=bound-port) -# for recovery invocation you can use e.g.: `telnet localhost 4712`; enter 'SCAN' on input + # for transaction manager could be asked for recovery to be started the listener at port has to be enabled (JVM restart needed) + /subsystem=transactions:write-attribute(name=recovery-listener,value=true) + echo "Transaction recovery listener enabled" + # the recovery listener is normally bound at port 4712, you can verify it with: + # /socket-binding-group=standard-sockets/socket-binding=txn-recovery-environment:read-attribute(name=bound-port) + # for recovery invocation you can use e.g.: `telnet localhost 4712`; enter 'SCAN' on input -# to get detailed insight on what happening during transaction processing switch on the TRACE logging for Narayana -# /subsystem=logging/logger=com.arjuna:write-attribute(name=level,value=TRACE) + # to get detailed insight on what happening during transaction processing switch on the TRACE logging for Narayana + # /subsystem=logging/logger=com.arjuna:write-attribute(name=level,value=TRACE) -echo "remoting-configuration.cli script finished" + echo "remoting-configuration.cli script finished" end-if -quit \ No newline at end of file +quit diff --git a/ejb-txn-remote-call/server/configuration/application-roles.properties b/ejb-txn-remote-call/server/extra-content/standalone/configuration/application-roles.properties similarity index 100% rename from ejb-txn-remote-call/server/configuration/application-roles.properties rename to ejb-txn-remote-call/server/extra-content/standalone/configuration/application-roles.properties diff --git a/ejb-txn-remote-call/server/configuration/application-users.properties b/ejb-txn-remote-call/server/extra-content/standalone/configuration/application-users.properties similarity index 100% rename from ejb-txn-remote-call/server/configuration/application-users.properties rename to ejb-txn-remote-call/server/extra-content/standalone/configuration/application-users.properties diff --git a/ejb-txn-remote-call/server/pom.xml b/ejb-txn-remote-call/server/pom.xml index 960329a881..71aa63f042 100644 --- a/ejb-txn-remote-call/server/pom.xml +++ b/ejb-txn-remote-call/server/pom.xml @@ -30,7 +30,7 @@ ejb-txn-remote-call-server - 35.0.0.Final-SNAPSHOT + 35.0.0.Beta1-SNAPSHOT war Quickstart: ejb-txn-remote-call-server The project is the application to be deployed on the second server to receive the call @@ -40,6 +40,8 @@ 35.0.0.Beta1 ${version.server} + 7.0.2.Final + 8.0.0.Final 5.1.0.Beta2 7.0.0.Final @@ -207,70 +209,38 @@ ${postgresqlUsername} ${postgresqlPassword} + + + org.wildfly:wildfly-galleon-pack:${version.server} + + + org.wildfly.cloud:wildfly-cloud-galleon-pack:${version.pack.cloud} + + + org.wildfly:wildfly-datasources-galleon-pack:${version.pack.datasources} + + + + ${version.server} + + postgresql + wildfly-cli + + cloud + + false + ha + + + extra-content + + false - package - package package - - true - - ${version.server} - - postgresql - wildfly-cli - - - false - ha - - - - - - - - - - openshift - - - - org.wildfly.plugins - wildfly-maven-plugin - - - package - package - - package - - - - ${version.server} - - postgresql - - cloud - - false - ha - - - - - - - - org.apache.maven.plugins - maven-source-plugin - - - attach-sources - none diff --git a/ejb-txn-remote-call/server/server-cr.yaml b/ejb-txn-remote-call/server/server-cr.yaml index d7b82b20a0..5c4b33fdb3 100644 --- a/ejb-txn-remote-call/server/server-cr.yaml +++ b/ejb-txn-remote-call/server/server-cr.yaml @@ -1,7 +1,7 @@ apiVersion: wildfly.org/v1alpha1 kind: WildFlyServer metadata: - name: server + name: ejb-txn-remote-call-server spec: env: - name: POSTGRESQL_DATABASE @@ -12,5 +12,5 @@ spec: value: test - name: POSTGRESQL_USER value: test - applicationImage: "server:latest" - replicas: 2 \ No newline at end of file + applicationImage: "localhost:5000/ejb-txn-remote-call-server:latest" + replicas: 2