From bbda6e32ab3a5fddbea2bdcfd1436ded8008813c Mon Sep 17 00:00:00 2001 From: Augusto Date: Sun, 10 Dec 2023 14:24:16 +0100 Subject: [PATCH] Improving RETORCH tool to provide Jenkinsfiles in generic projects --- Jenkinsfile | 239 +++++++++--------- .../configurations/retorch-ciinfo.json | 9 + retorchfiles/configurations/retorch-info.json | 28 ++ retorchfiles/envfiles/tjobc.env | 17 ++ retorchfiles/envfiles/tjobd.env | 17 ++ retorchfiles/envfiles/tjobe.env | 17 ++ retorchfiles/envfiles/tjobf.env | 17 ++ retorchfiles/envfiles/tjobg.env | 17 ++ retorchfiles/envfiles/tjobh.env | 17 ++ retorchfiles/envfiles/tjobi.env | 17 ++ retorchfiles/envfiles/tjobj.env | 17 ++ retorchfiles/envfiles/tjobk.env | 17 ++ retorchfiles/envfiles/tjobl.env | 17 ++ retorchfiles/envfiles/tjobm.env | 17 ++ retorchfiles/envfiles/tjobn.env | 17 ++ .../FullTeachingSystemResources.json | 130 ++++++++++ .../retorchdockercomposesenvfiles/tjobc.env | 5 - .../retorchdockercomposesenvfiles/tjobd.env | 5 - .../retorchdockercomposesenvfiles/tjobe.env | 5 - .../retorchdockercomposesenvfiles/tjobf.env | 5 - .../retorchdockercomposesenvfiles/tjobg.env | 5 - .../retorchdockercomposesenvfiles/tjobh.env | 5 - .../retorchdockercomposesenvfiles/tjobi.env | 5 - .../retorchdockercomposesenvfiles/tjobj.env | 5 - .../retorchdockercomposesenvfiles/tjobk.env | 5 - .../retorchdockercomposesenvfiles/tjobl.env | 5 - .../retorchdockercomposesenvfiles/tjobm.env | 5 - .../retorchdockercomposesenvfiles/tjobn.env | 5 - .../scripts/coilifecycles/coi-setup.sh | 78 ++++-- .../scripts/coilifecycles/coi-teardown.sh | 20 +- retorchfiles/scripts/saveTJobLifecycledata.sh | 14 - retorchfiles/scripts/savetjoblifecycledata.sh | 29 +++ .../scripts/tjoblifecycles/tjob-setup.sh | 33 ++- .../scripts/tjoblifecycles/tjob-teardown.sh | 20 +- .../tjoblifecycles/tjob-testexecution.sh | 63 ++++- retorchfiles/scripts/waitForFullteaching.sh | 13 - retorchfiles/scripts/waitforSUT.sh | 19 ++ retorchfiles/scripts/writetime.sh | 38 ++- .../no_elastest/common/BaseLoggedTest.java | 56 ++-- .../e2e/no_elastest/common/ChromeUser.java | 8 +- .../e2e/no_elastest/common/Constants.java | 2 +- 41 files changed, 765 insertions(+), 298 deletions(-) create mode 100644 retorchfiles/configurations/retorch-ciinfo.json create mode 100644 retorchfiles/configurations/retorch-info.json create mode 100644 retorchfiles/envfiles/tjobc.env create mode 100644 retorchfiles/envfiles/tjobd.env create mode 100644 retorchfiles/envfiles/tjobe.env create mode 100644 retorchfiles/envfiles/tjobf.env create mode 100644 retorchfiles/envfiles/tjobg.env create mode 100644 retorchfiles/envfiles/tjobh.env create mode 100644 retorchfiles/envfiles/tjobi.env create mode 100644 retorchfiles/envfiles/tjobj.env create mode 100644 retorchfiles/envfiles/tjobk.env create mode 100644 retorchfiles/envfiles/tjobl.env create mode 100644 retorchfiles/envfiles/tjobm.env create mode 100644 retorchfiles/envfiles/tjobn.env create mode 100644 retorchfiles/resources/FullTeachingSystemResources.json delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobc.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobd.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobe.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobf.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobg.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobh.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobi.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobj.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobk.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobl.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobm.env delete mode 100644 retorchfiles/retorchdockercomposesenvfiles/tjobn.env delete mode 100644 retorchfiles/scripts/saveTJobLifecycledata.sh create mode 100644 retorchfiles/scripts/savetjoblifecycledata.sh delete mode 100644 retorchfiles/scripts/waitForFullteaching.sh create mode 100644 retorchfiles/scripts/waitforSUT.sh diff --git a/Jenkinsfile b/Jenkinsfile index 5c873df..6c195a3 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -1,174 +1,177 @@ pipeline { agent {label 'xretorch-agent'} environment { - ET_EUS_API = "http://selenoid:4444/wd/hub" - CURRENT_DATE = " date +\'[%m-%d-%y] %T - \'" - //Used to avoid the UnixHTTPConnectionPool(host='localhost', port=None): Read timed out and - DOCKER_CLIENT_TIMEOUT = 120 - COMPOSE_HTTP_TIMEOUT = 120 - }//EndEnvironment + SELENOID_PRESENT = "TRUE" + SUT_LOCATION = "$WORKSPACE" + SCRIPTS_FOLDER = "$WORKSPACE/retorchfiles/scripts" + }// EndEnvironment options { - disableConcurrentBuilds() - }//EndPipOptions + disableConcurrentBuilds() + }// EndPipOptions stages{ + stage('Clean Workspace') { + steps{ + cleanWs() + }// EndStepsCleanWS + }// EndStageCleanWS + stage('Clone Project') { + steps{ + checkout scm + }// EndStepsCloneProject + }// EndStageCloneProject stage('SETUP-Infrastructure') { steps{ - //Change the permisions to the scripts folder the - sh 'chmod +x -R ./retorchfiles/scripts' - sh './retorchfiles/scripts/coilifecycles/coi-setup.sh' + sh 'chmod +x -R $SCRIPTS_FOLDER' + sh '$SCRIPTS_FOLDER/coilifecycles/coi-setup.sh' }// EndStepsSETUPINF - }//EndStageSETUPInf + }// EndStageSETUPInf stage('Stage 0'){ failFast false parallel{ stage('TJobC IdResource: Attenders LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobc 0' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobc 0 "FullTeachingEndToEndRESTTests#attendersRestOperations"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobc 0' - }//EndExecutionStageErrorTJobC - }//EndStepsTJobC - }//EndStageTJobC + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobc 0' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobc 0 https://full-teaching- 5000 "FullTeachingEndToEndRESTTests#attendersRestOperations"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobc 0' + }// EndExecutionStageErrorTJobC + }// EndStepsTJobC + }// EndStageTJobC stage('TJobD IdResource: Configuration LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobd 0' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobd 0 "FullTeachingEndToEndRESTTests#courseRestOperations,CourseTeacherTest#teacherEditCourseValues"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobd 0' - }//EndExecutionStageErrorTJobD - }//EndStepsTJobD - }//EndStageTJobD + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobd 0' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobd 0 https://full-teaching- 5000 "FullTeachingEndToEndRESTTests#courseRestOperations,CourseTeacherTest#teacherEditCourseValues"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobd 0' + }// EndExecutionStageErrorTJobD + }// EndStepsTJobD + }// EndStageTJobD stage('TJobE IdResource: Configuration LoginService OpenVidu ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobe 0' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobe 0 "FullTeachingEndToEndEChatTests#oneToOneChatInSessionChrome"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobe 0' - }//EndExecutionStageErrorTJobE - }//EndStepsTJobE - }//EndStageTJobE + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobe 0' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobe 0 https://full-teaching- 5000 "FullTeachingEndToEndEChatTests#oneToOneChatInSessionChrome"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobe 0' + }// EndExecutionStageErrorTJobE + }// EndStepsTJobE + }// EndStageTJobE stage('TJobF IdResource: Course LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobf 0' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobf 0 "LoggedLinksTests#spiderLoggedTest,UnLoggedLinksTests#spiderUnloggedTest,CourseTeacherTest#teacherDeleteCourseTest"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobf 0' - }//EndExecutionStageErrorTJobF - }//EndStepsTJobF - }//EndStageTJobF + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobf 0' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobf 0 https://full-teaching- 5000 "LoggedLinksTests#spiderLoggedTest,UnLoggedLinksTests#spiderUnloggedTest,CourseTeacherTest#teacherDeleteCourseTest"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobf 0' + }// EndExecutionStageErrorTJobF + }// EndStepsTJobF + }// EndStageTJobF stage('TJobG IdResource: Course LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobg 0' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobg 0 "CourseStudentTest#studentCourseMainTest,CourseTeacherTest#teacherCourseMainTest,CourseTeacherTest#teacherCreateAndDeleteCourseTest"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobg 0' - }//EndExecutionStageErrorTJobG - }//EndStepsTJobG - }//EndStageTJobG - }//End Parallel - }//End Stage + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobg 0' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobg 0 https://full-teaching- 5000 "CourseStudentTest#studentCourseMainTest,CourseTeacherTest#teacherCourseMainTest,CourseTeacherTest#teacherCreateAndDeleteCourseTest"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobg 0' + }// EndExecutionStageErrorTJobG + }// EndStepsTJobG + }// EndStageTJobG + }// End Parallel + }// End Stage stage('Stage 1'){ failFast false parallel{ stage('TJobH IdResource: Information LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobh 1' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobh 1 "FullTeachingEndToEndRESTTests#courseInfoRestOperations"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobh 1' - }//EndExecutionStageErrorTJobH - }//EndStepsTJobH - }//EndStageTJobH + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobh 1' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobh 1 https://full-teaching- 5000 "FullTeachingEndToEndRESTTests#courseInfoRestOperations"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobh 1' + }// EndExecutionStageErrorTJobH + }// EndStepsTJobH + }// EndStageTJobH stage('TJobI IdResource: Files LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobi 1' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobi 1 "FullTeachingEndToEndRESTTests#filesRestOperations"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobi 1' - }//EndExecutionStageErrorTJobI - }//EndStepsTJobI - }//EndStageTJobI + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobi 1' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobi 1 https://full-teaching- 5000 "FullTeachingEndToEndRESTTests#filesRestOperations"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobi 1' + }// EndExecutionStageErrorTJobI + }// EndStepsTJobI + }// EndStageTJobI stage('TJobJ IdResource: Forum LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobj 1' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobj 1 "LoggedForumTest#forumLoadEntriesTest"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobj 1' - }//EndExecutionStageErrorTJobJ - }//EndStepsTJobJ - }//EndStageTJobJ + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobj 1' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobj 1 https://full-teaching- 5000 "LoggedForumTest#forumLoadEntriesTest"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobj 1' + }// EndExecutionStageErrorTJobJ + }// EndStepsTJobJ + }// EndStageTJobJ stage('TJobK IdResource: Forum LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobk 1' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobk 1 "LoggedForumTest#forumNewCommentTest,LoggedForumTest#forumNewEntryTest,LoggedForumTest#forumNewReply2CommentTest,FullTeachingEndToEndRESTTests#forumRestOperations"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobk 1' - }//EndExecutionStageErrorTJobK - }//EndStepsTJobK - }//EndStageTJobK + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobk 1' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobk 1 https://full-teaching- 5000 "LoggedForumTest#forumNewCommentTest,LoggedForumTest#forumNewEntryTest,LoggedForumTest#forumNewReply2CommentTest,FullTeachingEndToEndRESTTests#forumRestOperations"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobk 1' + }// EndExecutionStageErrorTJobK + }// EndStepsTJobK + }// EndStageTJobK stage('TJobL IdResource: LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobl 1' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobl 1 "UserTest#loginTest"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobl 1' - }//EndExecutionStageErrorTJobL - }//EndStepsTJobL - }//EndStageTJobL - }//End Parallel - }//End Stage + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobl 1' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobl 1 https://full-teaching- 5000 "UserTest#loginTest"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobl 1' + }// EndExecutionStageErrorTJobL + }// EndStepsTJobL + }// EndStageTJobL + }// End Parallel + }// End Stage stage('Stage 2'){ failFast false parallel{ stage('TJobM IdResource: Session LoginService OpenVidu ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobm 2' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobm 2 "FullTeachingTestEndToEndVideoSessionTests#oneToOneVideoAudioSessionChrome,FullTeachingLoggedVideoSessionTests#sessionTest"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobm 2' - }//EndExecutionStageErrorTJobM - }//EndStepsTJobM - }//EndStageTJobM + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobm 2' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobm 2 https://full-teaching- 5000 "FullTeachingTestEndToEndVideoSessionTests#oneToOneVideoAudioSessionChrome,FullTeachingLoggedVideoSessionTests#sessionTest"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobm 2' + }// EndExecutionStageErrorTJobM + }// EndStepsTJobM + }// EndStageTJobM stage('TJobN IdResource: Session LoginService OpenViduMock ') { steps { catchError(buildResult: 'UNSTABLE', stageResult: 'FAILURE') { - sh 'retorchfiles/scripts/tjoblifecycles/tjob-setup.sh tjobn 2' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh tjobn 2 "FullTeachingEndToEndRESTTests#sessionRestOperations"' - sh 'retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh tjobn 2' - }//EndExecutionStageErrorTJobN - }//EndStepsTJobN - }//EndStageTJobN - }//End Parallel - }//End Stage - stage('TEARDOWN-Infrastructure'){ - stages{ - stage('PublishReports'){ - steps{ - sh 'retorchfiles/scripts/coilifecycles/coi-teardown.sh' - sh 'retorchfiles/scripts/saveTJobLifecycledata.sh' - publishHTML (target : [allowMissing: false, - alwaysLinkToLastBuild: true, - keepAll: true, - reportDir: 'target/site/', - reportFiles: 'surefire-report.html', - reportName: 'Test Execution Report']) - - }//EndStepsPublishReports - }//EndStagePublishReports - }//EndStagesINFTearDown - - }//EndStageTearDown -}//EndStagesPipeline + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-setup.sh tjobn 2' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-testexecution.sh tjobn 2 https://full-teaching- 5000 "FullTeachingEndToEndRESTTests#sessionRestOperations"' + sh '$SCRIPTS_FOLDER/tjoblifecycles/tjob-teardown.sh tjobn 2' + }// EndExecutionStageErrorTJobN + }// EndStepsTJobN + }// EndStageTJobN + }// End Parallel + }// End Stage +stage('TEARDOWN-Infrastructure') { + stages { + stage('PublishReports') { + steps { + sh '$SCRIPTS_FOLDER/coilifecycles/coi-teardown.sh' + publishHTML( + target: [ + allowMissing: false, + alwaysLinkToLastBuild: true, + keepAll: true, + reportDir: 'target/site/', + reportFiles: 'surefire-report.html', + reportName: 'Test Execution Report' + ]) + }// EndStepsPublishReports + }// EndStagePublishReports + }// EndStagesINFTearDown +}// EndStageTearDown + }// EndStagesPipeline post { always { - archiveArtifacts artifacts: 'artifacts/*.csv', onlyIfSuccessful: true }//EndAlways - cleanup { - cleanWs() - sh """(eval \$CURRENT_DATE ; echo "Cleaning Environment ") | cat |tr '\n' ' ' """ - echo 'Switch off all containers...' - sh """docker stop \$(docker ps | grep tjob | awk '{print \$1}') || echo 'All the containers are stopped!'""" - sh """docker rm --volumes \$(docker ps -a | grep tjob | awk '{print \$1}') || echo 'All the containers are removed!'""" - }//EndCleanUp + archiveArtifacts artifacts: '$WORKSPACE/artifacts/*.csv', onlyIfSuccessful: true + archiveArtifacts artifacts: 'target/testlogs/**/*.*', onlyIfSuccessful: false + archiveArtifacts artifacts: 'target/containerlogs/**/*.*', onlyIfSuccessful: false + }//EndAlways }//EndPostActions -}//EndPipeline +}// EndPipeline diff --git a/retorchfiles/configurations/retorch-ciinfo.json b/retorchfiles/configurations/retorch-ciinfo.json new file mode 100644 index 0000000..bafae36 --- /dev/null +++ b/retorchfiles/configurations/retorch-ciinfo.json @@ -0,0 +1,9 @@ +{ + "agentCIName": "xretorch-agent", + "sut-wait-html": "FullTeaching", + "sut-location": "$WORKSPACE", + "docker-frontend-name": "https://full-teaching-", + "docker-frontend-port": "5000", + "external-binded-port": "" + +} \ No newline at end of file diff --git a/retorchfiles/configurations/retorch-info.json b/retorchfiles/configurations/retorch-info.json new file mode 100644 index 0000000..90c134a --- /dev/null +++ b/retorchfiles/configurations/retorch-info.json @@ -0,0 +1,28 @@ +{ + "OpenViduMock": { + "dockerImageResource": [ + { + "placeHolderId": "OpenViduImage", + "imageName": "eexit/mirror-http-server" + }, + { + "placeHolderId": "mysqlImage", + "imageName": "mysql:5.7.21" + } + ], + "testsBasePath": "./" + }, + "generic": { + "dockerImageResource": [ + { + "placeHolderId": "OpenViduImage", + "imageName": "openvidu/openvidu-server-kms:1.7.0" + }, + { + "placeHolderId": "mysqlImage", + "imageName": "mysql:5.7.21" + } + ], + "testsBasePath": "./" + } +} diff --git a/retorchfiles/envfiles/tjobc.env b/retorchfiles/envfiles/tjobc.env new file mode 100644 index 0000000..09fa289 --- /dev/null +++ b/retorchfiles/envfiles/tjobc.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobc +frontend_port=5000 +retorchportj=5009 +retorchportk=5010 +retorchporth=5007 +mysqlImage=mysql:5.7.21 +retorchporti=5008 +retorchportf=5005 +retorchportg=5006 +retorchportd=5003 +retorchporte=5004 +retorchportb=5001 +retorchportc=5002 +retorchporta=5000 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/envfiles/tjobd.env b/retorchfiles/envfiles/tjobd.env new file mode 100644 index 0000000..30717a4 --- /dev/null +++ b/retorchfiles/envfiles/tjobd.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobd +frontend_port=5000 +retorchportj=5020 +retorchportk=5021 +retorchporth=5018 +mysqlImage=mysql:5.7.21 +retorchporti=5019 +retorchportf=5016 +retorchportg=5017 +retorchportd=5014 +retorchporte=5015 +retorchportb=5012 +retorchportc=5013 +retorchporta=5011 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/envfiles/tjobe.env b/retorchfiles/envfiles/tjobe.env new file mode 100644 index 0000000..844d9dd --- /dev/null +++ b/retorchfiles/envfiles/tjobe.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobe +frontend_port=5000 +retorchportj=5031 +retorchportk=5032 +retorchporth=5029 +mysqlImage=mysql:5.7.21 +retorchporti=5030 +retorchportf=5027 +retorchportg=5028 +retorchportd=5025 +retorchporte=5026 +retorchportb=5023 +retorchportc=5024 +retorchporta=5022 +OpenViduImage=openvidu/openvidu-server-kms:1.7.0 + diff --git a/retorchfiles/envfiles/tjobf.env b/retorchfiles/envfiles/tjobf.env new file mode 100644 index 0000000..4948a47 --- /dev/null +++ b/retorchfiles/envfiles/tjobf.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobf +frontend_port=5000 +retorchportj=5042 +retorchportk=5043 +retorchporth=5040 +mysqlImage=mysql:5.7.21 +retorchporti=5041 +retorchportf=5038 +retorchportg=5039 +retorchportd=5036 +retorchporte=5037 +retorchportb=5034 +retorchportc=5035 +retorchporta=5033 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/envfiles/tjobg.env b/retorchfiles/envfiles/tjobg.env new file mode 100644 index 0000000..65642ed --- /dev/null +++ b/retorchfiles/envfiles/tjobg.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobg +frontend_port=5000 +retorchportj=5053 +retorchportk=5054 +retorchporth=5051 +mysqlImage=mysql:5.7.21 +retorchporti=5052 +retorchportf=5049 +retorchportg=5050 +retorchportd=5047 +retorchporte=5048 +retorchportb=5045 +retorchportc=5046 +retorchporta=5044 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/envfiles/tjobh.env b/retorchfiles/envfiles/tjobh.env new file mode 100644 index 0000000..9c78b43 --- /dev/null +++ b/retorchfiles/envfiles/tjobh.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobh +frontend_port=5000 +retorchportj=5064 +retorchportk=5065 +retorchporth=5062 +mysqlImage=mysql:5.7.21 +retorchporti=5063 +retorchportf=5060 +retorchportg=5061 +retorchportd=5058 +retorchporte=5059 +retorchportb=5056 +retorchportc=5057 +retorchporta=5055 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/envfiles/tjobi.env b/retorchfiles/envfiles/tjobi.env new file mode 100644 index 0000000..b245760 --- /dev/null +++ b/retorchfiles/envfiles/tjobi.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobi +frontend_port=5000 +retorchportj=5075 +retorchportk=5076 +retorchporth=5073 +mysqlImage=mysql:5.7.21 +retorchporti=5074 +retorchportf=5071 +retorchportg=5072 +retorchportd=5069 +retorchporte=5070 +retorchportb=5067 +retorchportc=5068 +retorchporta=5066 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/envfiles/tjobj.env b/retorchfiles/envfiles/tjobj.env new file mode 100644 index 0000000..1c7081c --- /dev/null +++ b/retorchfiles/envfiles/tjobj.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobj +frontend_port=5000 +retorchportj=5086 +retorchportk=5087 +retorchporth=5084 +mysqlImage=mysql:5.7.21 +retorchporti=5085 +retorchportf=5082 +retorchportg=5083 +retorchportd=5080 +retorchporte=5081 +retorchportb=5078 +retorchportc=5079 +retorchporta=5077 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/envfiles/tjobk.env b/retorchfiles/envfiles/tjobk.env new file mode 100644 index 0000000..3fc301b --- /dev/null +++ b/retorchfiles/envfiles/tjobk.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobk +frontend_port=5000 +retorchportj=5097 +retorchportk=5098 +retorchporth=5095 +mysqlImage=mysql:5.7.21 +retorchporti=5096 +retorchportf=5093 +retorchportg=5094 +retorchportd=5091 +retorchporte=5092 +retorchportb=5089 +retorchportc=5090 +retorchporta=5088 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/envfiles/tjobl.env b/retorchfiles/envfiles/tjobl.env new file mode 100644 index 0000000..a95cd93 --- /dev/null +++ b/retorchfiles/envfiles/tjobl.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobl +frontend_port=5000 +retorchportj=5108 +retorchportk=5109 +retorchporth=5106 +mysqlImage=mysql:5.7.21 +retorchporti=5107 +retorchportf=5104 +retorchportg=5105 +retorchportd=5102 +retorchporte=5103 +retorchportb=5100 +retorchportc=5101 +retorchporta=5099 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/envfiles/tjobm.env b/retorchfiles/envfiles/tjobm.env new file mode 100644 index 0000000..ac2be6f --- /dev/null +++ b/retorchfiles/envfiles/tjobm.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobm +frontend_port=5000 +retorchportj=5119 +retorchportk=5120 +retorchporth=5117 +mysqlImage=mysql:5.7.21 +retorchporti=5118 +retorchportf=5115 +retorchportg=5116 +retorchportd=5113 +retorchporte=5114 +retorchportb=5111 +retorchportc=5112 +retorchporta=5110 +OpenViduImage=openvidu/openvidu-server-kms:1.7.0 + diff --git a/retorchfiles/envfiles/tjobn.env b/retorchfiles/envfiles/tjobn.env new file mode 100644 index 0000000..0895a12 --- /dev/null +++ b/retorchfiles/envfiles/tjobn.env @@ -0,0 +1,17 @@ +testsBasePath=./ +tjobname=tjobn +frontend_port=5000 +retorchportj=5130 +retorchportk=5131 +retorchporth=5128 +mysqlImage=mysql:5.7.21 +retorchporti=5129 +retorchportf=5126 +retorchportg=5127 +retorchportd=5124 +retorchporte=5125 +retorchportb=5122 +retorchportc=5123 +retorchporta=5121 +OpenViduImage=eexit/mirror-http-server + diff --git a/retorchfiles/resources/FullTeachingSystemResources.json b/retorchfiles/resources/FullTeachingSystemResources.json new file mode 100644 index 0000000..f56c8a0 --- /dev/null +++ b/retorchfiles/resources/FullTeachingSystemResources.json @@ -0,0 +1,130 @@ +{ + "Configuration": { + "hierarchyParent": [ + "Course" + ], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelConfiguration", + "elasticity": 40, + "elasticityCost": 15.0 + }, + "resourceType": "LOGICAL", + "resourceID": "Configuration" + }, + "OpenViduMock": { + "hierarchyParent": [ + "OpenVidu" + ], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelOpenViduMock", + "elasticity": 30, + "elasticityCost": 10.0 + }, + "resourceType": "LOGICAL", + "resourceID": "OpenViduMock" + }, + "OpenVidu": { + "hierarchyParent": [], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelOpenVidu", + "elasticity": 1, + "elasticityCost": 300.0 + }, + "resourceType": "LOGICAL", + "resourceID": "OpenVidu" + }, + "Course": { + "hierarchyParent": [ + "MySQL" + ], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelCourse", + "elasticity": 5, + "elasticityCost": 100.0 + }, + "resourceType": "LOGICAL", + "resourceID": "Course" + }, + "Information": { + "hierarchyParent": [ + "Course" + ], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelInformation", + "elasticity": 20, + "elasticityCost": 15.0 + }, + "resourceType": "LOGICAL", + "resourceID": "Information" + }, + "Files": { + "hierarchyParent": [ + "Course" + ], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelFiles", + "elasticity": 20, + "elasticityCost": 15.0 + }, + "resourceType": "LOGICAL", + "resourceID": "Files" + }, + "Attenders": { + "hierarchyParent": [ + "Course" + ], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelAttenders", + "elasticity": 20, + "elasticityCost": 15.0 + }, + "resourceType": "LOGICAL", + "resourceID": "Attenders" + }, + "LoginService": { + "hierarchyParent": [ + "MySQL" + ], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelLoginService", + "elasticity": 5, + "elasticityCost": 30.0 + }, + "resourceType": "LOGICAL", + "resourceID": "LoginService" + }, + "Session": { + "hierarchyParent": [ + "Course" + ], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelSession", + "elasticity": 20, + "elasticityCost": 15.0 + }, + "resourceType": "LOGICAL", + "resourceID": "Session" + }, + "Forum": { + "hierarchyParent": [ + "Course" + ], + "replaceable": [], + "elasticityModel": { + "elasticityID": "elasModelForum", + "elasticity": 20, + "elasticityCost": 15.0 + }, + "resourceType": "LOGICAL", + "resourceID": "Forum" + } +} \ No newline at end of file diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobc.env b/retorchfiles/retorchdockercomposesenvfiles/tjobc.env deleted file mode 100644 index bce6519..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobc.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobc - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobd.env b/retorchfiles/retorchdockercomposesenvfiles/tjobd.env deleted file mode 100644 index 8bd3643..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobd.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobd - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobe.env b/retorchfiles/retorchdockercomposesenvfiles/tjobe.env deleted file mode 100644 index 613e445..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobe.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=openvidu/openvidu-server-kms:1.7.0 -tjobname=tjobe - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobf.env b/retorchfiles/retorchdockercomposesenvfiles/tjobf.env deleted file mode 100644 index 4c5891c..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobf.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobf - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobg.env b/retorchfiles/retorchdockercomposesenvfiles/tjobg.env deleted file mode 100644 index 3fcb65c..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobg.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobg - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobh.env b/retorchfiles/retorchdockercomposesenvfiles/tjobh.env deleted file mode 100644 index b7d1b54..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobh.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobh - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobi.env b/retorchfiles/retorchdockercomposesenvfiles/tjobi.env deleted file mode 100644 index c6ef1b9..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobi.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobi - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobj.env b/retorchfiles/retorchdockercomposesenvfiles/tjobj.env deleted file mode 100644 index 7ca7908..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobj.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobj - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobk.env b/retorchfiles/retorchdockercomposesenvfiles/tjobk.env deleted file mode 100644 index 7eeab50..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobk.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobk - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobl.env b/retorchfiles/retorchdockercomposesenvfiles/tjobl.env deleted file mode 100644 index da9c6bf..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobl.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobl - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobm.env b/retorchfiles/retorchdockercomposesenvfiles/tjobm.env deleted file mode 100644 index 0b8bd89..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobm.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=openvidu/openvidu-server-kms:1.7.0 -tjobname=tjobm - diff --git a/retorchfiles/retorchdockercomposesenvfiles/tjobn.env b/retorchfiles/retorchdockercomposesenvfiles/tjobn.env deleted file mode 100644 index b891da4..0000000 --- a/retorchfiles/retorchdockercomposesenvfiles/tjobn.env +++ /dev/null @@ -1,5 +0,0 @@ -mysqlImage=mysql:5.7.21 -testsBasePath=./ -OpenViduImage=eexit/mirror-http-server -tjobname=tjobn - diff --git a/retorchfiles/scripts/coilifecycles/coi-setup.sh b/retorchfiles/scripts/coilifecycles/coi-setup.sh index 75fbf51..89ee7d6 100644 --- a/retorchfiles/scripts/coilifecycles/coi-setup.sh +++ b/retorchfiles/scripts/coilifecycles/coi-setup.sh @@ -1,30 +1,60 @@ #!/bin/bash -OUTPUTDIRCOI="./src/retorchcostestimationdata/exec$BUILD_NUMBER/COI.data" + +SEL_VIDEO_DIR="/opt/selenoid/video/" +SEL_LOG_DIR="/opt/selenoid/logs/" + +# Function to remove older files +remove_old_files() { + dir=$1 + days=$2 + echo "Removing older files ($days days) in $dir! The number of files prior to remove:" + find "$dir" | wc -l + find "$dir" -mindepth 1 -maxdepth 1 -mtime +$days -exec rm -rf {} \; + echo "Removing older files ($days days) in $dir! The number of files after remove:" + find "$dir" | wc -l +} + +# Set output directory for COI +OUTPUTDIRCOI="$WORKSPACE/retorchcostestimationdata/exec$BUILD_NUMBER/COI.data" + +# Record start time for COI setup COISETUPSTART=$(date +%s%3N) -echo 'Remove older videos (7 days)! The number of videos prior remove :' -find /opt/selenoid/video/ | wc -l -find /opt/selenoid/video/ -mindepth 1 -maxdepth 1 -mtime +7 -name '*.mp4' | xargs rm -rf -echo 'Remove older videos (7 days)! The number of videos after remove : ' -find /opt/selenoid/video/ | wc -l -echo 'Remove older logs (7days)! The number of logs prior remove :' -find /opt/selenoid/logs/ | wc -l -find /opt/selenoid/logs/ -mindepth 1 -maxdepth 1 -mtime +7 -name '*.log' | xargs rm -rf -echo 'Remove older logs (7days)! The number of logs prior remove : ' -find /opt/selenoid/logs/ | wc -l -mkdir -p "./src/retorchcostestimationdata/exec$BUILD_NUMBER" -mkdir -p "./artifacts" -echo "Pulling the Docker Images required by Selenoid (if are not pulled)" -docker pull selenoid/vnc_chrome:116.0 -docker pull selenoid/video-recorder:latest-release -echo "Pulling the Docker Images requirede by the Test suite" -docker pull eexit/mirror-http-server -docker pull mysql:5.7.21 -docker pull openvidu/openvidu-server-kms:1.7.0 -docker pull codeurjc/full-teaching:demo -COISETUPEND=$(date +%s%3N) +# Remove older videos (older than 15 days) +remove_old_files "$SEL_VIDEO_DIR" 15 + +# Remove older logs (older than 7 days) +remove_old_files "$SEL_LOG_DIR" 7 +# Create necessary directories +mkdir -p "$WORKSPACE/retorchcostestimationdata/exec$BUILD_NUMBER" +mkdir -p "$WORKSPACE/artifacts" +mkdir -p "$SUT_LOCATION/tmp" -echo "COI-SETUP-START;COI-SETUP-END;COI-TEARDOWN-START;COI-TEARDOWN-END" >"$OUTPUTDIRCOI" -echo -n "$COISETUPSTART;$COISETUPEND">>"$OUTPUTDIRCOI" +# Pull Docker images +echo "Pulling images" +if docker pull selenoid/vnc_chrome:116.0 && docker pull selenoid/video-recorder:latest-release; then + echo "Images pulled successfully." +else + echo "Failed to pull Docker images." +fi + +echo "Building images of SUT" + +# Use double quotes for Docker Compose files TEMPORAL FIX +docker compose -f "docker-compose.yml" --env-file "$WORKSPACE/retorchfiles/envfiles/tjobc.env" --ansi never build + +# Check the exit status of the last command +if [ $? -eq 0 ]; then + echo "Images for SUT" +else + echo "Failed to build images of SUT" + exit 1 +fi + +# Record end time for COI setup +COISETUPEND=$(date +%s%3N) +# Write setup timestamps to output file +echo "COI-SETUP-START;COI-SETUP-END;COI-TEARDOWN-START;COI-TEARDOWN-END" > "$OUTPUTDIRCOI" +echo -n "$COISETUPSTART;$COISETUPEND" >> "$OUTPUTDIRCOI" diff --git a/retorchfiles/scripts/coilifecycles/coi-teardown.sh b/retorchfiles/scripts/coilifecycles/coi-teardown.sh index b0cd055..3bae4ce 100644 --- a/retorchfiles/scripts/coilifecycles/coi-teardown.sh +++ b/retorchfiles/scripts/coilifecycles/coi-teardown.sh @@ -1,13 +1,21 @@ #!/bin/bash +set -e # Exit immediately if any command exits with a non-zero status COITEARDOWNSTART="$(date +%s%3N)" -echo 'Switch off all containers...' -docker stop "$(docker ps | grep tjob | awk '{print \$1}')" || echo 'All the containers are stopped!' -docker rm --volumes "$(docker ps -a | grep tjob | awk '{print \$1}')" || echo 'All the containers are removed!' -sh 'retorchfiles/scripts/saveTJobLifecycledata.sh' +echo "Switch off all containers that start with *tjob*..." +docker rm $(docker stop $(docker ps -a -q --filter name=tjob --format="{{.ID}}") || echo 'Any Container to remove') || echo 'All the containers are removed!' + +echo "Pruning also its volumes" +docker volume prune --all -f + +# Run saveTJobLifecycledata.sh script +echo "Running saveTJobLifecycledata.sh script..." +sh "$SCRIPTS_FOLDER/savetjoblifecycledata.sh" + COITEARDOWNEND="$(date +%s%3N)" -OUTPUTDIRCOI="./src/retorchcostestimationdata/exec$BUILD_NUMBER/COI.data" -echo -n ";$COITEARDOWNSTART;$COITEARDOWNEND" >>"$OUTPUTDIRCOI" +OUTPUTDIRCOI="$WORKSPACE/retorchcostestimationdata/exec$BUILD_NUMBER/COI.data" +echo -n ";$COITEARDOWNSTART;$COITEARDOWNEND" >> "$OUTPUTDIRCOI" +echo "COI teardown script completed successfully." diff --git a/retorchfiles/scripts/saveTJobLifecycledata.sh b/retorchfiles/scripts/saveTJobLifecycledata.sh deleted file mode 100644 index 5fd3a30..0000000 --- a/retorchfiles/scripts/saveTJobLifecycledata.sh +++ /dev/null @@ -1,14 +0,0 @@ -#!/bin/bash -PATH_FILES="./src/retorchcostestimationdata/exec${BUILD_NUMBER}/tjob*" -OUTPUT_FILE="./artifacts/lifecycletimmingsexec${BRANCH_NAME///}-${BUILD_NUMBER}.csv" -OUTPUTDIRCOI="./src/retorchcostestimationdata/exec$BUILD_NUMBER/COI.data" -echo "tjobname;stage;COI-setup-start;COI-setup-end;tjob-setup-start;tjob-setup-end;tjob-testexec-start;tjob-testexec-end;tjob-teardown-start;tjob-teardown-end;coi-teardown-start;coi-teardown-end" >"$OUTPUT_FILE" -for csvfile in $PATH_FILES; do - { - tail -n +2 "$csvfile" - echo -n ";" - tail -n +2 "$OUTPUTDIRCOI" | rev | cut -d ';' -f 2 | rev | tr -d '\n' - echo -n ";" - tail -n +2 "$OUTPUTDIRCOI" | rev | cut -d ';' -f 1 | rev - } >>"$OUTPUT_FILE" -done diff --git a/retorchfiles/scripts/savetjoblifecycledata.sh b/retorchfiles/scripts/savetjoblifecycledata.sh new file mode 100644 index 0000000..b660324 --- /dev/null +++ b/retorchfiles/scripts/savetjoblifecycledata.sh @@ -0,0 +1,29 @@ +#!/bin/bash +set -e + +# Check if the correct number of arguments is provided +if [ "$#" -ne 0 ]; then + echo "This script doesn't take any parameter" + exit 1 +fi + +PATH_FILES="$WORKSPACE/retorchcostestimationdata/exec${BUILD_NUMBER}/tjob*" +OUTPUT_FILE="$WORKSPACE/artifacts/lifecycletimingsexec${BRANCH_NAME///}-${BUILD_NUMBER}.csv" +OUTPUT_DIR_COI="$WORKSPACE/retorchcostestimationdata/exec$BUILD_NUMBER/COI.data" + +echo "tjobname;stage;COI-setup-start;COI-setup-end;tjob-setup-start;tjob-setup-end;tjob-testexec-start;tjob-testexec-end;tjob-teardown-start;tjob-teardown-end;coi-teardown-start;coi-teardown-end" >"$OUTPUT_FILE" + +for csvfile in $PATH_FILES; do + if [ -e "$csvfile" ] && [ -e "$OUTPUT_DIR_COI" ]; then + { + tail -n +2 "$csvfile" + echo -n ";" + tail -n +2 "$OUTPUT_DIR_COI" | rev | cut -d ';' -f 2 | rev | tr -d '\n' + echo -n ";" + tail -n +2 "$OUTPUT_DIR_COI" | rev | cut -d ';' -f 1 | rev + } >>"$OUTPUT_FILE" + else + echo "Error: One or more files do not exist." + exit 1 + fi +done diff --git a/retorchfiles/scripts/tjoblifecycles/tjob-setup.sh b/retorchfiles/scripts/tjoblifecycles/tjob-setup.sh index 757045c..d1b0cd3 100644 --- a/retorchfiles/scripts/tjoblifecycles/tjob-setup.sh +++ b/retorchfiles/scripts/tjoblifecycles/tjob-setup.sh @@ -1,7 +1,28 @@ #!/bin/bash -retorchfiles/scripts/writetime.sh "$2" "$1" #$2 is the stage, $1 tjob -docker compose --env-file "./retorchfiles/retorchdockercomposesenvfiles/${1}.env" --ansi never -p "$1" up -d -echo "Waiting for the SUT... " -retorchfiles/scripts/waitForFullteaching.sh "$1" -echo "SUT READY!" -retorchfiles/scripts/writetime.sh "$2" "$1" #$2 is the stage, $1 tjob +set -e +# Execute the script to write timestamp +"$SCRIPTS_FOLDER/writetime.sh" "$2" "$1" + +# Export Docker Host IP +DOCKER_HOST_IP=$(/sbin/ip route | awk '/default/ { print $3 }') +export DOCKER_HOST_IP +echo "Exporting the HOST_IP: $DOCKER_HOST_IP" +echo "The HOST_IP is: $DOCKER_HOST_IP" +# Custom Set-up commands +echo "Executing custom commands" + + + +# Deploy containers +cd "$SUT_LOCATION" +echo "Deploying containers for TJOB $1" +docker compose -f docker-compose.yml --env-file "$WORKSPACE/retorchfiles/envfiles/$1.env" --ansi never -p "$1" up -d + +echo "Waiting for the system to be up..." +"$WORKSPACE/retorchfiles/scripts/waitforSUT.sh" "$1" +cd "$WORKSPACE" + +echo "System READY!! Test execution can start!" + +# Execute the script to write timestamp again +"$SCRIPTS_FOLDER/writetime.sh" "$2" "$1" diff --git a/retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh b/retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh index 46d3ae2..5cb50de 100644 --- a/retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh +++ b/retorchfiles/scripts/tjoblifecycles/tjob-teardown.sh @@ -1,4 +1,18 @@ #!/bin/bash -retorchfiles/scripts/writetime.sh "$2" "$1" #$2 is the stage, $1 tjob -docker compose --env-file "./retorchfiles/retorchdockercomposesenvfiles/${1}.env" --ansi never -p "$1" down --volumes -retorchfiles/scripts/writetime.sh "$2" "$1" #$2 is the stage, $1 tjob +set -e + +# Execute the script to write timestamp +"$SCRIPTS_FOLDER/writetime.sh" "$2" "$1" + +# Change to SUT location +cd "$SUT_LOCATION" + +# Tear down Docker containers and volumes +echo "Tearing down Docker containers and volumes for TJOB $1" +docker compose -f docker-compose.yml --env-file "$WORKSPACE/retorchfiles/envfiles/$1.env" --ansi never -p "$1" down --volumes + +# Return to the original working directory +cd "$WORKSPACE" + +# Execute the script to write timestamp again +"$SCRIPTS_FOLDER/writetime.sh" "$2" "$1" diff --git a/retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh b/retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh index 4446a40..a60df5d 100644 --- a/retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh +++ b/retorchfiles/scripts/tjoblifecycles/tjob-testexecution.sh @@ -1,15 +1,52 @@ #!/bin/bash -URL="https://full-teaching-$1:5000" -#https://stackoverflow.com/questions/4365418/get-state-of-maven-execution-within-shell-script set -e -retorchfiles/scripts/writetime.sh "$2" "$1" #$2 is the stage, $1 tjob -mvn -Dapp.url="${URL}" -Dtest="$3" test -Ddirtarget="$1" -retorchfiles/scripts/writetime.sh "$2" "$1" #$2 is the stage, $1 tjob -#if [[$EXECUTION_RESULT -eq 0]] -# then -# echo "EXECUTION TJOB $1 FINISHED" -# return 0 -# else -# echo "SOMETHING GO WRONG WITH TJOB $1" -# return 1 -# fi +# Function to execute timestamp script +EXECUTE_TIMESTAMP_SCRIPT() { + local STAGE="$1" + local TJOB_NAME="$2" + $SCRIPTS_FOLDER/writetime.sh "$STAGE" "$TJOB_NAME" +} + +# Check if the required parameters are provided +if [ "$#" -lt 5 ]; then + echo "Usage: $0 " + exit 1 +fi +# Constants +DOCKER_HOST_IP=$(/sbin/ip route | awk '/default/ { print $3 }') +# Define variables +TJOB_NAME="$1" +STAGE="$2" +PORT="$4" +TEST_NAME="$5" +if [[ $url == "https://" || $url == "http://" ]]; then + echo "Only http:// || https:// protocol provided, using HOST DOCKER INTERNAL IP " + SUT_URL="$3"+DOCKER_HOST_IP +else + echo "Using the provided URL" + SUT_URL="$3" +fi +echo "The URL IS $SUT_URL" + +# Execute the script to write timestamp +EXECUTE_TIMESTAMP_SCRIPT "$STAGE" "$TJOB_NAME" + +# Display HOST_IP and PORT information +echo "The HOST_IP is: $DOCKER_HOST_IP and PORT $PORT for the TJOB $TJOB_NAME" + +LOCALHOST="$DOCKER_HOST_IP:$PORT" +# Run Maven test +mvn test -Ddirtarget="$TJOBNAME" -Dtest="$TEST_NAME" -Dtjob_name="$TJOB_NAME" -DSUT_URL="$SUT_URL" -DSUT_PORT="$PORT" + +# Check if Maven test failed +if [ $? -ne 0 ]; then + echo "Maven test FAILED with exit code $?." + exit 1 # Return 1 if the Maven test fails +fi + +# If the script reaches here, the Maven test succeeded +echo "Maven test succeeded." + +# Execute the script to write timestamp again +EXECUTE_TIMESTAMP_SCRIPT "$STAGE" "$TJOB_NAME" +exit 0 diff --git a/retorchfiles/scripts/waitForFullteaching.sh b/retorchfiles/scripts/waitForFullteaching.sh deleted file mode 100644 index fed6a42..0000000 --- a/retorchfiles/scripts/waitForFullteaching.sh +++ /dev/null @@ -1,13 +0,0 @@ -#!/bin/bash -COUNTER=0 - -URL="https://full-teaching-$1:5000" -until curl --insecure -s "${URL}" | grep -q "FullTeaching"; do - echo "waiting $COUNTER for $1 wit URL $URL " - sleep 4 - COUNTER=$(expr $COUNTER + 1) - if test "$COUNTER" -gt 80; then - echo "The container is down" - exit 1 - fi -done diff --git a/retorchfiles/scripts/waitforSUT.sh b/retorchfiles/scripts/waitforSUT.sh new file mode 100644 index 0000000..55cda36 --- /dev/null +++ b/retorchfiles/scripts/waitforSUT.sh @@ -0,0 +1,19 @@ +#!/bin/bash +if [ "$#" -ne 1 ]; then + echo "Usage: $0 " + exit 1 +fi +DOCKER_HOST_IP=$(/sbin/ip route | awk '/default/ { print $3 }') +COUNTER=0 +WAIT_LIMIT=40 + +while ! curl --insecure -s "https://full-teaching-$1:5000" | grep -q "FullTeaching"; do + echo "Waiting $COUNTER seconds for $1 with URL https://full-teaching-$1:5000" + sleep 5 + ((COUNTER++)) + + if ((COUNTER > WAIT_LIMIT)); then + echo "The container is down" + exit 1 + fi +done diff --git a/retorchfiles/scripts/writetime.sh b/retorchfiles/scripts/writetime.sh index 980d4b6..dea11af 100644 --- a/retorchfiles/scripts/writetime.sh +++ b/retorchfiles/scripts/writetime.sh @@ -1,16 +1,34 @@ #!/bin/bash -OUTPUTDIR="./src/retorchcostestimationdata/exec$BUILD_NUMBER/$2.data" -OUTPUTDIRCOI="./src/retorchcostestimationdata/exec$BUILD_NUMBER/COI.data" -if [ -f "$OUTPUTDIR" ]; then - echo -n ";$(date +%s%3N)" >>"$OUTPUTDIR" -else +# Check if the correct number of parameters is provided +if [ "$#" -ne 2 ]; then + echo "Usage: $0 " + exit 1 +fi +STAGE=$2 +# Constants +WORKSPACE_DIR="$WORKSPACE/retorchcostestimationdata/exec$BUILD_NUMBER" +OUTPUT_FILE="$WORKSPACE_DIR/$STAGE.data" +OUTPUT_DIR_COI="$WORKSPACE_DIR/COI.data" + +# Function to append timestamp +append_timestamp() { + if [ -f "$1" ]; then + echo -n ";$(date +%s%3N)" >>"$1" + else + echo "Error: File $1 does not exist." + exit 1 + fi +} - echo "tjobname;stage;COI-setup-start;COI-setup-end;setup-start;setup-end;testexec-start;testexec-end;teardown-start;teardown-end" >"$OUTPUTDIR" +# Check if the output file exists +if [ -f "$OUTPUT_FILE" ]; then + append_timestamp "$OUTPUT_FILE" +else + echo "tjobname;stage;COI-setup-start;COI-setup-end;setup-start;setup-end;testexec-start;testexec-end;teardown-start;teardown-end" >"$OUTPUT_FILE" { - echo -n "$2;$1;" - tail -n +2 "$OUTPUTDIRCOI" + echo -n "$STAGE;$BUILD_NUMBER;" + tail -n +2 "$OUTPUT_DIR_COI" echo -n ";$(date +%s%3N)" - } >>"$OUTPUTDIR" - + } >>"$OUTPUT_FILE" fi diff --git a/src/test/java/com/fullteaching/e2e/no_elastest/common/BaseLoggedTest.java b/src/test/java/com/fullteaching/e2e/no_elastest/common/BaseLoggedTest.java index 31bf574..2da20e3 100644 --- a/src/test/java/com/fullteaching/e2e/no_elastest/common/BaseLoggedTest.java +++ b/src/test/java/com/fullteaching/e2e/no_elastest/common/BaseLoggedTest.java @@ -27,7 +27,6 @@ import static org.openqa.selenium.logging.LogType.BROWSER; import static org.slf4j.LoggerFactory.getLogger; - public class BaseLoggedTest { public static final String CHROME = "chrome"; @@ -50,47 +49,60 @@ public class BaseLoggedTest { protected static String TEST_NAME = "DEFAULT"; protected static String TJOB_NAME = "TJobDef"; - public WebDriver driver; protected BrowserUser user; - public BaseLoggedTest() { } - @BeforeAll() - static void setupAll() { //28 lines + @BeforeAll + static void setupAll() { // 28 lines + // Initialize properties properties = new Properties(); + try { - // load a properties file for reading + // Load a properties file for reading properties.load(new FileInputStream("src/test/resources/inputs/test.properties")); } catch (IOException ex) { - ex.printStackTrace(); + ex.printStackTrace(); // Consider logging the exception instead of printing the stack trace } + + // Check if running outside ElasTest if (System.getenv("ET_EUS_API") == null) { - // Outside ElasTest + // Setup drivers for Chrome and Firefox ChromeDriverManager.getInstance(chrome).setup(); FirefoxDriverManager.getInstance(firefox).setup(); } - if (System.getenv("ET_SUT_HOST") != null) { - APP_URL = "https://" + System.getenv("ET_SUT_HOST") + ":" + PORT + "/"; + + String envUrl = System.getProperty("SUT_URL"); + String envPort = System.getProperty("SUT_PORT"); + String envTJobName = System.getProperty("tjob_name"); + log.debug("Using URL {} PORT: {} TJOB: {}", envUrl, envPort, envTJobName); + // Check if SUT_URL is defined in the environment variables + if ((envUrl != null) & (envPort != null)) { + TJOB_NAME = envTJobName; + PORT = envPort; + APP_URL = envUrl + TJOB_NAME + ":" + PORT + "/"; + log.debug("The URL is" + APP_URL); HOST = APP_URL; } else { - APP_URL = System.getProperty("app.url"); - if (APP_URL == null) { - APP_URL = LOCALHOST; - } else { + // Check if app.url system property is defined + APP_URL = System.getProperty("app.url", LOCALHOST); + + // Set HOST if APP_URL is not null + if (APP_URL != null) { HOST = APP_URL; } } + + // Set browser types for teacher and student TEACHER_BROWSER = System.getenv("TEACHER_BROWSER"); STUDENT_BROWSER = System.getenv("STUDENT_BROWSER"); - if ((TEACHER_BROWSER == null) || (!TEACHER_BROWSER.equals(FIREFOX))) { - TEACHER_BROWSER = CHROME; - } - if ((STUDENT_BROWSER == null) || (!STUDENT_BROWSER.equals(FIREFOX))) { - STUDENT_BROWSER = CHROME; - } + + // Default to Chrome if browser types are not defined or are not Firefox + TEACHER_BROWSER = (TEACHER_BROWSER == null || !TEACHER_BROWSER.equals(FIREFOX)) ? CHROME : TEACHER_BROWSER; + STUDENT_BROWSER = (STUDENT_BROWSER == null || !STUDENT_BROWSER.equals(FIREFOX)) ? CHROME : STUDENT_BROWSER; + log.info("Using URL {} to connect to OpenVidu-app", APP_URL); } @@ -111,7 +123,6 @@ protected BrowserUser setupBrowser(String browser, String testName, BrowserUser u; log.info("Starting browser ({})", browser); - switch (browser) { case FIREFOX: BROWSER_NAME = FIREFOX; @@ -124,7 +135,6 @@ protected BrowserUser setupBrowser(String browser, String testName, userIdentifier); break; - default: BROWSER_NAME = CHROME; u = new ChromeUser(userIdentifier, secondsOfWait, testName, @@ -165,7 +175,6 @@ void tearDown(TestInfo testInfo) { //13 lines } } - protected void slowLogin(BrowserUser user, String userEmail, String userPass) {//24 lines log.info("Slow login"); @@ -268,7 +277,6 @@ protected void logout(BrowserUser user) { //43 lines user.setOnSession(false); log.info("Logging out successful for {}", user.getClientData()); - } private boolean isClickable(String selector, BrowserUser user) { diff --git a/src/test/java/com/fullteaching/e2e/no_elastest/common/ChromeUser.java b/src/test/java/com/fullteaching/e2e/no_elastest/common/ChromeUser.java index 41f8137..35a6eb6 100644 --- a/src/test/java/com/fullteaching/e2e/no_elastest/common/ChromeUser.java +++ b/src/test/java/com/fullteaching/e2e/no_elastest/common/ChromeUser.java @@ -61,15 +61,11 @@ public ChromeUser(String userName, int timeOfWaitInSeconds, String testName, Str options.addArguments(argument); } - String eusApiURL = System.getenv("ET_EUS_API"); - - log.debug("The URL its ({})", eusApiURL); - options.setAcceptInsecureCerts(true); //This capability is to store the logs of the test case log.debug("Added Capabilities of acceptInsecureCerts and ignore alarms"); - if (eusApiURL == null) { + if (System.getenv("SELENOID_PRESENT") == null) { log.info("Using the Local WebDriver ()"); this.driver = new ChromeDriver(options); } else { @@ -102,7 +98,7 @@ public ChromeUser(String userName, int timeOfWaitInSeconds, String testName, Str //END CAPABILITIES FOR SELENOID RETORCH log.debug("Configuring the remote WebDriver "); - RemoteWebDriver remote = new RemoteWebDriver(new URL(eusApiURL), options); + RemoteWebDriver remote = new RemoteWebDriver(new URL("http://selenoid:4444/wd/hub"), options); log.debug("Configuring the Local File Detector"); remote.setFileDetector(new LocalFileDetector()); this.driver = remote; diff --git a/src/test/java/com/fullteaching/e2e/no_elastest/common/Constants.java b/src/test/java/com/fullteaching/e2e/no_elastest/common/Constants.java index 340d99a..d72648d 100644 --- a/src/test/java/com/fullteaching/e2e/no_elastest/common/Constants.java +++ b/src/test/java/com/fullteaching/e2e/no_elastest/common/Constants.java @@ -7,7 +7,7 @@ public final class Constants { public static final int WAIT_SECONDS = 150; public static final String LOCALHOST = "https://localhost:5000"; - public static final String PORT = "11811"; + public static String PORT = "11811"; public static final String STUDENT_NAME = "Student Imprudent"; public static final String TEACHER_NAME = "Teacher Cheater";