From 261600930f2dfc6715d93e5d93d265080466eb04 Mon Sep 17 00:00:00 2001 From: Soule BA Date: Fri, 12 Jul 2024 23:14:24 +0200 Subject: [PATCH 1/2] Automate helm chart docs generation If implemented the helm customization file will be generated automatically. A makefile is created with several targets in order to fetch the needed chart and generate an `rst` doc based on a template. Signed-off-by: Soule BA --- .gitignore | 6 +- .helmdocsignore | 1 + Makefile | 50 ++ docs/customizations/helm.rst | 1106 ++++++++++++++++++---------------- templates/helm.rst.gotmpl | 495 +++++++++++++++ 5 files changed, 1130 insertions(+), 528 deletions(-) create mode 100644 .helmdocsignore create mode 100644 Makefile create mode 100644 templates/helm.rst.gotmpl diff --git a/.gitignore b/.gitignore index 89cb592..e3c4b44 100644 --- a/.gitignore +++ b/.gitignore @@ -14,4 +14,8 @@ _*/ # automatically generated files *.7z *.tmp -*latest* \ No newline at end of file +*latest* + +# local builds +build +bin diff --git a/.helmdocsignore b/.helmdocsignore new file mode 100644 index 0000000..c862a62 --- /dev/null +++ b/.helmdocsignore @@ -0,0 +1 @@ +build/_output/helmcharts/network-operator/charts diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..751a81f --- /dev/null +++ b/Makefile @@ -0,0 +1,50 @@ +# Package related +TOOLSDIR=$(CURDIR)/hack/tools/bin +BUILDDIR=$(CURDIR)/build/_output + + +# If gobin not set, create one on ./build and add to path. +ifeq (,$(shell go env GOBIN)) +GOBIN=$(BUILD_DIR)/gobin +else +GOBIN=$(shell go env GOBIN) +endif +export PATH:=$(GOBIN):${PATH} + +$(TOOLSDIR): + @mkdir -p $@ + +$(BUILDDIR): ; $(info Creating build directory...) + mkdir -p $@ + +# Paths to download the helm chart to. +HELM_CHART_DEP_ROOT ?= $(BUILDDIR)/helmcharts +# Helm chart version and url +HELM_CHART_VERSION ?= 24.4.1 +NGC_HELM_CHART_URL ?= https://helm.ngc.nvidia.com/nvidia/charts + +build-docs: helm-docs + ./repo.sh docs + +# helm-docs is used to generate helm chart documentation +HELM_DOCS_PKG := github.com/norwoodj/helm-docs/cmd/helm-docs +HELM_DOCS_VER := v1.14.2 +HELM_DOCS_BIN := helm-docs +HELM_DOCS_PATH = $(abspath $(TOOLSDIR)/$(HELM_DOCS_BIN)) +HELM_DOCS = $(abspath $(TOOLSDIR)/$(HELM_DOCS_BIN))-$(HELM_DOCS_VER) +$(HELM_DOCS): | $(TOOLSDIR) + $(call go-install-tool,$(HELM_DOCS_PKG),$(HELM_DOCS_BIN),$(HELM_DOCS_VER)) + $Q ln $(HELM_DOCS) $(HELM_DOCS_PATH) + +# go-install-tool will 'go install' a go module $1 with version $3 and install it with the name $2-$3 to $TOOLSDIR. +define go-install-tool + $Q echo "Installing $(2)-$(3) to $(TOOLSDIR)" + $Q GOBIN=$(TOOLSDIR) go install $(1)@$(3) + $Q mv $(TOOLSDIR)/$(2) $(TOOLSDIR)/$(2)-$(3) +endef + +# Generate helm chart documentation in a reStructuredText format. +helm-docs: $(HELM_DOCS) + mkdir -p ${HELM_CHART_DEP_ROOT} && cd ${HELM_CHART_DEP_ROOT} && curl -sL ${NGC_HELM_CHART_URL}/network-operator-${HELM_CHART_VERSION}.tgz | tar xz + $(HELM_DOCS) --output-file=../../../../docs/customizations/helm.rst --ignore-file=.helmdocsignore --template-files=./templates/helm.rst.gotmpl ${HELM_CHART_DEP_ROOT}/network-operator + diff --git a/docs/customizations/helm.rst b/docs/customizations/helm.rst index 5271126..c3af874 100644 --- a/docs/customizations/helm.rst +++ b/docs/customizations/helm.rst @@ -37,102 +37,155 @@ General Parameters .. list-table:: :header-rows: 1 + * - Name - Type - Default - Description + * - deployCR + - bool + - `false` + - + * - imagePullSecrets + - list + - `[]` + - + * - nfd.deployNodeFeatureRules + - bool + - `true` + - + * - nfd.enabled + - bool + - `true` + - * - operator.admissionController.enabled - - Bool - - False - - Deploy with admission controller + - bool + - `false` + - * - operator.admissionController.useCertManager - - Bool - - True - - Use cert-manager for generating self-signed certificate - * - operator.admissionController.certificate.tlsCrt - - String - - "" - - External TLS certificate. Ignored if cert-manager is used - * - operator.admissionController.certificate.tlsKey - - String - - "" - - External TLS private key. Ignored if cert-manager is used - * - nfd.enabled - - Bool - - True - - Deploy Node Feature Discovery - * - nfd.deployNodeFeatureRules - - Bool - - True - - Deploy Node Feature Rules to label the nodes + - bool + - `true` + - + * - operator.affinity.nodeAffinity.preferredDuringSchedulingIgnoredDuringExecution[0].preference.matchExpressions[0].key + - string + - `"node-role.kubernetes.io/master"` + - + * - operator.affinity.nodeAffinity.preferredDuringSchedulingIgnoredDuringExecution[0].preference.matchExpressions[0].operator + - string + - `"In"` + - + * - operator.affinity.nodeAffinity.preferredDuringSchedulingIgnoredDuringExecution[0].preference.matchExpressions[0].values[0] + - string + - `""` + - + * - operator.affinity.nodeAffinity.preferredDuringSchedulingIgnoredDuringExecution[0].weight + - int + - `1` + - + * - operator.affinity.nodeAffinity.preferredDuringSchedulingIgnoredDuringExecution[1].preference.matchExpressions[0].key + - string + - `"node-role.kubernetes.io/control-plane"` + - + * - operator.affinity.nodeAffinity.preferredDuringSchedulingIgnoredDuringExecution[1].preference.matchExpressions[0].operator + - string + - `"In"` + - + * - operator.affinity.nodeAffinity.preferredDuringSchedulingIgnoredDuringExecution[1].preference.matchExpressions[0].values[0] + - string + - `""` + - + * - operator.affinity.nodeAffinity.preferredDuringSchedulingIgnoredDuringExecution[1].weight + - int + - `1` + - + * - operator.cniBinDirectory + - string + - `"/opt/cni/bin"` + - + * - operator.fullnameOverride + - string + - `""` + - + * - operator.image + - string + - `"network-operator"` + - + * - operator.nameOverride + - string + - `""` + - + * - operator.nodeSelector + - object + - `{}` + - + * - operator.repository + - string + - `"nvcr.io/nvidia/cloud-native"` + - + * - operator.resources.limits.cpu + - string + - `"500m"` + - + * - operator.resources.limits.memory + - string + - `"128Mi"` + - + * - operator.resources.requests.cpu + - string + - `"5m"` + - + * - operator.resources.requests.memory + - string + - `"64Mi"` + - + * - operator.tolerations[0].effect + - string + - `"NoSchedule"` + - + * - operator.tolerations[0].key + - string + - `"node-role.kubernetes.io/master"` + - + * - operator.tolerations[0].operator + - string + - `"Equal"` + - + * - operator.tolerations[0].value + - string + - `""` + - + * - operator.tolerations[1].effect + - string + - `"NoSchedule"` + - + * - operator.tolerations[1].key + - string + - `"node-role.kubernetes.io/control-plane"` + - + * - operator.tolerations[1].operator + - string + - `"Equal"` + - + * - operator.tolerations[1].value + - string + - `""` + - + * - operator.useDTK + - bool + - `true` + - * - sriovNetworkOperator.enabled - - Bool - - False - - Deploy SR-IOV Network Operator - * - sriovNetworkOperator.configDaemonNodeSelectorExtra - - List - - node-role.kubernetes.io/worker: "" - - Additional values for SR-IOV Config Daemon nodes selector + - bool + - `false` + - + * - test.pf + - string + - `"ens2f0"` + - * - upgradeCRDs - - Bool - - True - - Enable CRDs upgrade with helm pre-install and pre-upgrade hooks - * - operator.repository - - String - - nvcr.io/nvidia - - Network Operator image repository - * - operator.image - - String - - network-operator - - Network Operator image name - * - operator.tag - - String - - None - - Network Operator image tag. If set to ``None``, the chart's ``appVersion`` will be used - * - operator.imagePullSecrets - - List - - [] - - An optional list of references to secrets to use for pulling Network Operator image - * - operator.cniBinDirectory - - String - - /opt/cni/bin - - Directory, where CNI binaries will be deployed on the nodes. Setting for the sriov-network-operator is set with ``sriov-network-operator.cniBinPath`` parameter. Note that the CNI bin directory should be aligned with the CNI bin directory in the container runtime. - * - operator.resources - - Yaml - - | resources: - | limits: - | cpu: 500m - | memory: 128Mi - | requests: - | cpu: 5m - | memory: 64Mi - - Optional `resource requests and limits `_ for the operator - * - imagePullSecrets - - List - - [] - - An optional list of references to secrets to use for pulling any of the Network Operator image, if it is not overridden - * - deployCR - - Bool - - False - - Deploy ``NicClusterPolicy`` custom resource according to the provided parameters - * - nodeAffinity - - Yaml - - | requiredDuringSchedulingIgnoredDuringExecution: - | nodeSelectorTerms: - | - matchExpressions: - | - key: node-role.kubernetes.io/master - | operator: DoesNotExist - | - key: node-role.kubernetes.io/control-plane - | operator: DoesNotExist - - Configure node affinity settings for Network Operator components - * - tolerations - - Yaml - - "" - - Set additional tolerations for various Daemonsets deployed by the network operator, e.g. whereabouts, multus, cni-plugins. - * - useDTK - - Bool - - True - - Enable the use of Driver ToolKit to compile OFED drivers (OpenShift only) + - bool + - `true` + - ------------------------------ ImagePullSecrets customization @@ -162,11 +215,97 @@ The NFD labels required by the Network Operator and GPU Operator: * - feature.node.kubernetes.io/pci-10de.present - Nodes containing NVIDIA GPU hardware +======================= +Node Feature Discovery +======================= + +Node Feature Discovery Helm chart customization options can be found `here `__. Following is a list of overriden values by NVIDIA Operator Helm Chart: + +.. list-table:: + :header-rows: 1 + + * - Name + - Type + - Default in NVIDIA Network Operator + - Notes + * - node-feature-discovery.enableNodeFeatureApi + - bool + - `true` + - + * - node-feature-discovery.master.config.extraLabelNs[0] + - string + - `"nvidia.com"` + - + * - node-feature-discovery.master.serviceAccount.create + - bool + - `true` + - + * - node-feature-discovery.master.serviceAccount.name + - string + - `"node-feature-discovery"` + - + * - node-feature-discovery.worker.config.sources.pci.deviceClassWhitelist[0] + - string + - `"0300"` + - + * - node-feature-discovery.worker.config.sources.pci.deviceClassWhitelist[1] + - string + - `"0302"` + - + * - node-feature-discovery.worker.config.sources.pci.deviceLabelFields[0] + - string + - `"vendor"` + - + * - node-feature-discovery.worker.serviceAccount.create + - bool + - `false` + - + * - node-feature-discovery.worker.serviceAccount.name + - string + - `"node-feature-discovery"` + - + * - node-feature-discovery.worker.tolerations[0].effect + - string + - `"NoSchedule"` + - + * - node-feature-discovery.worker.tolerations[0].key + - string + - `"node-role.kubernetes.io/master"` + - + * - node-feature-discovery.worker.tolerations[0].operator + - string + - `"Exists"` + - + * - node-feature-discovery.worker.tolerations[1].effect + - string + - `"NoSchedule"` + - + * - node-feature-discovery.worker.tolerations[1].key + - string + - `"node-role.kubernetes.io/control-plane"` + - + * - node-feature-discovery.worker.tolerations[1].operator + - string + - `"Exists"` + - + * - node-feature-discovery.worker.tolerations[2].effect + - string + - `"NoSchedule"` + - + * - node-feature-discovery.worker.tolerations[2].key + - string + - `"nvidia.com/gpu"` + - + * - node-feature-discovery.worker.tolerations[2].operator + - string + - `"Exists"` + - + ======================= SR-IOV Network Operator ======================= -SR-IOV Network Operator Helm chart customization options can be found `here `_. Following is a list of overriden values by NVIDIA Operator Helm Chart: +SR-IOV Network Operator Helm chart customization options can be found `here `__. Following is a list of overriden values by NVIDIA Operator Helm Chart: .. list-table:: :header-rows: 1 @@ -175,33 +314,81 @@ SR-IOV Network Operator Helm chart customization options can be found `here `_ passed to the NVIDIA OFED driver image - * - ofedDriver.startupProbe.initialDelaySeconds - - Int - - 10 - - NVIDIA DOCA Driver startup probe initial delay - * - ofedDriver.startupProbe.periodSeconds - - Int - - 20 - - NVIDIA DOCA Driver startup probe interval + - `"v0.0.2"` + - * - ofedDriver.livenessProbe.initialDelaySeconds - - Int - - 30 - - NVIDIA DOCA Driver liveness probe initial delay + - int + - `30` + - * - ofedDriver.livenessProbe.periodSeconds - - Int - - 30 - - NVIDIA DOCA Driver liveness probe interval + - int + - `30` + - * - ofedDriver.readinessProbe.initialDelaySeconds - - Int - - 10 - - NVIDIA DOCA Driver readiness probe initial delay + - int + - `10` + - * - ofedDriver.readinessProbe.periodSeconds - - Int - - 30 - - NVIDIA DOCA Driver readiness probe interval + - int + - `30` + - + * - ofedDriver.repoConfig.name + - string + - `""` + - + * - ofedDriver.repository + - string + - `"nvcr.io/nvidia/mellanox"` + - + * - ofedDriver.startupProbe.initialDelaySeconds + - int + - `10` + - + * - ofedDriver.startupProbe.periodSeconds + - int + - `20` + - + * - ofedDriver.terminationGracePeriodSeconds + - int + - `300` + - * - ofedDriver.upgradePolicy.autoUpgrade - - Bool - - true - - A global switch for the automatic upgrade feature. If set to false, all other options are ignored. - * - ofedDriver.upgradePolicy.maxParallelUpgrades - - Int - - 1 - - The amount of nodes that can be upgraded in parallel. 0 means no limit. All nodes will be upgraded in parallel. - * - ofedDriver.upgradePolicy.safeLoad - - Bool - - false - - Cordon and drain (if enabled) a node before loading the driver on it, requires ``ofedDriver.initContainer`` to be enabled and ``ofedDriver.upgradePolicy.autoUpgrade`` to be true + - bool + - `true` + - + * - ofedDriver.upgradePolicy.drain.deleteEmptyDir + - bool + - `true` + - * - ofedDriver.upgradePolicy.drain.enable - - Bool - - true - - Options for node drain (``kubectl drain``) before driver reload, if auto upgrade is enabled. + - bool + - `true` + - * - ofedDriver.upgradePolicy.drain.force - - Bool - - true - - Use force drain of pods + - bool + - `true` + - * - ofedDriver.upgradePolicy.drain.podSelector - - String - - "" - - Pod selector to specify which pods will be drained from the node. An empty selector means all pods. + - string + - `""` + - * - ofedDriver.upgradePolicy.drain.timeoutSeconds - - Int - - 300 - - Number of seconds to wait for pod eviction - * - ofedDriver.upgradePolicy.drain.deleteEmptyDir - - Bool - - false - - Delete pods local storage - * - ofedDriver.upgradePolicy.waitForCompletion.podSelector - - String - - Not set - - Specifies a label selector for the pods to wait for completion before starting the driver upgrade - * - ofedDriver.upgradePolicy.waitForCompletion.timeoutSeconds - int - - Not set - - Specify the length of time in seconds to wait before giving up for workload to finish. Zero means infinite - * - ofedDriver.containerResources - - List - - Not set - - Optional `resource requests and limits `_ and limits for the ``mofed-container`` - * - ofedDriver.forcePrecompiled - - Bool - - false - - Fail Mellanox OFED deployment if precompiled OFED driver container image does not exists + - `300` + - + * - ofedDriver.upgradePolicy.maxParallelUpgrades + - int + - `1` + - + * - ofedDriver.upgradePolicy.safeLoad + - bool + - `false` + - + * - ofedDriver.upgradePolicy.waitForCompletion + - string + - `nil` + - + * - ofedDriver.version + - string + - `"24.04-0.6.6.0-0"` + - =============================================== NVIDIA DOCA Driver Driver Environment Variables @@ -424,38 +594,37 @@ RDMA Shared Device Plugin - Default - Description * - rdmaSharedDevicePlugin.deploy - - Bool - - true - - Deploy RDMA shared device plugin - * - rdmaSharedDevicePlugin.repository - - String - - nvcr.io/nvidia/cloud-native - - RDMA shared device plugin image repository + - bool + - `true` + - * - rdmaSharedDevicePlugin.image - - String - - k8s-rdma-shared-dev-plugin - - RDMA shared device plugin image name - * - rdmaSharedDevicePlugin.version - - String - - |k8s-rdma-shared-dev-plugin-version| - - RDMA shared device plugin version - * - rdmaSharedDevicePlugin.imagePullSecrets - - List - - [] - - An optional list of references to secrets to use for pulling any of the RDMA Shared device plugin image - * - rdmaSharedDevicePlugin.resources - - List - - See below - - RDMA shared device plugin resources + - string + - `"k8s-rdma-shared-dev-plugin"` + - + * - rdmaSharedDevicePlugin.repository + - string + - `"ghcr.io/mellanox"` + - + * - rdmaSharedDevicePlugin.resources[0].name + - string + - `"rdma_shared_device_a"` + - + * - rdmaSharedDevicePlugin.resources[0].rdmaHcaMax + - int + - `63` + - + * - rdmaSharedDevicePlugin.resources[0].vendors[0] + - string + - `"15b3"` + - * - rdmaSharedDevicePlugin.useCdi - - Bool - - false - - | Enable Container Device Interface (CDI) mode. - | **NOTE**: NVIDIA Network Operator does not configure container runtime to enable CDI - * - rdmaSharedDevicePlugin.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``rdma-shared-dp`` container + - bool + - `false` + - + * - rdmaSharedDevicePlugin.version + - string + - `"1.4.0"` + - ========================================== RDMA Device Plugin Resource Configurations @@ -489,39 +658,33 @@ SR-IOV Network Device Plugin - Default - Description * - sriovDevicePlugin.deploy - - Bool - - false - - Deploy SR-IOV Network device plugin - * - sriovDevicePlugin.repository - - String - - ghcr.io/k8snetworkplumbingwg - - SR-IOV Network device plugin image repository + - bool + - `false` + - * - sriovDevicePlugin.image - - String - - sriov-network-device-plugin - - SR-IOV Network device plugin image name - * - sriovDevicePlugin.version - - String - - |sriov-device-plugin-version| - - | SR-IOV Network device plugin version - | For ARM-based deployments, it is recommended to use the ``ghcr.io/k8snetworkplumbingwg/sriov-network-device-plugin:v3.6.2-amd64`` image - * - sriovDevicePlugin.imagePullSecrets - - List - - [] - - An optional list of references to secrets to use for pulling any of the SR-IOV Network device plugin image - * - sriovDevicePlugin.resources - - List - - See below - - SR-IOV Network device plugin resources + - string + - `"sriov-network-device-plugin"` + - + * - sriovDevicePlugin.repository + - string + - `"ghcr.io/k8snetworkplumbingwg"` + - + * - sriovDevicePlugin.resources[0].name + - string + - `"hostdev"` + - + * - sriovDevicePlugin.resources[0].vendors[0] + - string + - `"15b3"` + - * - sriovDevicePlugin.useCdi - - Bool - - false - - | Enable Container Device Interface (CDI) mode. - | **NOTE**: NVIDIA Network Operator does not configure container runtime to enable CD. - * - sriovDevicePlugin.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``kube-sriovdp`` container + - bool + - `false` + - + * - sriovDevicePlugin.version + - string + - `"e6ead1e8f76a407783430ee2666b403db2d76f64"` + - =================================================== SR-IOV Network Device Plugin Resource Configuration @@ -557,44 +720,36 @@ ib-kubernetes provides a daemon that works in conjunction with the `SR-IOV Netwo - Description * - ibKubernetes.deploy - bool - - false - - Deploy IB Kubernetes - * - ibKubernetes.repository - - string - - ghcr.io/mellanox - - IB Kubernetes image repository + - `false` + - * - ibKubernetes.image - string - - ib-kubernetes - - IB Kubernetes image name - * - ibKubernetes.version + - `"ib-kubernetes"` + - + * - ibKubernetes.pKeyGUIDPoolRangeEnd - string - - |ib-kubernetes-version| - - IB Kubernetes version - * - ibKubernetes.imagePullSecrets - - list - - [] - - An optional list of references to secrets used for pulling any of the IB Kubernetes images - * - ibKubernetes.periodicUpdateSeconds - - int - - 5 - - Interval of periodic update in seconds + - `"02:FF:FF:FF:FF:FF:FF:FF"` + - * - ibKubernetes.pKeyGUIDPoolRangeStart - string - - 02:00:00:00:00:00:00:00 - - Minimal available GUID value to be allocated for the pod - * - ibKubernetes.pKeyGUIDPoolRangeEnd + - `"02:00:00:00:00:00:00:00"` + - + * - ibKubernetes.periodicUpdateSeconds + - int + - `5` + - + * - ibKubernetes.repository - string - - 02:FF:FF:FF:FF:FF:FF:FF - - Maximal available GUID value to be allocated for the pod + - `"ghcr.io/mellanox"` + - * - ibKubernetes.ufmSecret - string - - See below - - Name of the Secret with the NVIDIA UFM access credentials, deployed in advance - * - ibKubernetes.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``ib-kubernetes`` container + - `""` + - + * - ibKubernetes.version + - string + - `"v1.0.2"` + - ========== UFM Secret @@ -621,9 +776,11 @@ IB Kubernetes must access `NVIDIA UFM `_ is recommended to be used on large-scale deployments of the NVIDIA Network Operator. .. list-table:: :header-rows: 1 @@ -632,10 +789,33 @@ Secondary Network - Type - Default - Description - * - secondaryNetwork.deploy - - Bool - - true - - Deploy Secondary Network + * - nvIpam.deploy + - bool + - `false` + - + * - nvIpam.enableWebhook + - bool + - `false` + - + * - nvIpam.image + - string + - `"nvidia-k8s-ipam"` + - + * - nvIpam.repository + - string + - `"ghcr.io/mellanox"` + - + * - nvIpam.version + - string + - `"v0.1.2"` + - + +.. warning:: + Supported X.509 certificate management system should be available in the cluster to enable the validation webhook. Currently, the supported systems are `certmanager `_ and `Openshift certificate management `_. + +================= +Secondary Network +================= Specifies components to deploy in order to facilitate a secondary network in Kubernetes. It consists of the following optionally deployed components: @@ -644,10 +824,6 @@ Specifies components to deploy in order to facilitate a secondary network in Kub * IPAM CNI: Currently only `Whereabout IPAM CNI `_ is supported as a part of the secondaryNetwork section. NVIDIA-IPAM is configured separately. * `IPoIB CNI `_: Allows the user to create IPoIB child link and move it to the pod -========== -CNI Plugin -========== - .. list-table:: :header-rows: 1 @@ -656,188 +832,73 @@ CNI Plugin - Default - Description * - secondaryNetwork.cniPlugins.deploy - - Bool - - true - - Deploy CNI Plugins Secondary Network + - bool + - `true` + - * - secondaryNetwork.cniPlugins.image - - String - - plugins - - CNI Plugins image name + - string + - `"plugins"` + - * - secondaryNetwork.cniPlugins.repository - - String - - ghcr.io/k8snetworkplumbingwg - - CNI Plugins image repository + - string + - `"ghcr.io/k8snetworkplumbingwg"` + - * - secondaryNetwork.cniPlugins.version - - String - - |cni-plugins-version|-amd64 - - CNI Plugins image version - * - secondaryNetwork.cniPlugins.imagePullSecrets - - List - - [] - - An optional list of references to secrets to use for pulling any of the CNI Plugins images - * - secondaryNetwork.cniPlugins.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``cni-plugins`` container - -========== -Multus CNI -========== - -.. list-table:: - :header-rows: 1 - - * - Name - - Type - - Default - - Description - * - secondaryNetwork.multus.deploy - - Bool - - true - - Deploy Multus Secondary Network - * - secondaryNetwork.multus.image - - String - - multus-cni - - Multus image name - * - secondaryNetwork.multus.repository - - String - - ghcr.io/k8snetworkplumbingwg - - Multus image repository - * - secondaryNetwork.multus.version - - String - - |multus-version| - - Multus image version - * - secondaryNetwork.multus.imagePullSecrets - - List - - [] - - An optional list of references to secrets to use for pulling any of the Multus images - * - secondaryNetwork.multus.config - - String - - "" - - Multus CNI config. If empty, the config will be automatically generated from the CNI configuration file of the master plugin (the first file in lexicographical order in the cni-confg-dir). - * - secondaryNetwork.multus.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``kube-multus`` container - -========= -IPoIB CNI -========= - -.. list-table:: - :header-rows: 1 - - * - Name - - Type - - Default - - Description - * - secondaryNetwork.ipoib.deploy - - Bool - - false - - Deploy IPoIB CNI - * - secondaryNetwork.ipoib.image - - String - - ipoib-cni - - IPoIB CNI image name - * - secondaryNetwork.ipoib.repository - - String - - "" - - IPoIB CNI image repository - * - secondaryNetwork.ipoib.version - - String - - |ipoib-cni-version| - - IPoIB CNI image version - * - secondaryNetwork.ipoib.imagePullSecrets - - List - - [] - - An optional list of references to secrets to use for pulling any of the IPoIB CNI images - * - secondaryNetwork.ipoib.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``ipoib-cni`` container - -=============== -IPAM CNI Plugin -=============== - -.. list-table:: - :header-rows: 1 - - * - Name - - Type - - Default - - Description + - string + - `"v1.3.0"` + - + * - secondaryNetwork.deploy + - bool + - `true` + - * - secondaryNetwork.ipamPlugin.deploy - - Bool - - false - - Deploy IPAM CNI Plugin Secondary Network + - bool + - `true` + - * - secondaryNetwork.ipamPlugin.image - - String - - whereabouts - - IPAM CNI Plugin image name + - string + - `"whereabouts"` + - * - secondaryNetwork.ipamPlugin.repository - - String - - ghcr.io/k8snetworkplumbingwg - - IPAM CNI Plugin image repository + - string + - `"ghcr.io/k8snetworkplumbingwg"` + - * - secondaryNetwork.ipamPlugin.version - - String - - |whereabouts-version|-amd64 - - IPAM CNI Plugin image version - * - secondaryNetwork.ipamPlugin.imagePullSecrets - - List - - [] - - An optional list of references to secrets to use for pulling any of the IPAM CNI Plugin images - * - secondaryNetwork.ipamPlugin.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``whereabouts`` container - -================== -NVIDIA IPAM Plugin -================== - -`NVIDIA IPAM Plugin `_ is recommended to be used on large-scale deployments of the NVIDIA Network Operator. - -.. list-table:: - :header-rows: 1 - - * - Name - - Type - - Default - - Description - * - nvIpam.deploy - - Bool - - true - - Deploy NVIDIA IPAM Plugin - * - nvIpam.image - - String - - nvidia-k8s-ipam - - NVIDIA IPAM Plugin image name - * - nvIpam.repository - - String - - ghcr.io/mellanox - - NVIDIA IPAM Plugin image repository - * - nvIpam.version - - String - - |nvidia-ipam-version| - - NVIDIA IPAM Plugin image version - * - nvIpam.imagePullSecrets - - List - - [] - - An optional list of references to secrets to use for pulling any of the Plugin images - * - nvIpam.enableWebhook - - Bool - - false - - Enable deployment of the validataion webhook for IPPool CRD - * - nvIpam.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``nv-ipam-node`` and ``nv-ipam-controller`` containers - - - -.. warning:: - Supported X.509 certificate management system should be available in the cluster to enable the validation webhook. Currently, the supported systems are `certmanager `_ and `Openshift certificate management `_. + - string + - `"v0.7.0"` + - + * - secondaryNetwork.ipoib.deploy + - bool + - `false` + - + * - secondaryNetwork.ipoib.image + - string + - `"ipoib-cni"` + - + * - secondaryNetwork.ipoib.repository + - string + - `"ghcr.io/mellanox"` + - + * - secondaryNetwork.ipoib.version + - string + - `"428715a57c0b633e48ec7620f6e3af6863149ccf"` + - + * - secondaryNetwork.multus.deploy + - bool + - `true` + - + * - secondaryNetwork.multus.image + - string + - `"multus-cni"` + - + * - secondaryNetwork.multus.repository + - string + - `"ghcr.io/k8snetworkplumbingwg"` + - + * - secondaryNetwork.multus.version + - string + - `"v3.9.3"` + - ============================ NVIDIA NIC Feature Discovery @@ -853,25 +914,21 @@ NVIDIA NIC Feature Discovery - Default - Description * - nicFeatureDiscovery.deploy - - Bool - - false - - Deploy NVIDIA NIC Feature Discovery + - bool + - `false` + - * - nicFeatureDiscovery.image - - String - - nic-feature-discovery - - NVIDIA NIC Feature Discovery image name + - string + - `"nic-feature-discovery"` + - * - nicFeatureDiscovery.repository - - String - - ghcr.io/mellanox - - NVIDIA NIC Feature Discovery repository + - string + - `"ghcr.io/mellanox"` + - * - nicFeatureDiscovery.version - - String - - |nic-feature-discovery-version| - - NVIDIA NIC Feature Discovery image version - * - nicFeatureDiscovery.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``nic-feature-discovery`` container + - string + - `"v0.0.1"` + - ====================== DOCA Telemetry Service @@ -886,25 +943,21 @@ DOCA Telemetry Service - Default - Description * - docaTelemetryService.deploy - - Bool - - false - - Deploy DOCA Telemetry Service + - bool + - `false` + - * - docaTelemetryService.image - - String - - doca_telemetry - - DOCA Telemetry Service image name + - string + - `"doca_telemetry"` + - * - docaTelemetryService.repository - - String - - nvcr.io/nvidia/doca - - DOCA Telemetry Service image repository + - string + - `"nvcr.io/nvidia/doca"` + - * - docaTelemetryService.version - - String - - |doca-telemetry-version| - - DOCA Telemetry Service image version - * - docaTelemetryService.containerResources - - List - - Not set - - Optional `resource requests and limits `_ for the ``doca-telemetry-service`` container + - string + - `"1.16.5-doca2.6.0-host"` + - ======================= Helm customization file @@ -913,7 +966,6 @@ Helm customization file .. warning:: Since several parameters should be provided when creating custom resources during operator deployment, it is recommended to use a configuration file. While it is possible to override the parameters via CLI, we recommend to avoid the use of CLI arguments in favor of a configuration file. - .. code-block:: bash $ helm install -f ./values.yaml -n nvidia-network-operator --create-namespace --wait nvidia/network-operator network-operator diff --git a/templates/helm.rst.gotmpl b/templates/helm.rst.gotmpl new file mode 100644 index 0000000..4e7e99e --- /dev/null +++ b/templates/helm.rst.gotmpl @@ -0,0 +1,495 @@ +.. license-header + SPDX-FileCopyrightText: Copyright (c) 2024 NVIDIA CORPORATION & AFFILIATES. All rights reserved. + SPDX-License-Identifier: Apache-2.0 + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. + +.. headings # #, * *, =, -, ^, " + +.. include:: ../common/vars.rst + +******************************** +Helm Chart Customization Options +******************************** + +There are various customizations you can do to tailor the deployment of the Network Operator to your cluster needs. You +can find those below. + +.. contents:: + :depth: 2 + :local: + :backlinks: none + +================== +General Parameters +================== + +.. list-table:: + :header-rows: 1 + + {{- define "chart.generalParamsvaluesTable" }} + * - Name + - Type + - Default + - Description + {{- range .Values }} + {{- if (not (or (hasPrefix "sriov-network-operator" .Key) (hasPrefix "ofedDriver" .Key) + (hasPrefix "rdmaSharedDevicePlugin" .Key) (hasPrefix "sriovDevicePlugin" .Key) + (hasPrefix "ibKubernetes" .Key) (hasPrefix "nvIpam" .Key) (hasPrefix "secondaryNetwork" .Key) + (hasPrefix "docaTelemetryService" .Key) (hasPrefix "nicFeatureDiscovery" .Key) + (hasPrefix "node-feature-discovery" .Key))) }} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + + {{ template "chart.generalParamsvaluesTable" . }} + +------------------------------ +ImagePullSecrets customization +------------------------------ + +To provide `imagePullSecrets`` object references, you need to specify them using a following structure: + +.. code-block:: bash + + imagePullSecrets: + - image-pull-secret1 + - image-pull-secret2 + +========== +NFD labels +========== + +The NFD labels required by the Network Operator and GPU Operator: + +.. list-table:: + :header-rows: 1 + + * - Label + - Location + * - feature.node.kubernetes.io/pci-15b3.present + - Nodes containing NVIDIA Networking hardware + * - feature.node.kubernetes.io/pci-10de.present + - Nodes containing NVIDIA GPU hardware + +======================= +Node Feature Discovery +======================= + +Node Feature Discovery Helm chart customization options can be found `here `__. Following is a list of overriden values by NVIDIA Operator Helm Chart: + +.. list-table:: + :header-rows: 1 + + {{- define "chart.nfdOpValuesTable" }} + * - Name + - Type + - Default in NVIDIA Network Operator + - Notes + {{- range .Values }} + {{- if hasPrefix "node-feature-discovery" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.nfdOpValuesTable" . }} + +======================= +SR-IOV Network Operator +======================= + +SR-IOV Network Operator Helm chart customization options can be found `here `__. Following is a list of overriden values by NVIDIA Operator Helm Chart: + +.. list-table:: + :header-rows: 1 + + {{- define "chart.sriovValuesTable" }} + * - Name + - Type + - Default in NVIDIA Network Operator + - Notes + {{- range .Values }} + {{- if hasPrefix "sriov-network-operator" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.sriovValuesTable" . }} + +=================== +Container Resources +=================== + +Optional `requests and limits `_ can be configured for each container of the sub-resources deployed by the Network Operator by setting the parameter ``containerResources``. + +For example: + +.. code-block:: yaml + + containerResources: + - name: "mofed-container" + requests: + cpu: "200m" + memory: "150Mi" + limits: + cpu: "300m" + memory: "300Mi" + +=================== + NVIDIA DOCA Driver +=================== + +.. list-table:: + :header-rows: 1 + + {{- define "chart.ofedValuesTable" }} + * - Name + - Type + - Default + - Description + {{- range .Values }} + {{- if hasPrefix "ofedDriver" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.ofedValuesTable" . }} + +=============================================== +NVIDIA DOCA Driver Driver Environment Variables +=============================================== + +The following are special environment variables supported by the NVIDIA DOCA Driver container to configure its behavior: + +.. list-table:: + :header-rows: 1 + + * - Name + - Default + - Description + * - CREATE_IFNAMES_UDEV + - | * "true” for Ubuntu 20.04, RHEL v8.x and OCP <= v4.13. + | * "false" for newer OS. + - Create an udev rule to preserve "old-style" path based netdev names e.g enp3s0f0 + * - UNLOAD_STORAGE_MODULES + - "false" + - | Unload host storage modules prior to loading NVIDIA DOCA Driver modules: + | * ib_isert + | * nvme_rdma + | * nvmet_rdma + | * rpcrdma + | * xprtrdma + | * ib_srpt + * - ENABLE_NFSRDMA + - "false" + - Enable loading of NFS related storage modules from a NVIDIA DOCA Driver container + * - RESTORE_DRIVER_ON_POD_TERMINATION + - "true" + - Restore host drivers when a container + +In addition, it is possible to specify any environment variables to be exposed to the NVIDIA DOCA Driver container, such as the standard "HTTP_PROXY", "HTTPS_PROXY", "NO_PROXY". + +.. warning:: + CREATE_IFNAMES_UDEV is set automatically by the Network Operator, depending on the Operating System of the worker nodes in the cluster (the cluster is assumed to be homogenous). + +To set these variables, change them into Helm values. For example: + +.. code-block:: yaml + + ofedDriver: + env: + - name: RESTORE_DRIVER_ON_POD_TERMINATION + value: "true" + - name: UNLOAD_STORAGE_MODULES + value: "true" + - name: CREATE_IFNAMES_UDEV + value: "true" + +The variables can also be configured directly via the NicClusterPolicy CRD. + +========================= +RDMA Shared Device Plugin +========================= + +.. list-table:: + :header-rows: 1 + + {{- define "chart.rdmaDpValuesTable" }} + * - Name + - Type + - Default + - Description + {{- range .Values }} + {{- if hasPrefix "rdmaSharedDevicePlugin" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.rdmaDpValuesTable" . }} + +========================================== +RDMA Device Plugin Resource Configurations +========================================== + +These configurations consist of a list of RDMA resources, each with a name and a selector of RDMA capable network devices to be associated with the resource. Refer to `RDMA Shared Device Plugin Selectors `_ for supported selectors. + +.. code-block:: yaml + + resources: + - name: rdma_shared_device_a + vendors: [15b3] + deviceIDs: [1017] + ifNames: [enp5s0f0] + rdmaHcaMax: 63 + - name: rdma_shared_device_b + vendors: [15b3] + deviceIDs: [1017] + ifNames: [ib0, ib1] + rdmaHcaMax: 63 + +============================ +SR-IOV Network Device Plugin +============================ + +.. list-table:: + :header-rows: 1 + + {{- define "chart.sriovDpValuesTable" }} + * - Name + - Type + - Default + - Description + {{- range .Values }} + {{- if hasPrefix "sriovDevicePlugin" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.sriovDpValuesTable" . }} + +=================================================== +SR-IOV Network Device Plugin Resource Configuration +=================================================== + +Consists of a list of RDMA resources, each with a name and a selector of RDMA capable network devices to be associated with the resource. Refer to `SR-IOV Network Device Plugin Selectors `_ for supported selectors. + +.. code-block:: yaml + + resources: + - name: hostdev + vendors: [15b3] + - name: ethernet_rdma + vendors: [15b3] + linkTypes: [ether] + - name: sriov_rdma + vendors: [15b3] + devices: [1018] + drivers: [mlx5_ib] + +============= +IB Kubernetes +============= + +ib-kubernetes provides a daemon that works in conjunction with the `SR-IOV Network Device Plugin `_. It acts on Kubernetes pod object changes (Create/Update/Delete), reading the pod's network annotation, fetching its corresponding network CRD and reading the PKey. This is done in order to add the newly generated GUID or the predefined GUID in the GUID field of the CRD cni-args to that PKey for pods with ``mellanox.infiniband.app`` annotation. + +.. list-table:: + :header-rows: 1 + + {{- define "chart.ibValuesTable" }} + * - Name + - Type + - Default + - Description + {{- range .Values }} + {{- if hasPrefix "ibKubernetes" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.ibValuesTable" . }} + +========== +UFM Secret +========== + +IB Kubernetes must access `NVIDIA UFM `_ in order to manage pods' GUIDs. To provide its credentials, the secret of the following format should be deployed in advance: + +.. code-block:: yaml + + apiVersion: v1 + kind: Secret + metadata: + name: ib-kubernetes-ufm-secret + namespace: nvidia-network-operator + stringData: + UFM_USERNAME: "admin" + UFM_PASSWORD: "123456" + UFM_ADDRESS: "ufm-hostname" + UFM_HTTP_SCHEMA: "" + UFM_PORT: "" + data: + UFM_CERTIFICATE: "" + +.. warning:: + The InfiniBand Fabric manages a single pool of GUIDs. In order to use IB Kubernetes in different clusters, different GUID ranges must be specified to avoid collisions. + +================== +NVIDIA IPAM Plugin +================== + +`NVIDIA IPAM Plugin `_ is recommended to be used on large-scale deployments of the NVIDIA Network Operator. + +.. list-table:: + :header-rows: 1 + + {{- define "chart.nvipamValuesTable" }} + * - Name + - Type + - Default + - Description + {{- range .Values }} + {{- if hasPrefix "nvIpam" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.nvipamValuesTable" . }} + +.. warning:: + Supported X.509 certificate management system should be available in the cluster to enable the validation webhook. Currently, the supported systems are `certmanager `_ and `Openshift certificate management `_. + +================= +Secondary Network +================= + +Specifies components to deploy in order to facilitate a secondary network in Kubernetes. It consists of the following optionally deployed components: + +* `Multus-CNI `_: Delegate CNI plugin to support secondary networks in Kubernetes +* CNI plugins: Currently only `containernetworking-plugins `_ is supported +* IPAM CNI: Currently only `Whereabout IPAM CNI `_ is supported as a part of the secondaryNetwork section. NVIDIA-IPAM is configured separately. +* `IPoIB CNI `_: Allows the user to create IPoIB child link and move it to the pod + +.. list-table:: + :header-rows: 1 + + {{- define "chart.secNetworkValuesTable" }} + * - Name + - Type + - Default + - Description + {{- range .Values }} + {{- if hasPrefix "secondaryNetwork" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.secNetworkValuesTable" . }} + +============================ +NVIDIA NIC Feature Discovery +============================ + +`NVIDIA NIC Feature Discovery `_ leverages `Node Feature Discovery `_ to advertise NIC specific labels on K8s Node objects. + +.. list-table:: + :header-rows: 1 + + {{- define "chart.nfdValuesTable" }} + * - Name + - Type + - Default + - Description + {{- range .Values }} + {{- if hasPrefix "nicFeatureDiscovery" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.nfdValuesTable" . }} + +====================== +DOCA Telemetry Service +====================== +`DOCA Telemetry Service `_ exports metrics from NVIDIA NICs on K8s Nodes. + +.. list-table:: + :header-rows: 1 + + {{- define "chart.docaValuesTable" }} + * - Name + - Type + - Default + - Description + {{- range .Values }} + {{- if hasPrefix "docaTelemetryService" .Key}} + * - {{ .Key }} + - {{ .Type }} + - {{ if .Default }}{{ .Default }}{{ else }}{{ "" }}{{ end }} + - {{ if .Description }}{{ .Description }}{{ else }}{{ .AutoDescription }}{{ end }} + {{- end }} + {{- end }} + {{- end }} + +{{ template "chart.docaValuesTable" . }} + +======================= +Helm customization file +======================= + +.. warning:: + Since several parameters should be provided when creating custom resources during operator deployment, it is recommended to use a configuration file. While it is possible to override the parameters via CLI, we recommend to avoid the use of CLI arguments in favor of a configuration file. + + +.. code-block:: bash + + $ helm install -f ./values.yaml -n nvidia-network-operator --create-namespace --wait nvidia/network-operator network-operator From db7b27f3db49d3ef1af6b02095d618ae59c7eec5 Mon Sep 17 00:00:00 2001 From: Soule BA Date: Thu, 1 Aug 2024 11:57:15 +0200 Subject: [PATCH 2/2] Add a target to build helm-docs from a branch Signed-off-by: Soule BA --- Makefile | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/Makefile b/Makefile index 751a81f..a4e5305 100644 --- a/Makefile +++ b/Makefile @@ -17,14 +17,13 @@ $(TOOLSDIR): $(BUILDDIR): ; $(info Creating build directory...) mkdir -p $@ +BRANCH ?= master # Paths to download the helm chart to. HELM_CHART_DEP_ROOT ?= $(BUILDDIR)/helmcharts # Helm chart version and url HELM_CHART_VERSION ?= 24.4.1 -NGC_HELM_CHART_URL ?= https://helm.ngc.nvidia.com/nvidia/charts - -build-docs: helm-docs - ./repo.sh docs +NGC_HELM_CHART_URL ?= https://helm.ngc.nvidia.com/nvidia/charts/network-operator-${HELM_CHART_VERSION}.tgz +BRANCH_HELM_CHART_URL ?= https://github.com/Mellanox/network-operator/archive/refs/heads/${BRANCH}.tar.gz # helm-docs is used to generate helm chart documentation HELM_DOCS_PKG := github.com/norwoodj/helm-docs/cmd/helm-docs @@ -43,8 +42,20 @@ define go-install-tool $Q mv $(TOOLSDIR)/$(2) $(TOOLSDIR)/$(2)-$(3) endef +download-ngc-helm-chart: + mkdir -p ${HELM_CHART_DEP_ROOT} && cd ${HELM_CHART_DEP_ROOT} \ + && curl -sL ${NGC_HELM_CHART_URL} | tar -xz + +download-branch-helm-chart: + mkdir -p ${HELM_CHART_DEP_ROOT} \ + && curl -sL ${BRANCH_HELM_CHART_URL} \ + | tar -xz -C ${HELM_CHART_DEP_ROOT} \ + --strip-components 2 network-operator-${BRANCH}/deployment/network-operator + # Generate helm chart documentation in a reStructuredText format. helm-docs: $(HELM_DOCS) - mkdir -p ${HELM_CHART_DEP_ROOT} && cd ${HELM_CHART_DEP_ROOT} && curl -sL ${NGC_HELM_CHART_URL}/network-operator-${HELM_CHART_VERSION}.tgz | tar xz - $(HELM_DOCS) --output-file=../../../../docs/customizations/helm.rst --ignore-file=.helmdocsignore --template-files=./templates/helm.rst.gotmpl ${HELM_CHART_DEP_ROOT}/network-operator + $(HELM_DOCS) --output-file=../../../../docs/customizations/helm.rst --ignore-file=.helmdocsignore --template-files=./templates/helm.rst.gotmpl ${HELM_CHART_DEP_ROOT} + +ngc-helm-docs: download-ngc-helm-chart helm-docs +branch-helm-docs: download-branch-helm-chart helm-docs