From 0324993d609712e84e64be914b84f2c7cd277764 Mon Sep 17 00:00:00 2001 From: Matt McEuen Date: Wed, 10 Jun 2020 18:41:39 -0500 Subject: [PATCH] Add an m3 host generator function This PS has a function which constructs a collection of Metal3 BareMetalHost resources, along with associated configuration Secrets. It solves for a couple of things: 1. pulling the nitty gritty details for generating BMH into one reusable place, 2. allowing the site-specific details to be filled in via catalogues of values This function leverages a couple of different plugins in sequence: The airshipctl Replacement plugin, which pulls the site-specific data from the catalogue documents into a Templater plugin configuration; and then the airshipctl Templater plugin, which generates a variable number of BMHs in a data-driven fashion. More details can be found in the README.md in this patchset. Closes: #245 Change-Id: I3ddbd36dc53ea6afbd633098c985f4b28bcbb793 --- manifests/function/hostgenerator-m3/README.md | 37 ++++++++++ .../hostgenerator-m3/hosttemplate.yaml | 69 +++++++++++++++++++ .../hostgenerator-m3/kustomization.yaml | 4 ++ .../hostgenerator-m3/replacements/hosts.yaml | 34 +++++++++ .../replacements/kustomization.yaml | 4 ++ .../bootstrap}/baremetalhost.yaml | 6 +- .../hostgenerator/host-generation.yaml | 10 +++ .../hostgenerator/kustomization.yaml | 9 +++ .../ephemeral/bootstrap/kustomization.yaml | 7 +- .../hostgenerator/host-generation.yaml | 10 +++ .../hostgenerator/kustomization.yaml | 9 +++ .../controlplane/nodes/kustomization.yaml | 6 +- .../baremetalhost/node01/baremetalhost.yaml | 14 ---- .../baremetalhost/node01/kustomization.yaml | 16 ----- .../shared/baremetalhost/node01/networkData | 31 --------- .../baremetalhost/node02/kustomization.yaml | 16 ----- .../shared/baremetalhost/node02/networkData | 29 -------- .../test-site/shared/catalogues/hosts.yaml | 27 ++++++++ .../shared/catalogues/kustomization.yaml | 5 ++ .../shared/catalogues/common-networking.yaml | 39 +++++++++++ .../shared/catalogues/kustomization.yaml | 4 ++ .../plugin/templater/v1alpha1/templater.go | 17 ++++- .../templater/v1alpha1/templater_test.go | 33 +++++++++ playbooks/airship-airshipctl-build-gate.yaml | 16 ++++- tools/deployment/21_systemwide_executable.sh | 3 + tools/deployment/22_test_configs.sh | 4 +- tools/document/build_kustomize_plugin.sh | 22 ++++-- tools/document/validate_site_docs.sh | 21 +++--- zuul.d/jobs.yaml | 2 +- 29 files changed, 370 insertions(+), 134 deletions(-) create mode 100644 manifests/function/hostgenerator-m3/README.md create mode 100644 manifests/function/hostgenerator-m3/hosttemplate.yaml create mode 100644 manifests/function/hostgenerator-m3/kustomization.yaml create mode 100644 manifests/function/hostgenerator-m3/replacements/hosts.yaml create mode 100644 manifests/function/hostgenerator-m3/replacements/kustomization.yaml rename manifests/site/test-site/{shared/baremetalhost/node02 => ephemeral/bootstrap}/baremetalhost.yaml (80%) create mode 100644 manifests/site/test-site/ephemeral/bootstrap/hostgenerator/host-generation.yaml create mode 100644 manifests/site/test-site/ephemeral/bootstrap/hostgenerator/kustomization.yaml create mode 100644 manifests/site/test-site/ephemeral/controlplane/hostgenerator/host-generation.yaml create mode 100644 manifests/site/test-site/ephemeral/controlplane/hostgenerator/kustomization.yaml delete mode 100644 manifests/site/test-site/shared/baremetalhost/node01/baremetalhost.yaml delete mode 100644 manifests/site/test-site/shared/baremetalhost/node01/kustomization.yaml delete mode 100644 manifests/site/test-site/shared/baremetalhost/node01/networkData delete mode 100644 manifests/site/test-site/shared/baremetalhost/node02/kustomization.yaml delete mode 100644 manifests/site/test-site/shared/baremetalhost/node02/networkData create mode 100644 manifests/site/test-site/shared/catalogues/hosts.yaml create mode 100644 manifests/site/test-site/shared/catalogues/kustomization.yaml create mode 100644 manifests/type/gating/shared/catalogues/common-networking.yaml create mode 100644 manifests/type/gating/shared/catalogues/kustomization.yaml diff --git a/manifests/function/hostgenerator-m3/README.md b/manifests/function/hostgenerator-m3/README.md new file mode 100644 index 000000000..80f10fe69 --- /dev/null +++ b/manifests/function/hostgenerator-m3/README.md @@ -0,0 +1,37 @@ +Function: hostgenerator-m3 +========================== + +This function constructs a collection of Metal3 BareMetalHost resources, +along with associated configuration Secrets. It solves for a couple of things: + +1. pulling the nitty gritty details for generating BMH into one reusable place, +2. allowing the site-specific details to be filled in via catalogues of values + +This function leverages a couple of different plugins in sequence: +The airshipctl Replacement plugin, which pulls the site-specific data from +the catalogue documents into a Templater plugin configuration; and then +the airshipctl Templater plugin, which generates a variable number of +BMHs in a data-driven fashion. + +To use this function, do the following: + +* Supply a `common-networking-catalogue`, which outlines things that are + typically common across hosts in a site, such as networking interfaces, + DNS servers, and other networking info. + Example: `manifests/type/gating/shared/catalogues/common-networking.yaml` + +* Supply a `host-catalogue`, which contains host-specific data, such as + IP addresses and BMC information. + Example: `manifests/site/test-site/shared/catalogues/hosts.yaml` + +* Supply a `host-generation-catalogue` for each `phase` that needs to + deploy one or more BMHs. This catalogue simply lists the specific + hosts that should be deployed during that phase. + Example: `manifests/site/test-site/ephemeral/bootstrap/hostgenerator/host-generation.yaml` + +* If any per-host changes need to be made, they can be layered on top as + site- or phase-specific Kustomize patches against the generated + documents. E.g, if one host has a different network interface name, + or if different details need to be used during ISO bootstrapping + and normal deployment. + Example: `manifests/site/test-site/ephemeral/bootstrap/baremetalhost.yaml` diff --git a/manifests/function/hostgenerator-m3/hosttemplate.yaml b/manifests/function/hostgenerator-m3/hosttemplate.yaml new file mode 100644 index 000000000..a1217be67 --- /dev/null +++ b/manifests/function/hostgenerator-m3/hosttemplate.yaml @@ -0,0 +1,69 @@ +apiVersion: airshipit.org/v1alpha1 +kind: Templater +metadata: + name: m3-host-template + +# values: + # hosts: + # (filled in from the comprehensive site-wide host-catalogue) + # hostsToGenerate: + # (filled in with phase-specific host-generation-catalogue) + # commonNetworking: + # (filled in with the type-specific common-networking-catalogue) + +template: | + {{- $envAll := . }} + {{- range .hostsToGenerate }} + {{- $hostName := . }} + {{- $host := index $envAll.hosts $hostName }} + --- + apiVersion: metal3.io/v1alpha1 + kind: BareMetalHost + metadata: + annotations: + labels: + name: {{ $hostName }} + spec: + online: false + bootMACAddress: {{ $host.macAddress }} + networkData: + name: {{ $hostName }}-network-data + namespace: default + bmc: + address: {{ $host.bmcAddress }} + credentialsName: {{ $hostName }}-bmc-secret + --- + apiVersion: v1 + kind: Secret + metadata: + name: {{ $hostName }}-bmc-secret + data: + username: {{ $host.bmcUsername | b64enc }} + password: {{ $host.bmcPassword | b64enc }} + type: Opaque + --- + apiVersion: v1 + kind: Secret + metadata: + name: {{ $hostName }}-network-data + stringData: + networkData: | + links: + {{- range $envAll.commonNetworking.links }} + - + {{ toYaml . | indent 6 }} + {{- if $host.macAddresses }} + ethernet_mac_address: {{ index $host.macAddresses .id }} + {{- end }} + {{- end }} + networks: + {{- range $envAll.commonNetworking.networks }} + - + {{ toYaml . | indent 6 }} + ip_address: {{ index $host.ipAddresses .id }} + {{- end }} + services: + {{ toYaml $envAll.commonNetworking.services | indent 6 }} + type: Opaque + + {{ end -}} diff --git a/manifests/function/hostgenerator-m3/kustomization.yaml b/manifests/function/hostgenerator-m3/kustomization.yaml new file mode 100644 index 000000000..00cb0d9ba --- /dev/null +++ b/manifests/function/hostgenerator-m3/kustomization.yaml @@ -0,0 +1,4 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization +resources: + - hosttemplate.yaml diff --git a/manifests/function/hostgenerator-m3/replacements/hosts.yaml b/manifests/function/hostgenerator-m3/replacements/hosts.yaml new file mode 100644 index 000000000..fd91dbce6 --- /dev/null +++ b/manifests/function/hostgenerator-m3/replacements/hosts.yaml @@ -0,0 +1,34 @@ +# These rules inject host-specific information from the `host-catalogue` +# into the hostgenerator-m3 function's Template plugin config. +apiVersion: airshipit.org/v1alpha1 +kind: ReplacementTransformer +metadata: + name: m3-host-replacements +replacements: +- source: + objref: + name: host-catalogue + fieldref: hosts.m3 + target: + objref: + kind: Templater + name: m3-host-template + fieldrefs: [values.hosts] +- source: + objref: + name: host-generation-catalogue + fieldref: hosts.m3 + target: + objref: + kind: Templater + name: m3-host-template + fieldrefs: [values.hostsToGenerate] +- source: + objref: + name: common-networking-catalogue + fieldref: commonNetworking + target: + objref: + kind: Templater + name: m3-host-template + fieldrefs: [values.commonNetworking] diff --git a/manifests/function/hostgenerator-m3/replacements/kustomization.yaml b/manifests/function/hostgenerator-m3/replacements/kustomization.yaml new file mode 100644 index 000000000..69030f1c9 --- /dev/null +++ b/manifests/function/hostgenerator-m3/replacements/kustomization.yaml @@ -0,0 +1,4 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization +resources: + - hosts.yaml diff --git a/manifests/site/test-site/shared/baremetalhost/node02/baremetalhost.yaml b/manifests/site/test-site/ephemeral/bootstrap/baremetalhost.yaml similarity index 80% rename from manifests/site/test-site/shared/baremetalhost/node02/baremetalhost.yaml rename to manifests/site/test-site/ephemeral/bootstrap/baremetalhost.yaml index 21732713d..7d8282cc8 100644 --- a/manifests/site/test-site/shared/baremetalhost/node02/baremetalhost.yaml +++ b/manifests/site/test-site/ephemeral/bootstrap/baremetalhost.yaml @@ -1,3 +1,4 @@ +# This patches the node02 BMH to be suitable for ephemeral purposes apiVersion: metal3.io/v1alpha1 kind: BareMetalHost metadata: @@ -8,13 +9,8 @@ metadata: name: node02 spec: online: true - bootMACAddress: 00:3b:8b:0c:ec:8b - networkData: - name: node02-network-data - namespace: default bmc: address: redfish+https://localhost:8443/redfish/v1/Systems/air-ephemeral - credentialsName: node02-bmc-secret status: provisioning: # we need this status to make sure, that the host is not going to be diff --git a/manifests/site/test-site/ephemeral/bootstrap/hostgenerator/host-generation.yaml b/manifests/site/test-site/ephemeral/bootstrap/hostgenerator/host-generation.yaml new file mode 100644 index 000000000..665c8ae77 --- /dev/null +++ b/manifests/site/test-site/ephemeral/bootstrap/hostgenerator/host-generation.yaml @@ -0,0 +1,10 @@ +# Site-level, phase-specific lists of hosts to generate +# This is used by the hostgenerator-m3 function to narrow down the site-level +# host-catalogue to just the hosts needed for a particular phase. +apiVersion: airshipit.org/v1alpha1 +kind: VariableCatalogue +metadata: + name: host-generation-catalogue +hosts: + m3: + - node02 diff --git a/manifests/site/test-site/ephemeral/bootstrap/hostgenerator/kustomization.yaml b/manifests/site/test-site/ephemeral/bootstrap/hostgenerator/kustomization.yaml new file mode 100644 index 000000000..8de561b8c --- /dev/null +++ b/manifests/site/test-site/ephemeral/bootstrap/hostgenerator/kustomization.yaml @@ -0,0 +1,9 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization +resources: + - ../../../../../function/hostgenerator-m3 + - ../../../shared/catalogues/ + - host-generation.yaml + +transformers: + - ../../../../../function/hostgenerator-m3/replacements diff --git a/manifests/site/test-site/ephemeral/bootstrap/kustomization.yaml b/manifests/site/test-site/ephemeral/bootstrap/kustomization.yaml index 9bffed6d7..1fee0e73b 100644 --- a/manifests/site/test-site/ephemeral/bootstrap/kustomization.yaml +++ b/manifests/site/test-site/ephemeral/bootstrap/kustomization.yaml @@ -1,5 +1,10 @@ apiVersion: kustomize.config.k8s.io/v1beta1 kind: Kustomization resources: - - ../../shared/baremetalhost/node02 - ../../../../type/gating + +generators: + - hostgenerator + +patchesStrategicMerge: + - baremetalhost.yaml diff --git a/manifests/site/test-site/ephemeral/controlplane/hostgenerator/host-generation.yaml b/manifests/site/test-site/ephemeral/controlplane/hostgenerator/host-generation.yaml new file mode 100644 index 000000000..021bd1a0d --- /dev/null +++ b/manifests/site/test-site/ephemeral/controlplane/hostgenerator/host-generation.yaml @@ -0,0 +1,10 @@ +# Site-level, phase-specific lists of hosts to generate +# This is used by the hostgenerator-m3 function to narrow down the site-level +# host-catalogue to just the hosts needed for a particular phase. +apiVersion: airshipit.org/v1alpha1 +kind: VariableCatalogue +metadata: + name: host-generation-catalogue +hosts: + m3: + - node01 diff --git a/manifests/site/test-site/ephemeral/controlplane/hostgenerator/kustomization.yaml b/manifests/site/test-site/ephemeral/controlplane/hostgenerator/kustomization.yaml new file mode 100644 index 000000000..8de561b8c --- /dev/null +++ b/manifests/site/test-site/ephemeral/controlplane/hostgenerator/kustomization.yaml @@ -0,0 +1,9 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization +resources: + - ../../../../../function/hostgenerator-m3 + - ../../../shared/catalogues/ + - host-generation.yaml + +transformers: + - ../../../../../function/hostgenerator-m3/replacements diff --git a/manifests/site/test-site/ephemeral/controlplane/nodes/kustomization.yaml b/manifests/site/test-site/ephemeral/controlplane/nodes/kustomization.yaml index 96b914263..512dc07c8 100644 --- a/manifests/site/test-site/ephemeral/controlplane/nodes/kustomization.yaml +++ b/manifests/site/test-site/ephemeral/controlplane/nodes/kustomization.yaml @@ -1,6 +1,8 @@ apiVersion: kustomize.config.k8s.io/v1beta1 kind: Kustomization -resources: - - ../../../shared/baremetalhost/node01 + +generators: + - ../hostgenerator + commonLabels: airshipit.org/k8s-role: controlplane-host diff --git a/manifests/site/test-site/shared/baremetalhost/node01/baremetalhost.yaml b/manifests/site/test-site/shared/baremetalhost/node01/baremetalhost.yaml deleted file mode 100644 index 70e8e2682..000000000 --- a/manifests/site/test-site/shared/baremetalhost/node01/baremetalhost.yaml +++ /dev/null @@ -1,14 +0,0 @@ ---- -apiVersion: metal3.io/v1alpha1 -kind: BareMetalHost -metadata: - name: node01 -spec: - bmc: - address: redfish+http://10.23.25.1:8000/redfish/v1/Systems/air-target-1 - credentialsName: node01-bmc - online: false - bootMACAddress: 52:54:00:b6:ed:31 - networkData: - name: node01-netdata - namespace: default diff --git a/manifests/site/test-site/shared/baremetalhost/node01/kustomization.yaml b/manifests/site/test-site/shared/baremetalhost/node01/kustomization.yaml deleted file mode 100644 index bf4a78d64..000000000 --- a/manifests/site/test-site/shared/baremetalhost/node01/kustomization.yaml +++ /dev/null @@ -1,16 +0,0 @@ -apiVersion: kustomize.config.k8s.io/v1beta1 -kind: Kustomization -resources: - - baremetalhost.yaml - -generatorOptions: - disableNameSuffixHash: true - -secretGenerator: - - name: node01-netdata - files: - - networkData - - name: node01-bmc - literals: - - username=root - - password=r00tme diff --git a/manifests/site/test-site/shared/baremetalhost/node01/networkData b/manifests/site/test-site/shared/baremetalhost/node01/networkData deleted file mode 100644 index 2af1a80c6..000000000 --- a/manifests/site/test-site/shared/baremetalhost/node01/networkData +++ /dev/null @@ -1,31 +0,0 @@ -links: -- id: oam0 - name: oam0 - type: phy - ethernet_mac_address: 52:54:00:9b:27:4c - mtu: "1500" -- id: pxe0 - name: pxe0 - type: phy - ethernet_mac_address: 52:54:00:b6:ed:31 - mtu: "1500" -networks: -- id: private-ipv4 - type: ipv4 - link: oam0 - ip_address: 10.23.25.102 - netmask: 255.255.255.0 - routes: - - network: 0.0.0.0 - netmask: 0.0.0.0 - gateway: 10.23.25.1 -- id: private-ipv4 - type: ipv4 - link: pxe0 - ip_address: 10.23.24.102 - netmask: 255.255.255.0 -services: -- address: 8.8.8.8 - type: dns -- address: 8.8.4.4 - type: dns diff --git a/manifests/site/test-site/shared/baremetalhost/node02/kustomization.yaml b/manifests/site/test-site/shared/baremetalhost/node02/kustomization.yaml deleted file mode 100644 index 478d9f62a..000000000 --- a/manifests/site/test-site/shared/baremetalhost/node02/kustomization.yaml +++ /dev/null @@ -1,16 +0,0 @@ -apiVersion: kustomize.config.k8s.io/v1beta1 -kind: Kustomization -resources: - - baremetalhost.yaml - -generatorOptions: - disableNameSuffixHash: true - -secretGenerator: - - name: node02-network-data - files: - - networkData - - name: node02-bmc-secret - literals: - - username=username - - password=password diff --git a/manifests/site/test-site/shared/baremetalhost/node02/networkData b/manifests/site/test-site/shared/baremetalhost/node02/networkData deleted file mode 100644 index c5dc43a58..000000000 --- a/manifests/site/test-site/shared/baremetalhost/node02/networkData +++ /dev/null @@ -1,29 +0,0 @@ -links: - - id: enp0s3 - name: enp0s3 - type: phy - mtu: "1500" - - id: enp0s4 - name: enp0s4 - type: phy - mtu: "1500" -networks: - - id: private-ipv4 - type: ipv4 - link: enp0s3 - ip_address: 10.23.25.101 - netmask: 255.255.255.0 - routes: - - network: 0.0.0.0 - netmask: 0.0.0.0 - gateway: 10.23.25.1 - - id: private-ipv4 - type: ipv4 - link: enp0s4 - ip_address: 10.23.24.101 - netmask: 255.255.255.0 -services: - - address: 8.8.8.8 - type: dns - - address: 8.8.4.4 - type: dns diff --git a/manifests/site/test-site/shared/catalogues/hosts.yaml b/manifests/site/test-site/shared/catalogues/hosts.yaml new file mode 100644 index 000000000..68630208f --- /dev/null +++ b/manifests/site/test-site/shared/catalogues/hosts.yaml @@ -0,0 +1,27 @@ +# Site-level host catalogue. This info feeds the Templater +# kustomize plugin config in the hostgenerator-m3 function. +apiVersion: airshipit.org/v1alpha1 +kind: VariableCatalogue +metadata: + name: host-catalogue +hosts: + m3: + node01: + macAddress: 52:54:00:b6:ed:31 + bmcAddress: redfish+http://10.23.25.1:8000/redfish/v1/Systems/air-target-1 + bmcUsername: root + bmcPassword: r00tme + ipAddresses: + oam-ipv4: 10.23.25.102 + pxe-ipv4: 10.23.24.102 + macAddresses: + oam: 52:54:00:9b:27:4c + pxe: 52:54:00:b6:ed:31 + node02: + macAddress: 00:3b:8b:0c:ec:8b + bmcAddress: redfish+http://10.23.25.2:8000/redfish/v1/Systems/air-target-2 + bmcUsername: username + bmcPassword: password + ipAddresses: + oam-ipv4: 10.23.25.101 + pxe-ipv4: 10.23.24.101 diff --git a/manifests/site/test-site/shared/catalogues/kustomization.yaml b/manifests/site/test-site/shared/catalogues/kustomization.yaml new file mode 100644 index 000000000..23e790c2d --- /dev/null +++ b/manifests/site/test-site/shared/catalogues/kustomization.yaml @@ -0,0 +1,5 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization +resources: + - ../../../../type/gating/shared/catalogues + - hosts.yaml diff --git a/manifests/type/gating/shared/catalogues/common-networking.yaml b/manifests/type/gating/shared/catalogues/common-networking.yaml new file mode 100644 index 000000000..89c751c42 --- /dev/null +++ b/manifests/type/gating/shared/catalogues/common-networking.yaml @@ -0,0 +1,39 @@ +# Type-level networking catalogue. This info feeds the Templater +# kustomize plugin config in the hostgenerator-m3 function. +apiVersion: airshipit.org/v1alpha1 +kind: VariableCatalogue +metadata: + name: common-networking-catalogue +commonNetworking: + links: + - id: oam + name: enp0s3 + type: phy + mtu: "1500" + # ethernet_mac_address: (optional) + - id: pxe + name: enp0s4 + type: phy + mtu: "1500" + # ethernet_mac_address: (optional) + networks: + - id: oam-ipv4 + type: ipv4 + link: oam + # ip_address: + netmask: 255.255.255.0 + routes: + - network: 0.0.0.0 + netmask: 0.0.0.0 + gateway: 10.23.25.1 + - id: pxe-ipv4 + type: ipv4 + link: pxe + # ip_address: + netmask: 255.255.255.0 + services: + - address: 8.8.8.8 + type: dns + - address: 8.8.4.4 + type: dns + diff --git a/manifests/type/gating/shared/catalogues/kustomization.yaml b/manifests/type/gating/shared/catalogues/kustomization.yaml new file mode 100644 index 000000000..420c49366 --- /dev/null +++ b/manifests/type/gating/shared/catalogues/kustomization.yaml @@ -0,0 +1,4 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization +resources: + - common-networking.yaml diff --git a/pkg/document/plugin/templater/v1alpha1/templater.go b/pkg/document/plugin/templater/v1alpha1/templater.go index e89d99be1..add8f0bb8 100644 --- a/pkg/document/plugin/templater/v1alpha1/templater.go +++ b/pkg/document/plugin/templater/v1alpha1/templater.go @@ -48,9 +48,24 @@ func New(_ *environment.AirshipCTLSettings, cfg []byte) (plugtypes.Plugin, error // Run templater plugin func (t *Templater) Run(_ io.Reader, out io.Writer) error { - tmpl, err := template.New("tmpl").Funcs(sprig.TxtFuncMap()).Parse(t.Template) + funcMap := sprig.TxtFuncMap() + funcMap["toYaml"] = toYaml + tmpl, err := template.New("tmpl").Funcs(funcMap).Parse(t.Template) if err != nil { return err } return tmpl.Execute(out, t.Values) } + +// Render input yaml as output yaml +// This function is from the Helm project: +// https://github.com/helm/helm +// Copyright The Helm Authors +func toYaml(v interface{}) string { + data, err := yaml.Marshal(v) + if err != nil { + // Swallow errors inside of a template. + return "" + } + return string(data) +} diff --git a/pkg/document/plugin/templater/v1alpha1/templater_test.go b/pkg/document/plugin/templater/v1alpha1/templater_test.go index 7d2ee80ba..19d83053d 100644 --- a/pkg/document/plugin/templater/v1alpha1/templater_test.go +++ b/pkg/document/plugin/templater/v1alpha1/templater_test.go @@ -77,6 +77,39 @@ spec: cfg: ` apiVersion: airshipit.org/v1alpha1 kind: Templater +metadata: + name: notImportantHere +values: + test: + of: + - toYaml +template: | + {{ toYaml . -}} +`, + expectedOut: `test: + of: + - toYaml +`, + }, + { + cfg: ` +apiVersion: airshipit.org/v1alpha1 +kind: Templater +metadata: + name: notImportantHere +values: + test: + of: + - badToYamlInput +template: | + {{ toYaml ignorethisbadinput -}} +`, + expectedOut: ``, + }, + { + cfg: ` +apiVersion: airshipit.org/v1alpha1 +kind: Templater metadata: name: notImportantHere template: | diff --git a/playbooks/airship-airshipctl-build-gate.yaml b/playbooks/airship-airshipctl-build-gate.yaml index 797db240a..0665f11a9 100644 --- a/playbooks/airship-airshipctl-build-gate.yaml +++ b/playbooks/airship-airshipctl-build-gate.yaml @@ -36,6 +36,12 @@ include_role: name: install-kustomize + # Installs kustomize plugin functionality needed for rendering below + - name: install airshipctl + shell: | + cd {{ local_src_dir | default(zuul.project.src_dir) }} + ./tools/deployment/21_systemwide_executable.sh + - name: make sure serve directory exists file: dest: "{{ serve_dir }}" @@ -57,22 +63,26 @@ - name: get BareMetalHost objects shell: | set -e - kustomize build {{ airship_config_manifest_directory }}/{{ airship_config_site_path }}/ephemeral/controlplane | + kustomize build --enable_alpha_plugins \ + {{ airship_config_manifest_directory }}/{{ airship_config_site_path }}/ephemeral/controlplane | kustomize config grep "kind=BareMetalHost" register: bmh_command failed_when: "bmh_command.stdout == ''" environment: + KUSTOMIZE_PLUGIN_HOME: "{{ ansible_env.HOME }}/.airship/kustomize-plugins" KUSTOMIZE_ENABLE_ALPHA_COMMANDS: "true" - set_fact: bmh: "{{ bmh_command.stdout | from_yaml_all | list }}" - name: get network configuration for BareMetalHost objects shell: | set -e - kustomize build {{ airship_config_manifest_directory }}/{{ airship_config_site_path }}/ephemeral/controlplane | + kustomize build --enable_alpha_plugins \ + {{ airship_config_manifest_directory }}/{{ airship_config_site_path }}/ephemeral/controlplane | kustomize config grep "metadata.name={{ item.spec.networkData.name }}" register: netdata_command failed_when: "netdata_command.stdout == ''" environment: + KUSTOMIZE_PLUGIN_HOME: "{{ ansible_env.HOME }}/.airship/kustomize-plugins" KUSTOMIZE_ENABLE_ALPHA_COMMANDS: "true" with_items: "{{ bmh }}" - name: get links from network data per BareMetalHost object @@ -81,7 +91,7 @@ {{ netdata_command.results | map(attribute='stdout')| map('from_yaml') | - map(attribute='data.networkData') | map('b64decode') | map('from_yaml') | + map(attribute='stringData.networkData') | map('from_yaml') | map(attribute='links') | list }} - name: define list of VM mac addresses diff --git a/tools/deployment/21_systemwide_executable.sh b/tools/deployment/21_systemwide_executable.sh index cc23832f5..48583cad1 100755 --- a/tools/deployment/21_systemwide_executable.sh +++ b/tools/deployment/21_systemwide_executable.sh @@ -34,3 +34,6 @@ else echo "Airshipctl version" airshipctl version fi + +echo "Install airshipctl as kustomize plugins" +AIRSHIPCTL="/usr/local/bin/airshipctl" ./tools/document/build_kustomize_plugin.sh diff --git a/tools/deployment/22_test_configs.sh b/tools/deployment/22_test_configs.sh index 1a472cdaf..b86510c48 100755 --- a/tools/deployment/22_test_configs.sh +++ b/tools/deployment/22_test_configs.sh @@ -42,8 +42,8 @@ export AIRSHIP_CONFIG_EPHEMERAL_IP=${IP_Ephemeral:-"10.23.25.101"} export AIRSHIP_CONFIG_CLIENT_CERT_DATA=$(cat tools/deployment/certificates/airship_config_client_cert_data| base64 -w0) export AIRSHIP_CONFIG_CLIENT_KEY_DATA=$(cat tools/deployment/certificates/airship_config_client_key_data| base64 -w0) -#Remove and Create .airship folder -rm -rf $HOME/.airship +# Remove the contents of the .airship folder, preserving the kustomize plugin directory +rm -rf $HOME/.airship/*config* mkdir -p $HOME/.airship echo "Generate ~/.airship/config and ~/.airship/kubeconfig" diff --git a/tools/document/build_kustomize_plugin.sh b/tools/document/build_kustomize_plugin.sh index de8a4787d..8849b2594 100755 --- a/tools/document/build_kustomize_plugin.sh +++ b/tools/document/build_kustomize_plugin.sh @@ -32,14 +32,26 @@ fi rm -rf ${KUSTOMIZE_PLUGIN_HOME}/airshipit.org # copy our plugin to the PLUGIN_ROOT, and give a kustomzie-friendly wrapper -PLUGIN_PATH=${KUSTOMIZE_PLUGIN_HOME}/airshipit.org/v1alpha1/replacementtransformer -mkdir -p ${PLUGIN_PATH} -cat > ${PLUGIN_PATH}/ReplacementTransformer < ${PLUGIN_PATH}/${PLUGIN} < ${PLUGIN_PATH}/VariableCatalogue < ${TMP}/crds.yaml - if [ -s ${TMP}/crds.yaml ]; then - ${KUBECTL} --context ${CONTEXT} --kubeconfig ${KUBECONFIG} apply -f ${TMP}/crds.yaml + # step 1: actually apply all crds in the phase + # TODO: will need to loop through phases in order, eventually + # e.g., load CRDs from initinfra first, so they're present when validating later phases + ${ACTL} phase render ${phase} -k CustomResourceDefinition > ${TMP}/crds.yaml + if [ -s ${TMP}/crds.yaml ]; then + ${KUBECTL} --context ${CONTEXT} --kubeconfig ${KUBECONFIG} apply -f ${TMP}/crds.yaml + fi + + # step 2: dry-run the entire phase + ${ACTL} phase apply --dry-run ${phase} fi - - # step 2: dry-run the entire phase - ${ACTL} phase apply --dry-run ${phase} done fi done diff --git a/zuul.d/jobs.yaml b/zuul.d/jobs.yaml index 8ff175a7b..e526329be 100644 --- a/zuul.d/jobs.yaml +++ b/zuul.d/jobs.yaml @@ -90,7 +90,7 @@ site_name: test-site gate_scripts: - ./tools/deployment/01_install_kubectl.sh - - ./tools/deployment/21_systemwide_executable.sh + # 21_systemwide_executable.sh is run in the build-gate pre-run above - ./tools/deployment/22_test_configs.sh - ./tools/deployment/24_build_ephemeral_iso.sh - ./tools/deployment/25_deploy_ephemeral_node.sh