2018-08-21 15:45:59 +02:00
|
|
|
import com.sap.piper.k8s.ContainerMap
|
|
|
|
import com.sap.piper.JenkinsUtils
|
2018-08-31 10:22:43 +02:00
|
|
|
|
2017-12-06 13:03:06 +02:00
|
|
|
import org.junit.Before
|
2018-01-16 10:33:13 +02:00
|
|
|
import org.junit.Rule
|
2017-12-06 13:03:06 +02:00
|
|
|
import org.junit.Test
|
2018-01-16 10:33:13 +02:00
|
|
|
import org.junit.rules.RuleChain
|
|
|
|
|
2018-06-06 11:19:19 +02:00
|
|
|
import util.BasePiperTest
|
2018-01-16 10:33:13 +02:00
|
|
|
import util.JenkinsLoggingRule
|
2018-08-31 10:22:43 +02:00
|
|
|
import util.JenkinsReadYamlRule
|
2018-02-28 14:12:03 +02:00
|
|
|
import util.JenkinsStepRule
|
2018-08-21 15:45:59 +02:00
|
|
|
import util.PluginMock
|
|
|
|
import util.Rules
|
2017-12-06 13:03:06 +02:00
|
|
|
|
|
|
|
import static org.junit.Assert.assertTrue
|
2018-08-21 15:45:59 +02:00
|
|
|
import static org.junit.Assert.assertEquals
|
2017-12-15 17:41:10 +02:00
|
|
|
import static org.junit.Assert.assertFalse
|
2017-12-06 13:03:06 +02:00
|
|
|
|
2018-06-06 11:19:19 +02:00
|
|
|
class DockerExecuteTest extends BasePiperTest {
|
2018-03-02 11:54:50 +02:00
|
|
|
private DockerMock docker
|
2018-01-16 10:33:13 +02:00
|
|
|
private JenkinsLoggingRule jlr = new JenkinsLoggingRule(this)
|
2018-02-28 14:12:03 +02:00
|
|
|
private JenkinsStepRule jsr = new JenkinsStepRule(this)
|
2018-01-16 10:33:13 +02:00
|
|
|
|
|
|
|
@Rule
|
2018-02-28 14:12:03 +02:00
|
|
|
public RuleChain ruleChain = Rules
|
|
|
|
.getCommonRules(this)
|
2018-08-31 10:22:43 +02:00
|
|
|
.around(new JenkinsReadYamlRule(this))
|
2018-02-28 14:12:03 +02:00
|
|
|
.around(jlr)
|
|
|
|
.around(jsr)
|
2018-03-29 14:13:11 +02:00
|
|
|
|
2018-03-02 11:55:27 +02:00
|
|
|
int whichDockerReturnValue = 0
|
|
|
|
def bodyExecuted
|
2018-08-21 15:45:59 +02:00
|
|
|
def containerName
|
2017-12-06 13:03:06 +02:00
|
|
|
|
|
|
|
@Before
|
2018-01-16 10:33:13 +02:00
|
|
|
void init() {
|
2018-01-16 18:06:25 +02:00
|
|
|
bodyExecuted = false
|
2017-12-06 13:03:06 +02:00
|
|
|
docker = new DockerMock()
|
2018-08-21 15:45:59 +02:00
|
|
|
JenkinsUtils.metaClass.static.isPluginActive = {def s -> new PluginMock(s).isActive()}
|
2017-12-06 13:03:06 +02:00
|
|
|
binding.setVariable('docker', docker)
|
2017-12-15 17:41:10 +02:00
|
|
|
helper.registerAllowedMethod('sh', [Map.class], {return whichDockerReturnValue})
|
2017-12-06 13:03:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2018-08-21 15:45:59 +02:00
|
|
|
void testExecuteInsideContainerOfExistingPod() throws Exception {
|
|
|
|
helper.registerAllowedMethod('container', [String.class, Closure.class], { String container, Closure body ->
|
|
|
|
containerName = container
|
|
|
|
body()
|
|
|
|
})
|
|
|
|
binding.setVariable('env', [POD_NAME: 'testpod', ON_K8S: 'true'])
|
|
|
|
ContainerMap.instance.setMap(['testpod': ['maven:3.5-jdk-8-alpine': 'mavenexec']])
|
|
|
|
jsr.step.call(script: nullScript,
|
|
|
|
dockerImage: 'maven:3.5-jdk-8-alpine',
|
|
|
|
dockerEnvVars: ['http_proxy': 'http://proxy:8000']) {
|
|
|
|
bodyExecuted = true
|
|
|
|
}
|
|
|
|
assertTrue(jlr.log.contains('Executing inside a Kubernetes Container'))
|
|
|
|
assertEquals('mavenexec', containerName)
|
|
|
|
assertTrue(bodyExecuted)
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testExecuteInsideNewlyCreatedPod() throws Exception {
|
|
|
|
helper.registerAllowedMethod('dockerExecuteOnKubernetes', [Map.class, Closure.class], { Map config, Closure body -> body() })
|
|
|
|
binding.setVariable('env', [ON_K8S: 'true'])
|
|
|
|
ContainerMap.instance.setMap(['testpod': ['maven:3.5-jdk-8-alpine': 'mavenexec']])
|
|
|
|
jsr.step.call(script: nullScript,
|
|
|
|
dockerImage: 'maven:3.5-jdk-8-alpine',
|
|
|
|
dockerEnvVars: ['http_proxy': 'http://proxy:8000']) {
|
|
|
|
bodyExecuted = true
|
|
|
|
}
|
|
|
|
assertTrue(jlr.log.contains('Executing inside a Kubernetes Pod'))
|
|
|
|
assertTrue(bodyExecuted)
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testExecuteInsidePodWithEmptyContainerMap() throws Exception {
|
|
|
|
helper.registerAllowedMethod('dockerExecuteOnKubernetes', [Map.class, Closure.class], { Map config, Closure body -> body() })
|
|
|
|
binding.setVariable('env', [POD_NAME: 'testpod', ON_K8S: 'true'])
|
|
|
|
ContainerMap.instance.setMap([:])
|
|
|
|
jsr.step.call(script: nullScript,
|
|
|
|
dockerImage: 'maven:3.5-jdk-8-alpine',
|
|
|
|
dockerEnvVars: ['http_proxy': 'http://proxy:8000']) {
|
|
|
|
bodyExecuted = true
|
|
|
|
}
|
|
|
|
assertTrue(jlr.log.contains('Executing inside a Kubernetes Pod'))
|
|
|
|
assertTrue(bodyExecuted)
|
|
|
|
}
|
2018-01-16 18:06:25 +02:00
|
|
|
|
2018-08-21 15:45:59 +02:00
|
|
|
@Test
|
|
|
|
void testExecuteInsidePodWithStageKeyEmptyValue() throws Exception {
|
|
|
|
helper.registerAllowedMethod('dockerExecuteOnKubernetes', [Map.class, Closure.class], { Map config, Closure body -> body() })
|
|
|
|
binding.setVariable('env', [POD_NAME: 'testpod', ON_K8S: 'true'])
|
|
|
|
ContainerMap.instance.setMap(['testpod':[:]])
|
2018-06-06 11:19:19 +02:00
|
|
|
jsr.step.call(script: nullScript,
|
2018-08-21 15:45:59 +02:00
|
|
|
dockerImage: 'maven:3.5-jdk-8-alpine',
|
|
|
|
dockerEnvVars: ['http_proxy': 'http://proxy:8000']) {
|
2018-01-16 18:06:25 +02:00
|
|
|
bodyExecuted = true
|
|
|
|
}
|
2018-08-21 15:45:59 +02:00
|
|
|
assertTrue(jlr.log.contains('Executing inside a Kubernetes Pod'))
|
|
|
|
assertTrue(bodyExecuted)
|
|
|
|
}
|
2018-01-16 18:06:25 +02:00
|
|
|
|
2018-08-21 15:45:59 +02:00
|
|
|
@Test
|
|
|
|
void testExecuteInsideDockerContainer() throws Exception {
|
|
|
|
jsr.step.call(script: nullScript, dockerImage: 'maven:3.5-jdk-8-alpine') {
|
|
|
|
bodyExecuted = true
|
|
|
|
}
|
2017-12-06 13:03:06 +02:00
|
|
|
assertEquals('maven:3.5-jdk-8-alpine', docker.getImageName())
|
|
|
|
assertTrue(docker.isImagePulled())
|
2018-03-29 14:13:11 +02:00
|
|
|
assertEquals('--env http_proxy --env https_proxy --env no_proxy --env HTTP_PROXY --env HTTPS_PROXY --env NO_PROXY', docker.getParameters().trim())
|
2018-01-16 18:06:25 +02:00
|
|
|
assertTrue(bodyExecuted)
|
2017-12-06 13:03:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2018-08-21 15:45:59 +02:00
|
|
|
void testExecuteInsideDockerNoScript() throws Exception {
|
|
|
|
jsr.step.call(dockerImage: 'maven:3.5-jdk-8-alpine') {
|
|
|
|
bodyExecuted = true
|
|
|
|
}
|
|
|
|
assertEquals('maven:3.5-jdk-8-alpine', docker.getImageName())
|
|
|
|
assertTrue(docker.isImagePulled())
|
|
|
|
assertEquals('--env http_proxy --env https_proxy --env no_proxy --env HTTP_PROXY --env HTTPS_PROXY --env NO_PROXY', docker.getParameters().trim())
|
|
|
|
assertTrue(bodyExecuted)
|
|
|
|
}
|
2017-12-06 13:03:06 +02:00
|
|
|
|
2018-08-21 15:45:59 +02:00
|
|
|
@Test
|
|
|
|
void testExecuteInsideDockerContainerWithParameters() throws Exception {
|
2018-06-06 11:19:19 +02:00
|
|
|
jsr.step.call(script: nullScript,
|
2018-01-16 18:06:25 +02:00
|
|
|
dockerImage: 'maven:3.5-jdk-8-alpine',
|
|
|
|
dockerOptions: '-it',
|
|
|
|
dockerVolumeBind: ['my_vol': '/my_vol'],
|
|
|
|
dockerEnvVars: ['http_proxy': 'http://proxy:8000']) {
|
|
|
|
bodyExecuted = true
|
|
|
|
}
|
2018-03-29 14:13:11 +02:00
|
|
|
assertTrue(docker.getParameters().contains('--env https_proxy '))
|
|
|
|
assertTrue(docker.getParameters().contains('--env http_proxy=http://proxy:8000'))
|
|
|
|
assertTrue(docker.getParameters().contains('-it'))
|
|
|
|
assertTrue(docker.getParameters().contains('--volume my_vol:/my_vol'))
|
2018-01-16 18:06:25 +02:00
|
|
|
assertTrue(bodyExecuted)
|
2017-12-06 13:03:06 +02:00
|
|
|
}
|
|
|
|
|
2018-03-29 14:13:11 +02:00
|
|
|
@Test
|
2018-08-21 15:45:59 +02:00
|
|
|
void testExecuteInsideDockerContainerWithDockerOptionsList() throws Exception {
|
2018-06-06 11:19:19 +02:00
|
|
|
jsr.step.call(script: nullScript,
|
2018-03-29 14:13:11 +02:00
|
|
|
dockerImage: 'maven:3.5-jdk-8-alpine',
|
|
|
|
dockerOptions: ['-it', '--network=my-network'],
|
|
|
|
dockerEnvVars: ['http_proxy': 'http://proxy:8000']) {
|
|
|
|
bodyExecuted = true
|
|
|
|
}
|
|
|
|
assertTrue(docker.getParameters().contains('--env http_proxy=http://proxy:8000'))
|
|
|
|
assertTrue(docker.getParameters().contains('-it'))
|
|
|
|
assertTrue(docker.getParameters().contains('--network=my-network'))
|
|
|
|
}
|
|
|
|
|
2018-01-16 16:42:11 +02:00
|
|
|
@Test
|
|
|
|
void testDockerNotInstalledResultsInLocalExecution() throws Exception {
|
2017-12-15 17:41:10 +02:00
|
|
|
whichDockerReturnValue = 1
|
2018-06-06 11:19:19 +02:00
|
|
|
jsr.step.call(script: nullScript,
|
2018-08-21 15:45:59 +02:00
|
|
|
dockerOptions: '-it') {
|
2018-01-16 18:06:25 +02:00
|
|
|
bodyExecuted = true
|
|
|
|
}
|
2018-01-16 10:33:13 +02:00
|
|
|
assertTrue(jlr.log.contains('No docker environment found'))
|
|
|
|
assertTrue(jlr.log.contains('Running on local environment'))
|
2018-01-16 18:06:25 +02:00
|
|
|
assertTrue(bodyExecuted)
|
2017-12-15 17:41:10 +02:00
|
|
|
assertFalse(docker.isImagePulled())
|
|
|
|
}
|
2017-12-06 13:03:06 +02:00
|
|
|
|
|
|
|
private class DockerMock {
|
|
|
|
private String imageName
|
|
|
|
private boolean imagePulled = false
|
|
|
|
private String parameters
|
|
|
|
|
|
|
|
DockerMock image(String imageName) {
|
|
|
|
this.imageName = imageName
|
|
|
|
return this
|
|
|
|
}
|
|
|
|
|
|
|
|
void pull() {
|
|
|
|
imagePulled = true
|
|
|
|
}
|
|
|
|
|
|
|
|
void inside(String parameters, body) {
|
|
|
|
this.parameters = parameters
|
|
|
|
body()
|
|
|
|
}
|
|
|
|
|
|
|
|
String getImageName() {
|
|
|
|
return imageName
|
|
|
|
}
|
|
|
|
|
|
|
|
boolean isImagePulled() {
|
|
|
|
return imagePulled
|
|
|
|
}
|
|
|
|
|
|
|
|
String getParameters() {
|
|
|
|
return parameters
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|