Make the replica transformer kind aware.

The previous implementation had a bug and poorly handled
types that should not have a `spec: replica:` field.

Documentation is updated to reflect the change in behavior,
and better highlights the cases where a patch should be
used instead of this shorthand.
This commit is contained in:
Damien Robichaud
2019-06-13 17:31:53 -07:00
parent 05e3dead7b
commit 8d4b6452d4
9 changed files with 232 additions and 58 deletions

View File

@@ -24,26 +24,130 @@ apiVersion: builtin
kind: ReplicaCountTransformer
metadata:
name: notImportantHere
replica:
name: deploy1
name: myapp
count: 23
fieldSpecs:
- path: spec/replicas
create: true
kind: Deployment
- path: spec/replicas
create: true
kind: ReplicationController
- path: spec/replicas
create: true
kind: ReplicaSet
- path: spec/replicas
create: true
kind: StatefulSet
`, `
group: apps
apiVersion: v1
apiVersion: builtin
kind: Service
metadata:
name: myapp
spec:
ports:
- port: 1111
targetport: 1111
---
apiVersion: builtin
kind: Deployment
metadata:
name: deploy1
name: otherapp
spec:
replicas: 1
replicas: 5
---
apiVersion: builtin
kind: Deployment
metadata:
name: myapp
spec:
replicas: 5
---
apiVersion: builtin
kind: StatefulSet
metadata:
name: myapp
spec:
selector:
matchLabels:
app: app
---
apiVersion: builtin
kind: ReplicaSet
metadata:
name: myapp
spec:
selector:
matchLabels:
app: app
---
apiVersion: builtin
kind: ReplicationController
metadata:
name: myapp
spec:
selector:
matchLabels:
app: app
`)
th.AssertActualEqualsExpected(rm, `
apiVersion: v1
group: apps
apiVersion: builtin
kind: Service
metadata:
name: myapp
spec:
ports:
- port: 1111
targetport: 1111
---
apiVersion: builtin
kind: Deployment
metadata:
name: deploy1
name: myapp
spec:
replicas: 23
---
apiVersion: builtin
kind: Deployment
metadata:
name: otherapp
spec:
replicas: 5
---
apiVersion: builtin
kind: StatefulSet
metadata:
name: myapp
spec:
replicas: 23
selector:
matchLabels:
app: app
---
apiVersion: builtin
kind: ReplicaSet
metadata:
name: myapp
spec:
replicas: 23
selector:
matchLabels:
app: app
---
apiVersion: builtin
kind: ReplicationController
metadata:
name: myapp
spec:
replicas: 23
selector:
matchLabels:
app: app
`)
}