Skip to content

Commit

Permalink
DeploymentConfig replicas should be optional, other fields too
Browse files Browse the repository at this point in the history
Make a set of fields truly optional in openapi, and also make replicas a
pointer so we can default it.
  • Loading branch information
smarterclayton committed Oct 25, 2017
1 parent d29dd8e commit 5ec1b35
Show file tree
Hide file tree
Showing 14 changed files with 216 additions and 190 deletions.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 1 addition & 2 deletions api/swagger-spec/oapi-v1.json
Original file line number Diff line number Diff line change
Expand Up @@ -23170,8 +23170,7 @@
"id": "v1.DeploymentConfig",
"description": "Deployment Configs define the template for a pod and manages deploying new images or configuration changes. A single deployment configuration is usually analogous to a single micro-service. Can support many different deployment patterns, including full restart, customizable rolling updates, and fully custom behaviors, as well as pre- and post- deployment hooks. Each individual deployment is represented as a replication controller.\n\nA deployment is \"triggered\" when its configuration is changed or a tag in an Image Stream is changed. Triggers can be disabled to allow manual control over a deployment. The \"strategy\" determines how the deployment is carried out and may be changed at any time. The `latestVersion` field is updated when a new deployment is triggered by any means.",
"required": [
"spec",
"status"
"spec"
],
"properties": {
"kind": {
Expand Down
13 changes: 2 additions & 11 deletions api/swagger-spec/openshift-openapi-spec.json
Original file line number Diff line number Diff line change
Expand Up @@ -87032,8 +87032,7 @@
"com.github.openshift.origin.pkg.apps.apis.apps.v1.DeploymentConfig": {
"description": "Deployment Configs define the template for a pod and manages deploying new images or configuration changes. A single deployment configuration is usually analogous to a single micro-service. Can support many different deployment patterns, including full restart, customizable rolling updates, and fully custom behaviors, as well as pre- and post- deployment hooks. Each individual deployment is represented as a replication controller.\n\nA deployment is \"triggered\" when its configuration is changed or a tag in an Image Stream is changed. Triggers can be disabled to allow manual control over a deployment. The \"strategy\" determines how the deployment is carried out and may be changed at any time. The `latestVersion` field is updated when a new deployment is triggered by any means.",
"required": [
"spec",
"status"
"spec"
],
"properties": {
"apiVersion": {
Expand Down Expand Up @@ -87192,12 +87191,6 @@
},
"com.github.openshift.origin.pkg.apps.apis.apps.v1.DeploymentConfigSpec": {
"description": "DeploymentConfigSpec represents the desired state of the deployment.",
"required": [
"strategy",
"triggers",
"replicas",
"test"
],
"properties": {
"minReadySeconds": {
"description": "MinReadySeconds is the minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)",
Expand Down Expand Up @@ -90677,9 +90670,7 @@
"com.github.openshift.origin.pkg.image.apis.image.v1.TagReference": {
"description": "TagReference specifies optional annotations for images using this tag and an optional reference to an ImageStreamTag, ImageStreamImage, or DockerImage this tag should track.",
"required": [
"name",
"annotations",
"generation"
"name"
],
"properties": {
"annotations": {
Expand Down
4 changes: 4 additions & 0 deletions pkg/apps/apis/apps/v1/defaults.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,10 @@ func SetDefaults_DeploymentConfigSpec(obj *DeploymentConfigSpec) {
if len(obj.Selector) == 0 && obj.Template != nil {
obj.Selector = obj.Template.Labels
}
if obj.Replicas == nil {
one := int32(1)
obj.Replicas = &one
}

// if you only specify a single container, default the TagImages hook to the container name
if obj.Template != nil && len(obj.Template.Spec.Containers) == 1 {
Expand Down
Loading

0 comments on commit 5ec1b35

Please sign in to comment.