|
40 | 40 | import org.csanchez.jenkins.plugins.kubernetes.model.KeyValueEnvVar;
|
41 | 41 | import org.csanchez.jenkins.plugins.kubernetes.model.TemplateEnvVar;
|
42 | 42 | import org.csanchez.jenkins.plugins.kubernetes.pod.yaml.Merge;
|
| 43 | +import org.csanchez.jenkins.plugins.kubernetes.pod.yaml.Overrides; |
43 | 44 | import org.csanchez.jenkins.plugins.kubernetes.pod.yaml.YamlMergeStrategy;
|
44 | 45 | import org.csanchez.jenkins.plugins.kubernetes.volumes.ConfigMapVolume;
|
45 | 46 | import org.csanchez.jenkins.plugins.kubernetes.volumes.EmptyDirVolume;
|
@@ -584,6 +585,62 @@ public void testInheritsFromWithYaml(boolean directConnection) throws Exception
|
584 | 585 | validateContainers(pod, slave, directConnection);
|
585 | 586 | }
|
586 | 587 |
|
| 588 | + @Test |
| 589 | + public void inheritYamlMergeStrategy() throws Exception { |
| 590 | + PodTemplate parent = new PodTemplate(); |
| 591 | + parent.setYaml("apiVersion: v1\n" + "kind: Pod\n" |
| 592 | + + "spec:\n" |
| 593 | + + " tolerations:\n" |
| 594 | + + " - key: \"reservedFor\"\n" |
| 595 | + + " operator: Exists\n" |
| 596 | + + " effect: NoSchedule"); |
| 597 | + |
| 598 | + PodTemplate child = new PodTemplate(); |
| 599 | + child.setYaml("spec:\n"); |
| 600 | + child.setInheritFrom("parent"); |
| 601 | + setupStubs(); |
| 602 | + |
| 603 | + PodTemplate result; |
| 604 | + Pod pod; |
| 605 | + |
| 606 | + // Default behavior (backward compatible) |
| 607 | + parent.setYamlMergeStrategy(merge()); |
| 608 | + parent.setInheritYamlMergeStrategy(false); |
| 609 | + result = combine(parent, child); |
| 610 | + pod = new PodTemplateBuilder(result, slave).build(); |
| 611 | + assertThat(pod.getSpec().getTolerations(), hasSize(0)); |
| 612 | + |
| 613 | + // Inherit merge strategy with merge |
| 614 | + parent.setYamlMergeStrategy(merge()); |
| 615 | + parent.setInheritYamlMergeStrategy(true); |
| 616 | + result = combine(parent, child); |
| 617 | + pod = new PodTemplateBuilder(result, slave).build(); |
| 618 | + assertThat(pod.getSpec().getTolerations(), hasSize(1)); |
| 619 | + |
| 620 | + // Inherit merge strategy with override |
| 621 | + parent.setYamlMergeStrategy(overrides()); |
| 622 | + parent.setInheritYamlMergeStrategy(true); |
| 623 | + result = combine(parent, child); |
| 624 | + pod = new PodTemplateBuilder(result, slave).build(); |
| 625 | + assertThat(pod.getSpec().getTolerations(), hasSize(0)); |
| 626 | + |
| 627 | + // Override merge strategy with overrides |
| 628 | + parent.setYamlMergeStrategy(merge()); |
| 629 | + parent.setInheritYamlMergeStrategy(true); |
| 630 | + child.setYamlMergeStrategy(overrides()); |
| 631 | + result = combine(parent, child); |
| 632 | + pod = new PodTemplateBuilder(result, slave).build(); |
| 633 | + assertThat(pod.getSpec().getTolerations(), hasSize(0)); |
| 634 | + |
| 635 | + // Override overrides strategy with merge |
| 636 | + parent.setYamlMergeStrategy(overrides()); |
| 637 | + parent.setInheritYamlMergeStrategy(true); |
| 638 | + child.setYamlMergeStrategy(merge()); |
| 639 | + result = combine(parent, child); |
| 640 | + pod = new PodTemplateBuilder(result, slave).build(); |
| 641 | + assertThat(pod.getSpec().getTolerations(), hasSize(1)); |
| 642 | + } |
| 643 | + |
587 | 644 | @Test
|
588 | 645 | public void yamlMergeContainers() throws Exception {
|
589 | 646 | PodTemplate parent = new PodTemplate();
|
@@ -935,6 +992,10 @@ private String loadYamlFile(String s) throws IOException {
|
935 | 992 | return new String(IOUtils.toByteArray(getClass().getResourceAsStream(s)));
|
936 | 993 | }
|
937 | 994 |
|
| 995 | + private YamlMergeStrategy overrides() { |
| 996 | + return new Overrides(); |
| 997 | + } |
| 998 | + |
938 | 999 | private YamlMergeStrategy merge() {
|
939 | 1000 | return new Merge();
|
940 | 1001 | }
|
|
0 commit comments