|
| 1 | +package org.csanchez.jenkins.plugins.kubernetes; |
| 2 | + |
| 3 | +import static org.junit.Assert.assertEquals; |
| 4 | + |
| 5 | +import java.util.logging.Level; |
| 6 | +import java.util.logging.Logger; |
| 7 | +import org.junit.Rule; |
| 8 | +import org.junit.Test; |
| 9 | +import org.jvnet.hudson.test.JenkinsRule; |
| 10 | +import org.jvnet.hudson.test.LoggerRule; |
| 11 | + |
| 12 | +public class NonConfigurableKubernetesCloudTest { |
| 13 | + |
| 14 | + @Rule |
| 15 | + public JenkinsRule j = new JenkinsRule(); |
| 16 | + |
| 17 | + @Rule |
| 18 | + public LoggerRule logs = new LoggerRule() |
| 19 | + .record( |
| 20 | + Logger.getLogger(NonConfigurableKubernetesCloudTest.class |
| 21 | + .getPackage() |
| 22 | + .getName()), |
| 23 | + Level.ALL); |
| 24 | + |
| 25 | + @Test |
| 26 | + public void configRoundTrip() throws Exception { |
| 27 | + // create a cloud with a template |
| 28 | + var cloud = new KubernetesCloud("kubernetes"); |
| 29 | + var podTemplate = new PodTemplate(); |
| 30 | + podTemplate.setName("test-template"); |
| 31 | + podTemplate.setLabel("test"); |
| 32 | + cloud.addTemplate(podTemplate); |
| 33 | + var jenkins = j.jenkins; |
| 34 | + jenkins.clouds.add(cloud); |
| 35 | + jenkins.save(); |
| 36 | + var readOnly = new NonConfigurableKubernetesCloud("NonConfigurableKubernetes", cloud); |
| 37 | + readOnly.removeTemplate(podTemplate); // should not remove anything |
| 38 | + var podTemplate2 = new PodTemplate(); |
| 39 | + podTemplate2.setName("test-template-read-only"); |
| 40 | + podTemplate2.setLabel("test-read-only"); |
| 41 | + readOnly.addTemplate(podTemplate2); |
| 42 | + jenkins.clouds.add(readOnly); |
| 43 | + jenkins.save(); |
| 44 | + assertEquals(2, jenkins.clouds.size()); // sanity check |
| 45 | + assertEquals(1, readOnly.getTemplates().size()); // remove should not have removed anything, nor should have add |
| 46 | + readOnly.getTemplates().forEach(t -> { |
| 47 | + if (t.getName().equals("test-template-read-only")) { |
| 48 | + throw new RuntimeException("Template should not be added"); |
| 49 | + } |
| 50 | + }); |
| 51 | + } |
| 52 | +} |
0 commit comments