Skip to content

Bump openshift/api#1165

Closed
Elbehery wants to merge 1 commit intoopenshift:masterfrom
Elbehery:bump-openshift-api
Closed

Bump openshift/api#1165
Elbehery wants to merge 1 commit intoopenshift:masterfrom
Elbehery:bump-openshift-api

Conversation

@Elbehery
Copy link
Copy Markdown

@Elbehery Elbehery commented Jun 30, 2021

This will allow us to get latest feature gates about CSI migration

Note: this is needed for CSI migration feature to work in OCP 4.9. The goal of this bump is to apply CSIMigrationGCE and CSIMigrationAzureDisk feature gates when the TechPreviewNoUpgrade featureSet is set by the user, which was introduced in openshift/api#957

@Elbehery
Copy link
Copy Markdown
Author

/assign @bertinatto
/assign @jsafrane

@openshift-ci openshift-ci Bot requested review from soltysh and sttts June 30, 2021 19:15
@Elbehery Elbehery force-pushed the bump-openshift-api branch from 018f37a to 52a01fb Compare July 1, 2021 02:30
@sttts
Copy link
Copy Markdown
Contributor

sttts commented Jul 1, 2021

Why does this PR matter? Why does kube-apiserver have to get a feature gate that kubelet is supposed to receive?

@Elbehery
Copy link
Copy Markdown
Author

Elbehery commented Jul 1, 2021

Why does this PR matter? Why does kube-apiserver have to get a feature gate that kubelet is supposed to receive?

@sttts Thanks a lot for your review.
I did not edit kube-apiserver, I just bumped openshift/api#957 since we are wroking on CSIMigration for GCP & AzureDisk, both were added in this PR

@bertinatto @jsafrane correct me if I am wrong please

@bertinatto
Copy link
Copy Markdown
Member

bertinatto commented Jul 1, 2021

Why does this PR matter? Why does kube-apiserver have to get a feature gate that kubelet is supposed to receive?

@sttts some admission controllers need the CSI migration feature gates too.

Edit: I just noticed that the PR description mentions the kubelet, but that's probably just a copy/paste issue with MCO PR.

@Elbehery Elbehery force-pushed the bump-openshift-api branch from 6237aa1 to f0be442 Compare July 1, 2021 13:50
@Elbehery
Copy link
Copy Markdown
Author

Elbehery commented Jul 1, 2021

/retest

@Elbehery Elbehery force-pushed the bump-openshift-api branch from f0be442 to 2379e42 Compare July 2, 2021 10:57
@openshift-ci openshift-ci Bot added the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Jul 4, 2021
The goal of this bump is to apply `CSIMigrationGCE` and `CSIMigrationAzureDisk`
feature gates when the `TechPreviewNoUpgrade` featureSet is set by the user.
@Elbehery Elbehery force-pushed the bump-openshift-api branch from 2379e42 to 151d7fa Compare July 4, 2021 11:45
@openshift-ci openshift-ci Bot removed the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Jul 4, 2021
@Elbehery
Copy link
Copy Markdown
Author

Elbehery commented Jul 5, 2021

/retest

@Elbehery
Copy link
Copy Markdown
Author

Elbehery commented Jul 5, 2021

@soltysh the failing test is flaky, has nothing to do with the commit

@bertinatto
Copy link
Copy Markdown
Member

/lgtm

/assign @sttts @soltysh
for approval

@openshift-ci openshift-ci Bot added the lgtm Indicates that a PR is ready to be merged. label Jul 5, 2021
@bertinatto
Copy link
Copy Markdown
Member

/test e2e-aws-single-node

@openshift-ci
Copy link
Copy Markdown
Contributor

openshift-ci Bot commented Jul 5, 2021

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by: bertinatto, Elbehery
To complete the pull request process, please assign sttts after the PR has been reviewed.
You can assign the PR to them by writing /assign @sttts in a comment when ready.

The full list of commands accepted by this bot can be found here.

Details Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@sttts
Copy link
Copy Markdown
Contributor

sttts commented Jul 5, 2021

I still miss the point of this PR. It does not add a feature gate to the apiserver.

/hold

@openshift-ci openshift-ci Bot added the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Jul 5, 2021
maxItems: 24
items:
description: PerResourceAPIRequestLog logs request for various nodes.
- name: v1
Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

please don't mix bumps in vendor and other changes.

Copy link
Copy Markdown
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@sttts the test was failing till I have updated bindata.

After updating go.mod and without running make update I got this error

make verify
Makefile:96: warning: overriding commands for target `verify-golang-versions-Dockerfile.rhel7'
Makefile:49: warning: ignoring old commands for target `verify-golang-versions-Dockerfile.rhel7'
Makefile:96: warning: overriding commands for target `verify-golang-versions-.ci-operator.yaml'
Makefile:49: warning: ignoring old commands for target `verify-golang-versions-.ci-operator.yaml'
Makefile:96: warning: overriding commands for target `verify-golang-versions-go.mod'
Makefile:49: warning: ignoring old commands for target `verify-golang-versions-go.mod'
Running `gofmt -s -l` on 92 file(s).
go vet -mod=vendor ./...
diff -Naup vendor/github.com/openshift/api/apiserver/v1/apiserver.openshift.io_apirequestcount.yaml bindata/v4.1.0/kube-apiserver/apiserver.openshift.io_apirequestcount.yaml
--- vendor/github.com/openshift/api/apiserver/v1/apiserver.openshift.io_apirequestcount.yaml    2021-07-06 08:52:29.000000000 +0200
+++ bindata/v4.1.0/kube-apiserver/apiserver.openshift.io_apirequestcount.yaml   2021-07-06 08:50:33.000000000 +0200
@@ -15,100 +15,224 @@ spec:
     singular: apirequestcount
   scope: Cluster
   versions:
-    - name: v1
-      served: true
-      storage: true
-      subresources:
-        status: {}
-      additionalPrinterColumns:
-        - name: RemovedInRelease
-          type: string
-          description: Release in which an API will be removed.
-          jsonPath: .status.removedInRelease
-        - name: RequestsInCurrentHour
-          type: integer
-          description: Number of requests in the current hour.
-          jsonPath: .status.currentHour.requestCount
-        - name: RequestsInLast24h
-          type: integer
-          description: Number of requests in the last 24h.
-          jsonPath: .status.requestCount
-      "schema":
-        "openAPIV3Schema":
-          description: APIRequestCount tracks requests made to an API. The instance name must be of the form `resource.version.group`, matching the resource.
-          type: object
-          required:
-            - spec
-          properties:
-            apiVersion:
-              description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
-              type: string
-            kind:
-              description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
-              type: string
-            metadata:
-              type: object
-            spec:
-              description: spec defines the characteristics of the resource.
-              type: object
-              properties:
-                numberOfUsersToReport:
-                  description: numberOfUsersToReport is the number of users to include in the report. If unspecified or zero, the default is ten.  This is default is subject to change.
-                  type: integer
-                  format: int64
-                  default: 10
-                  maximum: 100
-                  minimum: 0
-            status:
-              description: status contains the observed state of the resource.
-              type: object
-              properties:
-                conditions:
-                  description: conditions contains details of the current status of this API Resource.
-                  type: array
-                  items:
-                    description: "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions.  For example, type FooStatus struct{     // Represents the observations of a foo's current state.     // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"     // +patchMergeKey=type     // +patchStrategy=merge     // +listType=map     // +listMapKey=type     Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n     // other fields }"
-                    type: object
-                    required:
-                      - lastTransitionTime
-                      - message
-                      - reason
-                      - status
-                      - type
-                    properties:
-                      lastTransitionTime:
-                        description: lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed.  If that is not known, then using the time when the API field changed is acceptable.
-                        type: string
-                        format: date-time
-                      message:
-                        description: message is a human readable message indicating details about the transition. This may be an empty string.
-                        type: string
-                        maxLength: 32768
-                      observedGeneration:
-                        description: observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.
-                        type: integer
-                        format: int64
-                        minimum: 0
-                      reason:
-                        description: reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.
-                        type: string
-                        maxLength: 1024
-                        minLength: 1
-                        pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$
-                      status:
-                        description: status of the condition, one of True, False, Unknown.
-                        type: string
-                        enum:
-                          - "True"
-                          - "False"
-                          - Unknown
-                      type:
-                        description: type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)
-                        type: string
-                        maxLength: 316
-                        pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$
-                currentHour:
-                  description: currentHour contains request history for the current hour. This is porcelain to make the API easier to read by humans seeing if they addressed a problem. This field is reset on the hour.
+  - name: v1
+    served: true
+    storage: true
+    subresources:
+      status: {}
+    additionalPrinterColumns:
+    - name: RemovedInRelease
+      type: string
+      description: Release in which an API will be removed.
+      jsonPath: .status.removedInRelease
+    - name: RequestsInCurrentHour
+      type: integer
+      description: Number of requests in the current hour.
+      jsonPath: .status.currentHour.requestCount
+    - name: RequestsInLast24h
+      type: integer
+      description: Number of requests in the last 24h.
+      jsonPath: .status.requestCount
+    "schema":
+      "openAPIV3Schema":
+        description: APIRequestCount tracks requests made to an API. The instance
+          name must be of the form `resource.version.group`, matching the resource.
+        type: object
+        required:
+        - spec
+        properties:
+          apiVersion:
+            description: 'APIVersion defines the versioned schema of this representation
+              of an object. Servers should convert recognized schemas to the latest
+              internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
+            type: string
+          kind:
+            description: 'Kind is a string value representing the REST resource this
+              object represents. Servers may infer this from the endpoint the client
+              submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
+            type: string
+          metadata:
+            type: object
+          spec:
+            description: spec defines the characteristics of the resource.
+            type: object
+            properties:
+              numberOfUsersToReport:
+                description: numberOfUsersToReport is the number of users to include
+                  in the report. If unspecified or zero, the default is ten.  This
+                  is default is subject to change.
+                type: integer
+                format: int64
+                default: 10
+                maximum: 100
+                minimum: 0
+          status:
+            description: status contains the observed state of the resource.
+            type: object
+            properties:
+              conditions:
+                description: conditions contains details of the current status of
+                  this API Resource.
+                type: array
+                items:
+                  description: "Condition contains details for one aspect of the current
+                    state of this API Resource. --- This struct is intended for direct
+                    use as an array at the field path .status.conditions.  For example,
+                    type FooStatus struct{     // Represents the observations of a
+                    foo's current state.     // Known .status.conditions.type are:
+                    \"Available\", \"Progressing\", and \"Degraded\"     // +patchMergeKey=type
+                    \    // +patchStrategy=merge     // +listType=map     // +listMapKey=type
+                    \    Conditions []metav1.Condition `json:\"conditions,omitempty\"
+                    patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`
+                    \n     // other fields }"
+                  type: object
+                  required:
+                  - lastTransitionTime
+                  - message
+                  - reason
+                  - status
+                  - type
+                  properties:
+                    lastTransitionTime:
+                      description: lastTransitionTime is the last time the condition
+                        transitioned from one status to another. This should be when
+                        the underlying condition changed.  If that is not known, then
+                        using the time when the API field changed is acceptable.
+                      type: string
+                      format: date-time
+                    message:
+                      description: message is a human readable message indicating
+                        details about the transition. This may be an empty string.
+                      type: string
+                      maxLength: 32768
+                    observedGeneration:
+                      description: observedGeneration represents the .metadata.generation
+                        that the condition was set based upon. For instance, if .metadata.generation
+                        is currently 12, but the .status.conditions[x].observedGeneration
+                        is 9, the condition is out of date with respect to the current
+                        state of the instance.
+                      type: integer
+                      format: int64
+                      minimum: 0
+                    reason:
+                      description: reason contains a programmatic identifier indicating
+                        the reason for the condition's last transition. Producers
+                        of specific condition types may define expected values and
+                        meanings for this field, and whether the values are considered
+                        a guaranteed API. The value should be a CamelCase string.
+                        This field may not be empty.
+                      type: string
+                      maxLength: 1024
+                      minLength: 1
+                      pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$
+                    status:
+                      description: status of the condition, one of True, False, Unknown.
+                      type: string
+                      enum:
+                      - "True"
+                      - "False"
+                      - Unknown
+                    type:
+                      description: type of condition in CamelCase or in foo.example.com/CamelCase.
+                        --- Many .condition.type values are consistent across resources
+                        like Available, but because arbitrary conditions can be useful
+                        (see .node.status.conditions), the ability to deconflict is
+                        important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)
+                      type: string
+                      maxLength: 316
+                      pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$
+              currentHour:
+                description: currentHour contains request history for the current
+                  hour. This is porcelain to make the API easier to read by humans
+                  seeing if they addressed a problem. This field is reset on the hour.
+                type: object
+                properties:
+                  byNode:
+                    description: byNode contains logs of requests per node.
+                    type: array
+                    maxItems: 512
+                    items:
+                      description: PerNodeAPIRequestLog contains logs of requests
+                        to a certain node.
+                      type: object
+                      properties:
+                        byUser:
+                          description: byUser contains request details by top .spec.numberOfUsersToReport
+                            users. Note that because in the case of an apiserver,
+                            restart the list of top users is determined on a best-effort
+                            basis, the list might be imprecise. In addition, some
+                            system users may be explicitly included in the list.
+                          type: array
+                          maxItems: 500
+                          items:
+                            description: PerUserAPIRequestCount contains logs of a
+                              user's requests.
+                            type: object
+                            properties:
+                              byVerb:
+                                description: byVerb details by verb.
+                                type: array
+                                maxItems: 10
+                                items:
+                                  description: PerVerbAPIRequestCount requestCounts
+                                    requests by API request verb.
+                                  type: object
+                                  properties:
+                                    requestCount:
+                                      description: requestCount of requests for verb.
+                                      type: integer
+                                      format: int64
+                                      minimum: 0
+                                    verb:
+                                      description: verb of API request (get, list,
+                                        create, etc...)
+                                      type: string
+                                      maxLength: 20
+                              requestCount:
+                                description: requestCount of requests by the user
+                                  across all verbs.
+                                type: integer
+                                format: int64
+                                minimum: 0
+                              userAgent:
+                                description: userAgent that made the request. The
+                                  same user often has multiple binaries which connect
+                                  (pods with many containers).  The different binaries
+                                  will have different userAgents, but the same user.  In
+                                  addition, we have userAgents with version information
+                                  embedded and the userName isn't likely to change.
+                                type: string
+                                maxLength: 1024
+                              username:
+                                description: userName that made the request.
+                                type: string
+                                maxLength: 512
+                        nodeName:
+                          description: nodeName where the request are being handled.
+                          type: string
+                          maxLength: 512
+                          minLength: 1
+                        requestCount:
+                          description: requestCount is a sum of all requestCounts
+                            across all users, even those outside of the top 10 users.
+                          type: integer
+                          format: int64
+                          minimum: 0
+                  requestCount:
+                    description: requestCount is a sum of all requestCounts across
+                      nodes.
+                    type: integer
+                    format: int64
+                    minimum: 0
+              last24h:
+                description: last24h contains request history for the last 24 hours,
+                  indexed by the hour, so 12:00AM-12:59 is in index 0, 6am-6:59am
+                  is index 6, etc. The index of the current hour is updated live and
+                  then duplicated into the requestsLastHour field.
+                type: array
+                maxItems: 24
+                items:
+                  description: PerResourceAPIRequestLog logs request for various nodes.
                   type: object
                   properties:
                     byNode:
@@ -116,15 +240,21 @@ spec:
                       type: array
                       maxItems: 512
                       items:
-                        description: PerNodeAPIRequestLog contains logs of requests to a certain node.
+                        description: PerNodeAPIRequestLog contains logs of requests
+                          to a certain node.
                         type: object
                         properties:
                           byUser:
-                            description: byUser contains request details by top .spec.numberOfUsersToReport users. Note that because in the case of an apiserver, restart the list of top users is determined on a best-effort basis, the list might be imprecise. In addition, some system users may be explicitly included in the list.
+                            description: byUser contains request details by top .spec.numberOfUsersToReport
+                              users. Note that because in the case of an apiserver,
+                              restart the list of top users is determined on a best-effort
+                              basis, the list might be imprecise. In addition, some
+                              system users may be explicitly included in the list.
                             type: array
                             maxItems: 500
                             items:
-                              description: PerUserAPIRequestCount contains logs of a user's requests.
+                              description: PerUserAPIRequestCount contains logs of
+                                a user's requests.
                               type: object
                               properties:
                                 byVerb:
@@ -132,25 +262,34 @@ spec:
                                   type: array
                                   maxItems: 10
                                   items:
-                                    description: PerVerbAPIRequestCount requestCounts requests by API request verb.
+                                    description: PerVerbAPIRequestCount requestCounts
+                                      requests by API request verb.
                                     type: object
                                     properties:
                                       requestCount:
-                                        description: requestCount of requests for verb.
+                                        description: requestCount of requests for
+                                          verb.
                                         type: integer
                                         format: int64
                                         minimum: 0
                                       verb:
-                                        description: verb of API request (get, list, create, etc...)
+                                        description: verb of API request (get, list,
+                                          create, etc...)
                                         type: string
                                         maxLength: 20
                                 requestCount:
-                                  description: requestCount of requests by the user across all verbs.
+                                  description: requestCount of requests by the user
+                                    across all verbs.
                                   type: integer
                                   format: int64
                                   minimum: 0
                                 userAgent:
-                                  description: userAgent that made the request. The same user often has multiple binaries which connect (pods with many containers).  The different binaries will have different userAgents, but the same user.  In addition, we have userAgents with version information embedded and the userName isn't likely to change.
+                                  description: userAgent that made the request. The
+                                    same user often has multiple binaries which connect
+                                    (pods with many containers).  The different binaries
+                                    will have different userAgents, but the same user.  In
+                                    addition, we have userAgents with version information
+                                    embedded and the userName isn't likely to change.
                                   type: string
                                   maxLength: 1024
                                 username:
@@ -163,92 +302,26 @@ spec:
                             maxLength: 512
                             minLength: 1
                           requestCount:
-                            description: requestCount is a sum of all requestCounts across all users, even those outside of the top 10 users.
+                            description: requestCount is a sum of all requestCounts
+                              across all users, even those outside of the top 10 users.
                             type: integer
                             format: int64
                             minimum: 0
                     requestCount:
-                      description: requestCount is a sum of all requestCounts across nodes.
+                      description: requestCount is a sum of all requestCounts across
+                        nodes.
                       type: integer
                       format: int64
                       minimum: 0
-                last24h:
-                  description: last24h contains request history for the last 24 hours, indexed by the hour, so 12:00AM-12:59 is in index 0, 6am-6:59am is index 6, etc. The index of the current hour is updated live and then duplicated into the requestsLastHour field.
-                  type: array
-                  maxItems: 24
-                  items:
-                    description: PerResourceAPIRequestLog logs request for various nodes.
-                    type: object
-                    properties:
-                      byNode:
-                        description: byNode contains logs of requests per node.
-                        type: array
-                        maxItems: 512
-                        items:
-                          description: PerNodeAPIRequestLog contains logs of requests to a certain node.
-                          type: object
-                          properties:
-                            byUser:
-                              description: byUser contains request details by top .spec.numberOfUsersToReport users. Note that because in the case of an apiserver, restart the list of top users is determined on a best-effort basis, the list might be imprecise. In addition, some system users may be explicitly included in the list.
-                              type: array
-                              maxItems: 500
-                              items:
-                                description: PerUserAPIRequestCount contains logs of a user's requests.
-                                type: object
-                                properties:
-                                  byVerb:
-                                    description: byVerb details by verb.
-                                    type: array
-                                    maxItems: 10
-                                    items:
-                                      description: PerVerbAPIRequestCount requestCounts requests by API request verb.
-                                      type: object
-                                      properties:
-                                        requestCount:
-                                          description: requestCount of requests for verb.
-                                          type: integer
-                                          format: int64
-                                          minimum: 0
-                                        verb:
-                                          description: verb of API request (get, list, create, etc...)
-                                          type: string
-                                          maxLength: 20
-                                  requestCount:
-                                    description: requestCount of requests by the user across all verbs.
-                                    type: integer
-                                    format: int64
-                                    minimum: 0
-                                  userAgent:
-                                    description: userAgent that made the request. The same user often has multiple binaries which connect (pods with many containers).  The different binaries will have different userAgents, but the same user.  In addition, we have userAgents with version information embedded and the userName isn't likely to change.
-                                    type: string
-                                    maxLength: 1024
-                                  username:
-                                    description: userName that made the request.
-                                    type: string
-                                    maxLength: 512
-                            nodeName:
-                              description: nodeName where the request are being handled.
-                              type: string
-                              maxLength: 512
-                              minLength: 1
-                            requestCount:
-                              description: requestCount is a sum of all requestCounts across all users, even those outside of the top 10 users.
-                              type: integer
-                              format: int64
-                              minimum: 0
-                      requestCount:
-                        description: requestCount is a sum of all requestCounts across nodes.
-                        type: integer
-                        format: int64
-                        minimum: 0
-                removedInRelease:
-                  description: removedInRelease is when the API will be removed.
-                  type: string
-                  maxLength: 64
-                  minLength: 0
-                  pattern: ^[0-9][0-9]*\.[0-9][0-9]*$
-                requestCount:
-                  description: requestCount is a sum of all requestCounts across all current hours, nodes, and users.
-                  type: integer
-                  format: int64
-                  minimum: 0
+              removedInRelease:
+                description: removedInRelease is when the API will be removed.
+                type: string
+                maxLength: 64
+                minLength: 0
+                pattern: ^[0-9][0-9]*\.[0-9][0-9]*$
+              requestCount:
+                description: requestCount is a sum of all requestCounts across all
+                  current hours, nodes, and users.
+                type: integer
+                format: int64
+                minimum: 0
make: *** [verify-apirequestcounts-crd] Error 1

Only running make update resolves this error and the test passes

@openshift-ci
Copy link
Copy Markdown
Contributor

openshift-ci Bot commented Jul 5, 2021

@Elbehery: The following test failed, say /retest to rerun all failed tests:

Test name Commit Details Rerun command
ci/prow/e2e-aws-single-node 151d7fa link /test e2e-aws-single-node

Full PR test history. Your PR dashboard.

Details

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository. I understand the commands that are listed here.

@bertinatto
Copy link
Copy Markdown
Member

I still miss the point of this PR. It does not add a feature gate to the apiserver.

/hold

This PR is meant to simply bump openshift/api to get the changes introduced in openshift/api#957.

The goal of this bump is: now when the user sets the TechPreviewNoUpgrade feature set, this operator will apply to the apiserver 2 additional feature gates: CSIMigrationGCE and CSIMigrationAzureDisk.

This needs to be done in all control-plane components, except the Attach Detach controller from KCM that works a bit differently. There, we always enable the gates in the Attach Detach controller (see openshift/kubernetes#831), and the rest of the controllers rely on the TechPreviewNoUpgrade feature set to enabled the CSI migation gates.

Please note that this isn't new, the same has been done in 4.8 to enable 2 other gates: CSIMigrationAWS and CSIMigrationOpenStack (see #1098).

This whole approach is described at openshift/enhancements#549.

@openshift-ci openshift-ci Bot added the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Jul 7, 2021
@openshift-ci
Copy link
Copy Markdown
Contributor

openshift-ci Bot commented Jul 7, 2021

@Elbehery: PR needs rebase.

Details

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

@bertinatto
Copy link
Copy Markdown
Member

Superseded by #1173

/close

@openshift-ci
Copy link
Copy Markdown
Contributor

openshift-ci Bot commented Jul 7, 2021

@bertinatto: Closed this PR.

Details

In response to this:

Superseded by #1173

/close

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

@openshift-ci openshift-ci Bot closed this Jul 7, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. lgtm Indicates that a PR is ready to be merged. needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants