Skip to content
This repository has been archived by the owner on Nov 1, 2022. It is now read-only.

Commit

Permalink
Bump to kubeyaml 0.5.1 to fix (F)HR updating
Browse files Browse the repository at this point in the history
kubeyaml 0.5.1 has a fix for updating images that include ports in
(Flux)HelmRelease manifests. So: bump that in the Dockerfile and shim
(`/bin/kubeyaml`), and add a test that it does account for such images
when updating.

Side issue in update_test.go: calling `t.Parallel()` _before_ invoking
the test case meant that the closed-over loop variable could be
reassigned before the test case was run.
  • Loading branch information
squaremo committed Nov 13, 2018
1 parent 73256e9 commit e1e62b7
Show file tree
Hide file tree
Showing 3 changed files with 60 additions and 10 deletions.
2 changes: 1 addition & 1 deletion bin/kubeyaml
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
#!/bin/sh
docker run --rm -i quay.io/squaremo/kubeyaml:0.5.0 "$@"
docker run --rm -i quay.io/squaremo/kubeyaml:0.5.1 "$@"
66 changes: 58 additions & 8 deletions cluster/kubernetes/update_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,13 +49,14 @@ func TestUpdates(t *testing.T) {
{"single quotes", case8resource, case8containers, case8image, case8, case8out},
{"in multidoc", case9resource, case9containers, case9image, case9, case9out},
{"in kubernetes List resource", case10resource, case10containers, case10image, case10, case10out},
{"FluxHelmRelease (simple image encoding)", case11resource, case11containers, case11image, case11, case11out},
{"FluxHelmRelease (multi image encoding)", case12resource, case12containers, case12image, case12, case12out},
{"initContainer", case13resource, case13containers, case13image, case13, case13out},
{"FluxHelmRelease (v1alpha2; simple image encoding)", case11resource, case11containers, case11image, case11, case11out},
{"FluxHelmRelease (v1alpha2; multi image encoding)", case12resource, case12containers, case12image, case12, case12out},
{"HelmRelease (v1beta1; image with port number)", case13resource, case13containers, case13image, case13, case13out},
{"initContainer", case14resource, case14containers, case14image, case14, case14out},
} {
t.Run(c.name, func(t *testing.T) {
t.Parallel()
testUpdate(t, c)
t.Parallel()
})
}
}
Expand Down Expand Up @@ -872,6 +873,55 @@ spec:
`

const case13 = `---
apiVersion: flux.weave.works/v1beta1
kind: HelmRelease
metadata:
name: mariadb
namespace: maria
spec:
chart:
repository: https://example.com/charts
name: mariadb
version: 1.1.2
values:
mariadb:
image: localhost:5000/mariadb
tag: 10.1.30-r1
persistence:
enabled: false
workProperly: true
sidecar:
image: sidecar:v1
`

const case13resource = "maria:helmrelease/mariadb"
const case13image = "localhost:5000/mariadb:10.1.33"

var case13containers = []string{"mariadb"}

const case13out = `---
apiVersion: flux.weave.works/v1beta1
kind: HelmRelease
metadata:
name: mariadb
namespace: maria
spec:
chart:
repository: https://example.com/charts
name: mariadb
version: 1.1.2
values:
mariadb:
image: localhost:5000/mariadb
tag: 10.1.33
persistence:
enabled: false
workProperly: true
sidecar:
image: sidecar:v1
`

const case14 = `---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
Expand All @@ -888,12 +938,12 @@ spec:
image: 'weaveworks/weave-kube:2.2.0'
`

const case13resource = "default:deployment/weave"
const case13image = "weaveworks/weave-kube:2.2.1"
const case14resource = "default:deployment/weave"
const case14image = "weaveworks/weave-kube:2.2.1"

var case13containers = []string{"weave"}
var case14containers = []string{"weave"}

const case13out = `---
const case14out = `---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
Expand Down
2 changes: 1 addition & 1 deletion docker/Dockerfile.flux
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ LABEL maintainer="Weaveworks <[email protected]>" \
ENTRYPOINT [ "/sbin/tini", "--", "fluxd" ]

# Get the kubeyaml binary (files) and put them on the path
COPY --from=quay.io/squaremo/kubeyaml:0.5.0 /usr/lib/kubeyaml /usr/lib/kubeyaml/
COPY --from=quay.io/squaremo/kubeyaml:0.5.1 /usr/lib/kubeyaml /usr/lib/kubeyaml/
ENV PATH=/bin:/usr/bin:/usr/local/bin:/usr/lib/kubeyaml

COPY ./kubeconfig /root/.kube/config
Expand Down

0 comments on commit e1e62b7

Please sign in to comment.