mirror of https://github.com/OpenVidu/openvidu.git
Jenkinsfile updated with try-catchs
parent
d4eac2c895
commit
339a894682
|
@ -11,121 +11,161 @@ node('container') {
|
|||
def mycontainer = docker.image('openvidu/openvidu-test-e2e:$DISTRO')
|
||||
mycontainer.pull()
|
||||
mycontainer.inside('--name e2e -p 4200:4200 -p 4443:4443 -p 5555:5555 -u root -e MY_UID=0 -v /var/run/docker.sock:/var/run/docker.sock:rw -v /dev/shm:/dev/shm -v /opt/openvidu:/opt/openvidu --privileged') {
|
||||
stage('Preparation') {
|
||||
sh 'rm -rf ~/.m2 || true'
|
||||
sh 'rm -rf openvidu || true'
|
||||
sh 'rm -rf kurento-java || true'
|
||||
sh 'git clone https://github.com/OpenVidu/openvidu.git'
|
||||
sh 'cd openvidu && git fetch --all && git checkout $OPENVIDU_COMMIT'
|
||||
sh(script: '''#!/bin/bash
|
||||
if $KURENTO_JAVA_SNAPSHOT ; then
|
||||
git clone https://github.com/Kurento/kurento-java.git
|
||||
cd kurento-java && MVN_VERSION=$(mvn --batch-mode -q -Dexec.executable=echo -Dexec.args='${project.version}' --non-recursive exec:exec)
|
||||
cd ../openvidu && mvn --batch-mode versions:set-property -Dproperty=version.kurento -DnewVersion=$MVN_VERSION
|
||||
mvn dependency:get -DrepoUrl=https://maven.openvidu.io/repository/snapshots/ -Dartifact=org.kurento:kurento-client:$MVN_VERSION
|
||||
mvn dependency:get -DrepoUrl=https://maven.openvidu.io/repository/snapshots/ -Dartifact=org.kurento:kurento-jsonrpc-client-jetty:$MVN_VERSION
|
||||
mvn dependency:get -DrepoUrl=https://maven.openvidu.io/repository/snapshots/ -Dartifact=org.kurento:kurento-jsonrpc-server:$MVN_VERSION
|
||||
mvn dependency:get -DrepoUrl=https://maven.openvidu.io/repository/snapshots/ -Dartifact=org.kurento:kurento-test:$MVN_VERSION
|
||||
fi
|
||||
'''.stripIndent())
|
||||
sh(script: '''#!/bin/bash
|
||||
if $KURENTO_MEDIA_SERVER_DEV ; then
|
||||
echo "Upgrading KMS to dev version"
|
||||
sudo apt-get update && sudo apt-get install -y aptitude
|
||||
sudo aptitude remove -y kurento-media-server
|
||||
DISTRO=`lsb_release --codename | cut -f2`
|
||||
sudo echo "deb [arch=amd64] http://ubuntu.openvidu.io/dev $DISTRO kms6" | sudo tee /etc/apt/sources.list.d/kurento.list
|
||||
sudo apt-get update && sudo apt-get --yes -o Dpkg::Options::="--force-confnew" install kurento-media-server
|
||||
fi
|
||||
'''.stripIndent())
|
||||
try {
|
||||
stage('Preparation') {
|
||||
sh 'rm -rf ~/.m2 || true'
|
||||
sh 'rm -rf openvidu || true'
|
||||
sh 'rm -rf kurento-java || true'
|
||||
sh 'git clone https://github.com/OpenVidu/openvidu.git'
|
||||
sh 'cd openvidu && git fetch --all && git checkout $OPENVIDU_COMMIT'
|
||||
sh(script: '''#!/bin/bash
|
||||
if $KURENTO_JAVA_SNAPSHOT ; then
|
||||
git clone https://github.com/Kurento/kurento-java.git
|
||||
cd kurento-java && MVN_VERSION=$(mvn --batch-mode -q -Dexec.executable=echo -Dexec.args='${project.version}' --non-recursive exec:exec)
|
||||
cd ../openvidu && mvn --batch-mode versions:set-property -Dproperty=version.kurento -DnewVersion=$MVN_VERSION
|
||||
mvn dependency:get -DrepoUrl=https://maven.openvidu.io/repository/snapshots/ -Dartifact=org.kurento:kurento-client:$MVN_VERSION
|
||||
mvn dependency:get -DrepoUrl=https://maven.openvidu.io/repository/snapshots/ -Dartifact=org.kurento:kurento-jsonrpc-client-jetty:$MVN_VERSION
|
||||
mvn dependency:get -DrepoUrl=https://maven.openvidu.io/repository/snapshots/ -Dartifact=org.kurento:kurento-jsonrpc-server:$MVN_VERSION
|
||||
mvn dependency:get -DrepoUrl=https://maven.openvidu.io/repository/snapshots/ -Dartifact=org.kurento:kurento-test:$MVN_VERSION
|
||||
fi
|
||||
'''.stripIndent())
|
||||
sh(script: '''#!/bin/bash
|
||||
if $KURENTO_MEDIA_SERVER_DEV ; then
|
||||
echo "Upgrading KMS to dev version"
|
||||
sudo apt-get update && sudo apt-get install -y aptitude
|
||||
sudo aptitude remove -y kurento-media-server
|
||||
DISTRO=`lsb_release --codename | cut -f2`
|
||||
sudo echo "deb [arch=amd64] http://ubuntu.openvidu.io/dev $DISTRO kms6" | sudo tee /etc/apt/sources.list.d/kurento.list
|
||||
sudo apt-get update && sudo apt-get --yes -o Dpkg::Options::="--force-confnew" install kurento-media-server
|
||||
fi
|
||||
'''.stripIndent())
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage('OpenVidu Browser build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu
|
||||
if [[ $OPENVIDU_BROWSER_COMMIT != "default" ]]; then
|
||||
git checkout -f $OPENVIDU_BROWSER_COMMIT
|
||||
fi
|
||||
cd openvidu-browser
|
||||
npm install --unsafe-perm && npm run build && npm pack
|
||||
cp openvidu-browser-*.tgz /opt/openvidu
|
||||
cd ..
|
||||
git checkout -f $OPENVIDU_COMMIT
|
||||
'''.stripIndent())
|
||||
try {
|
||||
stage('OpenVidu Browser build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu
|
||||
if [[ $OPENVIDU_BROWSER_COMMIT != "default" ]]; then
|
||||
git checkout -f $OPENVIDU_BROWSER_COMMIT
|
||||
fi
|
||||
cd openvidu-browser
|
||||
npm install --unsafe-perm && npm run build && npm pack
|
||||
cp openvidu-browser-*.tgz /opt/openvidu
|
||||
cd ..
|
||||
git checkout -f $OPENVIDU_COMMIT
|
||||
'''.stripIndent())
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage('OpenVidu Node Client build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu
|
||||
if [[ $OPENVIDU_NODE_CLIENT_COMMIT != "default" ]]; then
|
||||
git checkout -f $OPENVIDU_NODE_CLIENT_COMMIT
|
||||
fi
|
||||
cd openvidu-node-client
|
||||
npm install --unsafe-perm && npm run build && npm pack
|
||||
cp openvidu-node-client-*.tgz /opt/openvidu
|
||||
cd ..
|
||||
git checkout -f $OPENVIDU_COMMIT
|
||||
'''.stripIndent())
|
||||
try {
|
||||
stage('OpenVidu Node Client build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu
|
||||
if [[ $OPENVIDU_NODE_CLIENT_COMMIT != "default" ]]; then
|
||||
git checkout -f $OPENVIDU_NODE_CLIENT_COMMIT
|
||||
fi
|
||||
cd openvidu-node-client
|
||||
npm install --unsafe-perm && npm run build && npm pack
|
||||
cp openvidu-node-client-*.tgz /opt/openvidu
|
||||
cd ..
|
||||
git checkout -f $OPENVIDU_COMMIT
|
||||
'''.stripIndent())
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage('OpenVidu TestApp build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu
|
||||
if [[ $OPENVIDU_TESTAPP_COMMIT != "default" ]]; then
|
||||
git checkout -f $OPENVIDU_TESTAPP_COMMIT
|
||||
fi
|
||||
cd openvidu-testapp
|
||||
npm install --unsafe-perm
|
||||
npm install /opt/openvidu/openvidu-browser-*.tgz
|
||||
npm install /opt/openvidu/openvidu-node-client-*.tgz
|
||||
export NG_CLI_ANALYTICS="false" && ./node_modules/@angular/cli/bin/ng build --prod --output-path=/opt/openvidu/testapp
|
||||
cd ..
|
||||
git checkout -f $OPENVIDU_COMMIT
|
||||
'''.stripIndent())
|
||||
try {
|
||||
stage('OpenVidu TestApp build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu
|
||||
if [[ $OPENVIDU_TESTAPP_COMMIT != "default" ]]; then
|
||||
git checkout -f $OPENVIDU_TESTAPP_COMMIT
|
||||
fi
|
||||
cd openvidu-testapp
|
||||
npm install --unsafe-perm
|
||||
npm install /opt/openvidu/openvidu-browser-*.tgz
|
||||
npm install /opt/openvidu/openvidu-node-client-*.tgz
|
||||
export NG_CLI_ANALYTICS="false" && ./node_modules/@angular/cli/bin/ng build --prod --output-path=/opt/openvidu/testapp
|
||||
cd ..
|
||||
git checkout -f $OPENVIDU_COMMIT
|
||||
'''.stripIndent())
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage('OpenVidu Java Client build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu
|
||||
if [[ $OPENVIDU_JAVA_CLIENT_COMMIT != "default" ]]; then
|
||||
git checkout -f $OPENVIDU_JAVA_CLIENT_COMMIT
|
||||
fi
|
||||
cd openvidu-java-client
|
||||
mvn --batch-mode versions:set -DnewVersion=TEST
|
||||
mvn clean compile package
|
||||
mvn install:install-file -Dfile=target/openvidu-java-client-TEST.jar -DgroupId=io.openvidu -DartifactId=openvidu-java-client -Dversion=TEST -Dpackaging=jar
|
||||
git checkout -f $OPENVIDU_COMMIT
|
||||
'''.stripIndent())
|
||||
try {
|
||||
stage('OpenVidu Java Client build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu
|
||||
if [[ $OPENVIDU_JAVA_CLIENT_COMMIT != "default" ]]; then
|
||||
git checkout -f $OPENVIDU_JAVA_CLIENT_COMMIT
|
||||
fi
|
||||
cd openvidu-java-client
|
||||
mvn --batch-mode versions:set -DnewVersion=TEST
|
||||
mvn clean compile package
|
||||
mvn install:install-file -Dfile=target/openvidu-java-client-TEST.jar -DgroupId=io.openvidu -DartifactId=openvidu-java-client -Dversion=TEST -Dpackaging=jar
|
||||
git checkout -f $OPENVIDU_COMMIT
|
||||
'''.stripIndent())
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage('OpenVidu parent build') {
|
||||
sh 'cd openvidu && mvn --batch-mode versions:set-property -Dproperty=version.openvidu.java.client -DnewVersion=TEST'
|
||||
sh 'cd openvidu && mvn --batch-mode -DskipTests=true clean install'
|
||||
try {
|
||||
stage('OpenVidu parent build') {
|
||||
sh 'cd openvidu && mvn --batch-mode versions:set-property -Dproperty=version.openvidu.java.client -DnewVersion=TEST'
|
||||
sh 'cd openvidu && mvn --batch-mode -DskipTests=true clean install'
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage('OpenVidu Server unit tests') {
|
||||
sh 'cd openvidu/openvidu-server && mvn --batch-mode -Dtest=io.openvidu.server.test.unit.*Test test'
|
||||
try {
|
||||
stage('OpenVidu Server unit tests') {
|
||||
sh 'cd openvidu/openvidu-server && mvn --batch-mode -Dtest=io.openvidu.server.test.unit.*Test test'
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage('OpenVidu Server integration tests') {
|
||||
sh 'cd openvidu/openvidu-server && mvn --batch-mode -Dtest=io.openvidu.server.test.integration.*Test test'
|
||||
try {
|
||||
stage('OpenVidu Server integration tests') {
|
||||
sh 'cd openvidu/openvidu-server && mvn --batch-mode -Dtest=io.openvidu.server.test.integration.*Test test'
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage('OpenVidu Server build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu/openvidu-server/src/dashboard && npm install --unsafe-perm && npm install /opt/openvidu/openvidu-browser-*.tgz && export NG_CLI_ANALYTICS="false" && npm run build-prod
|
||||
cd ../..
|
||||
mvn --batch-mode package
|
||||
cp target/openvidu-server*.jar /opt/openvidu
|
||||
'''.stripIndent())
|
||||
try {
|
||||
stage('OpenVidu Server build') {
|
||||
sh(script: '''#!/bin/bash
|
||||
cd openvidu/openvidu-server/src/dashboard && npm install --unsafe-perm && npm install /opt/openvidu/openvidu-browser-*.tgz && export NG_CLI_ANALYTICS="false" && npm run build-prod
|
||||
cd ../..
|
||||
mvn --batch-mode package
|
||||
cp target/openvidu-server*.jar /opt/openvidu
|
||||
'''.stripIndent())
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage ('Environment Launch') {
|
||||
sh 'sudo openssl req -newkey rsa:2048 -new -nodes -x509 -days 3650 -subj "/CN=www.mydom.com/O=My Company LTD./C=US" -keyout /opt/openvidu/testapp/key.pem -out /opt/openvidu/testapp/cert.pem'
|
||||
sh 'cd /opt/openvidu/testapp && http-server -S -p 4200 &> /opt/openvidu/testapp.log &'
|
||||
sh '/usr/bin/kurento-media-server &> /kms.log &'
|
||||
sh 'until $(curl --insecure --output /dev/null --silent http://127.0.0.1:8888/kurento); do echo "Waiting for KMS..."; sleep 1; done'
|
||||
sh(script: '''#!/bin/bash
|
||||
if [ "$DOCKER_RECORDING_VERSION" != "default" ]; then
|
||||
echo "Using custom openvidu-recording tag: $DOCKER_RECORDING_VERSION"
|
||||
java -jar -DDOMAIN_OR_PUBLIC_IP=172.17.0.1 -DOPENVIDU_SECRET=MY_SECRET -DHTTPS_PORT=4443 -DOPENVIDU_RECORDING=true -DOPENVIDU_RECORDING_CUSTOM_LAYOUT=/opt/openvidu/test-layouts -DOPENVIDU_RECORDING_VERSION=$DOCKER_RECORDING_VERSION -DOPENVIDU_WEBHOOK=true -DOPENVIDU_WEBHOOK_ENDPOINT=http://127.0.0.1:7777/webhook /opt/openvidu/openvidu-server-*.jar &> openvidu-server.log &
|
||||
else
|
||||
echo "Using default openvidu-recording tag"
|
||||
java -jar -DDOMAIN_OR_PUBLIC_IP=172.17.0.1 -DOPENVIDU_SECRET=MY_SECRET -DHTTPS_PORT=4443 -DOPENVIDU_RECORDING=true -DOPENVIDU_RECORDING_CUSTOM_LAYOUT=/opt/openvidu/test-layouts -DOPENVIDU_WEBHOOK=true -DOPENVIDU_WEBHOOK_ENDPOINT=http://127.0.0.1:7777/webhook /opt/openvidu/openvidu-server-*.jar &> openvidu-server.log &
|
||||
fi
|
||||
'''.stripIndent())
|
||||
sh 'until $(curl --insecure --output /dev/null --silent --head --fail https://OPENVIDUAPP:MY_SECRET@localhost:4443/); do echo "Waiting for openvidu-server..."; sleep 2; done'
|
||||
try {
|
||||
stage ('Environment Launch') {
|
||||
sh 'openssl req -newkey rsa:2048 -new -nodes -x509 -days 3650 -subj "/CN=www.mydom.com/O=My Company LTD./C=US" -keyout /opt/openvidu/testapp/key.pem -out /opt/openvidu/testapp/cert.pem'
|
||||
sh 'cd /opt/openvidu/testapp && http-server -S -p 4200 &> /opt/openvidu/testapp.log &'
|
||||
sh '/usr/bin/kurento-media-server &> /kms.log &'
|
||||
sh 'until $(curl --insecure --output /dev/null --silent http://127.0.0.1:8888/kurento); do echo "Waiting for KMS..."; sleep 1; done'
|
||||
sh(script: '''#!/bin/bash
|
||||
if [ "$DOCKER_RECORDING_VERSION" != "default" ]; then
|
||||
echo "Using custom openvidu-recording tag: $DOCKER_RECORDING_VERSION"
|
||||
java -jar -DDOMAIN_OR_PUBLIC_IP=172.17.0.1 -DOPENVIDU_SECRET=MY_SECRET -DHTTPS_PORT=4443 -DOPENVIDU_RECORDING=true -DOPENVIDU_RECORDING_CUSTOM_LAYOUT=/opt/openvidu/test-layouts -DOPENVIDU_RECORDING_VERSION=$DOCKER_RECORDING_VERSION -DOPENVIDU_WEBHOOK=true -DOPENVIDU_WEBHOOK_ENDPOINT=http://127.0.0.1:7777/webhook /opt/openvidu/openvidu-server-*.jar &> openvidu-server.log &
|
||||
else
|
||||
echo "Using default openvidu-recording tag"
|
||||
java -jar -DDOMAIN_OR_PUBLIC_IP=172.17.0.1 -DOPENVIDU_SECRET=MY_SECRET -DHTTPS_PORT=4443 -DOPENVIDU_RECORDING=true -DOPENVIDU_RECORDING_CUSTOM_LAYOUT=/opt/openvidu/test-layouts -DOPENVIDU_WEBHOOK=true -DOPENVIDU_WEBHOOK_ENDPOINT=http://127.0.0.1:7777/webhook /opt/openvidu/openvidu-server-*.jar &> openvidu-server.log &
|
||||
fi
|
||||
'''.stripIndent())
|
||||
sh 'until $(curl --insecure --output /dev/null --silent --head --fail https://OPENVIDUAPP:MY_SECRET@localhost:4443/); do echo "Waiting for openvidu-server..."; sleep 2; done'
|
||||
}
|
||||
} catch (error) {
|
||||
currentBuild.result = 'FAILURE'
|
||||
}
|
||||
stage ('OpenVidu E2E tests') {
|
||||
try {
|
||||
|
|
Loading…
Reference in New Issue