Skip to content
This repository has been archived by the owner on May 16, 2023. It is now read-only.

[metricbeat] use deprecated kube-state-metrics config when existing #624

Merged
merged 11 commits into from
May 28, 2020
Merged
9 changes: 9 additions & 0 deletions BREAKING_CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,14 @@ Metricbeat is now using dedicated values for daemonset and deployment config.
The old values are still working but are now deprecated. See [#572][] for more
details.

Warning: When upgrading Metricbeat while using custom `metricbeatConfig` value
for `kube-state-metrics-metricbeat.yml`, Metricbeat deployment fails with
`missing field accessing 'metricbeat.modules.0.hosts.0' (source:'metricbeat.yml')`.

In this case `metricbeatConfig.kube-state-metrics-metricbeat.yml` value should
be migrated to `deployment.metricbeatConfig.metricbeat.yml`. See [#623][] for
more details.

## 6.8.9 - 2020/05/13

See [7.7.0 Breaking changes](#770---20200513)
Expand Down Expand Up @@ -164,6 +172,7 @@ volumeClaimTemplate:
[#568]: https://github.com/elastic/helm-charts/pull/568
[#572]: https://github.com/elastic/helm-charts/pull/572
[#621]: https://github.com/elastic/helm-charts/pull/621
[#623]: https://github.com/elastic/helm-charts/pull/623
[container input]: https://www.elastic.co/guide/en/beats/filebeat/7.7/filebeat-input-container.html
[docker input]: https://www.elastic.co/guide/en/beats/filebeat/7.7/filebeat-input-docker.html
[elastic helm repo]: https://helm.elastic.co
Expand Down
4 changes: 4 additions & 0 deletions metricbeat/templates/deployment.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,10 @@ spec:
image: "{{ .Values.image }}:{{ .Values.imageTag }}"
imagePullPolicy: "{{ .Values.imagePullPolicy }}"
args:
{{- if index .Values "metricbeatConfig" "kube-state-metrics-metricbeat.yml" }}
- "-c"
- "/usr/share/metricbeat/kube-state-metrics-metricbeat.yml"
{{- end }}
- "-e"
- "-E"
- "http.enabled=true"
Expand Down
51 changes: 40 additions & 11 deletions metricbeat/tests/metricbeat_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -537,48 +537,77 @@ def test_adding_in_deprecated_metricbeat_config():
nestedkey: value
dot.notation: test

other-config.yml: |
kube-state-metrics-metricbeat.yml: |
hello = world
"""
r = helm_template(config)
c = r["configmap"][name + "-config"]["data"]

assert "metricbeat.yml" in c
assert "other-config.yml" in c
assert "kube-state-metrics-metricbeat.yml" in c

assert "nestedkey: value" in c["metricbeat.yml"]
assert "dot.notation: test" in c["metricbeat.yml"]

assert "hello = world" in c["other-config.yml"]
assert "hello = world" in c["kube-state-metrics-metricbeat.yml"]

d = r["daemonset"][name]["spec"]["template"]["spec"]
daemonset = r["daemonset"][name]["spec"]["template"]["spec"]

assert {
"configMap": {"name": name + "-config", "defaultMode": 0o600},
"name": project + "-config",
} in d["volumes"]
} in daemonset["volumes"]
assert {
"mountPath": "/usr/share/metricbeat/metricbeat.yml",
"name": project + "-config",
"subPath": "metricbeat.yml",
"readOnly": True,
} in d["containers"][0]["volumeMounts"]
} in daemonset["containers"][0]["volumeMounts"]
assert {
"mountPath": "/usr/share/metricbeat/other-config.yml",
"mountPath": "/usr/share/metricbeat/kube-state-metrics-metricbeat.yml",
"name": project + "-config",
"subPath": "other-config.yml",
"subPath": "kube-state-metrics-metricbeat.yml",
"readOnly": True,
} in d["containers"][0]["volumeMounts"]
} in daemonset["containers"][0]["volumeMounts"]

assert (
"configChecksum"
in r["daemonset"][name]["spec"]["template"]["metadata"]["annotations"]
)

deployment = r["deployment"][name + "-metrics"]["spec"]["template"]["spec"]

assert {
"configMap": {"name": name + "-config", "defaultMode": 0o600},
"name": project + "-config",
} in deployment["volumes"]
assert {
"mountPath": "/usr/share/metricbeat/metricbeat.yml",
"name": project + "-config",
"subPath": "metricbeat.yml",
"readOnly": True,
} in deployment["containers"][0]["volumeMounts"]
assert {
"mountPath": "/usr/share/metricbeat/kube-state-metrics-metricbeat.yml",
"name": project + "-config",
"subPath": "kube-state-metrics-metricbeat.yml",
"readOnly": True,
} in deployment["containers"][0]["volumeMounts"]
assert ("/usr/share/metricbeat/kube-state-metrics-metricbeat.yml") in deployment[
"containers"
][0]["args"]

assert (
"configChecksum"
in r["deployment"][name + "-metrics"]["spec"]["template"]["metadata"][
"annotations"
]
)


def test_adding_a_secret_mount():
config = """
daemonset:
daemonset:
secretMounts:
- name: elastic-certificates
secretName: elastic-certificates-name
Expand Down Expand Up @@ -614,7 +643,7 @@ def test_adding_a_secret_mount():
} not in r["deployment"][name + "-metrics"]["spec"]["template"]["spec"]["volumes"]

config = """
deployment:
deployment:
secretMounts:
- name: elastic-certificates
secretName: elastic-certificates-name
Expand Down