Skip to content

Commit

Permalink
Update Jenkins tests for switch user
Browse files Browse the repository at this point in the history
Signed-off-by: Zelin Hao <[email protected]>
  • Loading branch information
zelinh committed Jan 10, 2025
1 parent 7639519 commit 206bc70
Show file tree
Hide file tree
Showing 7 changed files with 74 additions and 17 deletions.
27 changes: 22 additions & 5 deletions tests/jenkins/TestRunSmokeTestScript.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -19,16 +19,33 @@ class TestRunSmokeTestScript extends BuildPipelineTest {
@Test
public void TestRunSmokeTestScript() {
this.registerLibTester(new RunSmokeTestScriptLibTester(
'dummy_job',
'tests/data/opensearch-2.18.0-build.yml',
'tests/data/opensearch-2.18.0-test.yml',
'1234'
'dummy_job',
'tests/data/opensearch-2.18.0-build.yml',
'tests/data/opensearch-2.18.0-test.yml',
'1234',
'false'
)
)

binding.setVariable('env', ['BUILD_NUMBER': '9876'])
super.testPipeline("tests/jenkins/jobs/RunSmokeTestScript_Jenkinsfile")
assertThat(getShellCommands('sh', './test.sh'), hasItems('./test.sh smoke-test tests/data/opensearch-2.18.0-test.yml --test-run-id 9876 --paths opensearch=https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/1234/linux/x64/tar'))
assertThat(getShellCommands('sh', './test.sh'), hasItems(' ./test.sh smoke-test tests/data/opensearch-2.18.0-test.yml --test-run-id 9876 --paths opensearch=https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/1234/linux/x64/tar '))
}

@Test
public void TestRunSmokeTestScript_Switch_Non_Root() {
this.registerLibTester(new RunSmokeTestScriptLibTester(
'dummy_job',
'tests/data/opensearch-2.18.0-build.yml',
'tests/data/opensearch-2.18.0-test.yml',
'2345',
'true'
)
)

binding.setVariable('env', ['BUILD_NUMBER': '8765'])
super.testPipeline("tests/jenkins/jobs/RunSmokeTestScript_Switch_Non_Root_Jenkinsfile")
assertThat(getShellCommands('sh', './test.sh'), hasItems('su `id -un 1000` -c \" ./test.sh smoke-test tests/data/opensearch-2.18.0-test.yml --test-run-id 8765 --paths opensearch=https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/2345/linux/x64/tar \"'))
}

def getShellCommands(methodName, searchString) {
Expand Down
3 changes: 2 additions & 1 deletion tests/jenkins/jobs/RunSmokeTestScript_Jenkinsfile
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@ pipeline {
jobName: 'dummy_job',
buildManifest: 'tests/data/opensearch-2.18.0-build.yml',
testManifest: 'tests/data/opensearch-2.18.0-test.yml',
buildId: '1234'
buildId: '1234',
switchUserNonRoot: 'false'
)
}
}
Expand Down
5 changes: 3 additions & 2 deletions tests/jenkins/jobs/RunSmokeTestScript_Jenkinsfile.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,13 @@
RunSmokeTestScript_Jenkinsfile.echo(Executing on agent [label:none])
RunSmokeTestScript_Jenkinsfile.stage(smoke-test, groovy.lang.Closure)
RunSmokeTestScript_Jenkinsfile.script(groovy.lang.Closure)
RunSmokeTestScript_Jenkinsfile.runSmokeTestScript({jobName=dummy_job, buildManifest=tests/data/opensearch-2.18.0-build.yml, testManifest=tests/data/opensearch-2.18.0-test.yml, buildId=1234})
RunSmokeTestScript_Jenkinsfile.runSmokeTestScript({jobName=dummy_job, buildManifest=tests/data/opensearch-2.18.0-build.yml, testManifest=tests/data/opensearch-2.18.0-test.yml, buildId=1234, switchUserNonRoot=false})
runSmokeTestScript.legacySCM(groovy.lang.Closure)
runSmokeTestScript.library({identifier=jenkins@main, retriever=null})
runSmokeTestScript.readYaml({file=tests/data/opensearch-2.18.0-build.yml})
BuildManifest.asBoolean()
BuildManifest.getArtifactRootUrl(dummy_job, 1234)
runSmokeTestScript.echo(Artifact root URL: https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/1234/linux/x64/tar)
runSmokeTestScript.echo(Switch User to Non-Root (uid=1000): false)
runSmokeTestScript.echo(Paths: opensearch=https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/1234/linux/x64/tar)
runSmokeTestScript.sh(./test.sh smoke-test tests/data/opensearch-2.18.0-test.yml --test-run-id 9876 --paths opensearch=https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/1234/linux/x64/tar)
runSmokeTestScript.sh( ./test.sh smoke-test tests/data/opensearch-2.18.0-test.yml --test-run-id 9876 --paths opensearch=https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/1234/linux/x64/tar )
27 changes: 27 additions & 0 deletions tests/jenkins/jobs/RunSmokeTestScript_Switch_Non_Root_Jenkinsfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
/*
* Copyright OpenSearch Contributors
* SPDX-License-Identifier: Apache-2.0
*
* The OpenSearch Contributors require contributions made to
* this file be licensed under the Apache-2.0 license or a
* compatible open source license.
*/

pipeline {
agent none
stages {
stage('smoke-test') {
steps {
script {
runSmokeTestScript(
jobName: 'dummy_job',
buildManifest: 'tests/data/opensearch-2.18.0-build.yml',
testManifest: 'tests/data/opensearch-2.18.0-test.yml',
buildId: '2345',
switchUserNonRoot: 'true'
)
}
}
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
RunSmokeTestScript_Switch_Non_Root_Jenkinsfile.run()
RunSmokeTestScript_Switch_Non_Root_Jenkinsfile.pipeline(groovy.lang.Closure)
RunSmokeTestScript_Switch_Non_Root_Jenkinsfile.echo(Executing on agent [label:none])
RunSmokeTestScript_Switch_Non_Root_Jenkinsfile.stage(smoke-test, groovy.lang.Closure)
RunSmokeTestScript_Switch_Non_Root_Jenkinsfile.script(groovy.lang.Closure)
RunSmokeTestScript_Switch_Non_Root_Jenkinsfile.runSmokeTestScript({jobName=dummy_job, buildManifest=tests/data/opensearch-2.18.0-build.yml, testManifest=tests/data/opensearch-2.18.0-test.yml, buildId=2345, switchUserNonRoot=true})
runSmokeTestScript.legacySCM(groovy.lang.Closure)
runSmokeTestScript.library({identifier=jenkins@main, retriever=null})
runSmokeTestScript.readYaml({file=tests/data/opensearch-2.18.0-build.yml})
BuildManifest.asBoolean()
BuildManifest.getArtifactRootUrl(dummy_job, 2345)
runSmokeTestScript.echo(Artifact root URL: https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/2345/linux/x64/tar)
runSmokeTestScript.echo(Switch User to Non-Root (uid=1000): true)
runSmokeTestScript.echo(Paths: opensearch=https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/2345/linux/x64/tar)
runSmokeTestScript.sh(su `id -un 1000` -c " ./test.sh smoke-test tests/data/opensearch-2.18.0-test.yml --test-run-id 8765 --paths opensearch=https://ci.opensearch.org/ci/dbc/dummy_job/2.18.0/2345/linux/x64/tar ")
5 changes: 4 additions & 1 deletion tests/jenkins/lib-testers/RunSmokeTestScriptLibTester.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,14 @@ class RunSmokeTestScriptLibTester extends LibFunctionTester {
private String buildManifest
private String testManifest
private String buildId
private String switchUserNonRoot

public RunSmokeTestScriptLibTester(jobName, buildManifest, testManifest, buildId){
public RunSmokeTestScriptLibTester(jobName, buildManifest, testManifest, buildId, switchUserNonRoot){
this.jobName = jobName
this.buildManifest = buildManifest
this.testManifest = testManifest
this.buildId = buildId
this.switchUserNonRoot = switchUserNonRoot
}

void configure(helper, binding) {
Expand All @@ -39,6 +41,7 @@ class RunSmokeTestScriptLibTester extends LibFunctionTester {
&& call.args.buildManifest.first().toString().equals(this.buildManifest)
&& call.args.testManifest.first().toString().equals(this.testManifest)
&& call.args.buildId.first().toString().equals(this.buildId)
&& call.args.switchUserNonRoot.first().toString().equals(this.switchUserNonRoot)
}

String libFunctionName() {
Expand Down
9 changes: 1 addition & 8 deletions vars/runSmokeTestScript.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -13,30 +13,23 @@
* @param args.testManifest <required> Test manifest file location
* @param args.buildManifest <required> Build manifest file location
* @param args.buildId <required> Build ID of the distribution artifacts
* @param args.switchUserNonRoot <Required> Switch to non root user if true.
* @param args.jobName <optional> Job name that triggered the workflow. 'distribution-build-opensearh' by default.
* @param args.switchUserNonRoot <optional> Switch to non root user if true.
*/
void call(Map args = [:]) {
String jobName = args.jobName ?: 'distribution-build-opensearch'
lib = library(identifier: 'jenkins@main', retriever: legacySCM(scm))
def buildManifest = lib.jenkins.BuildManifest.new(readYaml(file: args.buildManifest))
String artifactRootUrl = buildManifest.getArtifactRootUrl(jobName, args.buildId)
// String filename = buildManifest.build.getFilename()
echo "Artifact root URL: ${artifactRootUrl}"

// def javaVersion = (filename == 'opensearch') ? detectTestDockerAgent(testManifest: args.testManifest).javaVersion : ''
// String javaHomeCommand = (javaVersion != '' && platform != 'windows') ? "JAVA_HOME=/opt/java/${javaVersion}" : ''
//
// echo "Possible Java Home: ${javaHomeCommand}"

String switchUser = args.switchUserNonRoot ?: 'false'
if (! (switchUser == 'true' || switchUser == 'false')) {
echo "args.switchUserNonRoot is not valid. Exit the program."
System.exit(1)
}
echo "Switch User to Non-Root (uid=1000): ${switchUser}"

// String switchCommandStart = switchUser == 'true' ? "su `id -un 1000` -c \"env PATH=\$PATH $javaHomeCommand" : "env PATH=\$PATH $javaHomeCommand"
String switchCommandStart = switchUser == 'true' ? "su `id -un 1000` -c \"" : ""
String switchCommandEnd = switchUser == 'true' ? '"' : ''

Expand Down

0 comments on commit 206bc70

Please sign in to comment.