From 87ec2984a0aa2323c6eb0b592d3631c9531400a7 Mon Sep 17 00:00:00 2001 From: Zahi Akiva Date: Wed, 27 Sep 2017 15:22:39 +0300 Subject: [PATCH] Drop Container Component Statuses --- .../container_manager/entities_mapping.rb | 1 - .../inventory_collections.rb | 11 ---- .../container_manager/refresh_parser.rb | 41 --------------- .../container_manager/refresher_mixin.rb | 4 +- .../container_manager/refresh_parser_spec.rb | 51 ------------------- .../container_manager/refresher_spec.rb | 10 ---- .../hawkular_capture_context_refresh.yml | 43 ---------------- .../prometheus_capture_context_refresh.yml | 41 --------------- .../container_manager/refresher.yml | 33 ------------ .../refresher_after_deletions.yml | 43 +--------------- .../refresher_before_deletions.yml | 43 +--------------- 11 files changed, 3 insertions(+), 318 deletions(-) diff --git a/app/models/manageiq/providers/kubernetes/container_manager/entities_mapping.rb b/app/models/manageiq/providers/kubernetes/container_manager/entities_mapping.rb index 8c2610c6b2..b0a97b9dd0 100644 --- a/app/models/manageiq/providers/kubernetes/container_manager/entities_mapping.rb +++ b/app/models/manageiq/providers/kubernetes/container_manager/entities_mapping.rb @@ -10,7 +10,6 @@ module ManageIQ::Providers::Kubernetes::ContainerManager::EntitiesMapping 'persistent_volume' => 'PersistentVolume', 'pod' => 'ContainerGroup', 'service' => 'ContainerService', - 'component_status' => 'ContainerComponentStatus', 'project' => 'ContainerProject', 'route' => 'ContainerRoute', 'build_config' => 'ContainerBuild', diff --git a/app/models/manageiq/providers/kubernetes/container_manager/inventory_collections.rb b/app/models/manageiq/providers/kubernetes/container_manager/inventory_collections.rb index bdfd87f9dd..9255d30278 100644 --- a/app/models/manageiq/providers/kubernetes/container_manager/inventory_collections.rb +++ b/app/models/manageiq/providers/kubernetes/container_manager/inventory_collections.rb @@ -242,17 +242,6 @@ def initialize_inventory_collections ) initialize_custom_attributes_collections(manager.container_routes, %w(labels)) - @collections[:container_component_statuses] = - ::ManagerRefresh::InventoryCollection.new( - shared_options.merge( - :model_class => ContainerComponentStatus, - :parent => manager, - :builder_params => {:ems_id => manager.id}, - :association => :container_component_statuses, - :manager_ref => [:name], - ) - ) - @collections[:container_templates] = ::ManagerRefresh::InventoryCollection.new( :model_class => ContainerTemplate, diff --git a/app/models/manageiq/providers/kubernetes/container_manager/refresh_parser.rb b/app/models/manageiq/providers/kubernetes/container_manager/refresh_parser.rb index a31e9d90a8..5ea5a82fc0 100644 --- a/app/models/manageiq/providers/kubernetes/container_manager/refresh_parser.rb +++ b/app/models/manageiq/providers/kubernetes/container_manager/refresh_parser.rb @@ -33,7 +33,6 @@ def ems_inv_to_hashes(inventory, _options = Config::Options.new) get_pods(inventory) get_endpoints(inventory) get_services(inventory) - get_component_statuses(inventory) EmsRefresh.log_inv_debug_trace(@data, "data:") # Returning a hash triggers save_inventory_container code path. @@ -71,7 +70,6 @@ def ems_inv_populate_collections(inventory, _options) get_persistent_volumes_graph(inventory) get_pods_graph(inventory) get_endpoints_and_services_graph(inventory) - get_component_statuses_graph(inventory) end def get_nodes(inventory) @@ -209,16 +207,6 @@ def get_limit_ranges(inventory) end end - def get_component_statuses(inventory) - key = path_for_entity("component_status") - process_collection(inventory["component_status"], key) do |cs| - parse_component_status(cs) - end - @data[key].each do |cs| - @data_index.store_path(key, :by_name, cs[:name], cs) - end - end - def get_additional_attributes(inventory) inventory["additional_attributes"] ||= {} process_collection(inventory["additional_attributes"], :additional_attributes) do |aa| @@ -540,15 +528,6 @@ def get_container_service_port_configs_graph(container_service, hashes) end end - def get_component_statuses_graph(inv) - collection = @inv_collections[:container_component_statuses] - - inv["component_status"].each do |cs| - h = parse_component_status(cs) - collection.build(h) - end - end - # TODO: images & registries still rely on @data_index def get_container_image_registries_graph collection = @inv_collections[:container_image_registries] @@ -990,26 +969,6 @@ def parse_replication_controllers(container_replicator) new_result end - def parse_component_status(container_component_status) - new_result = {} - - # At this point components statuses use only one condition. - # In the case of a future change, this will need to be modified accordingly. - component_condition = container_component_status.conditions.first - - new_result.merge!( - :name => container_component_status.metadata.name, - :condition => component_condition.type, - :status => component_condition.status, - :message => component_condition.message, - # workaround for handling Kubernetes issue: "nil" string is returned in component status error - # https://github.com/kubernetes/kubernetes/issues/16721 - :error => (component_condition.error unless component_condition.error == "nil") - ) - - new_result - end - def parse_labels(entity) parse_identifying_attributes(entity.metadata.labels, 'labels') end diff --git a/app/models/manageiq/providers/kubernetes/container_manager/refresher_mixin.rb b/app/models/manageiq/providers/kubernetes/container_manager/refresher_mixin.rb index 00f3dfe2a7..753ace6b8f 100644 --- a/app/models/manageiq/providers/kubernetes/container_manager/refresher_mixin.rb +++ b/app/models/manageiq/providers/kubernetes/container_manager/refresher_mixin.rb @@ -5,9 +5,7 @@ module ContainerManager::RefresherMixin KUBERNETES_ENTITIES = [ {:name => 'pods'}, {:name => 'services'}, {:name => 'replication_controllers'}, {:name => 'nodes'}, {:name => 'endpoints'}, {:name => 'namespaces'}, {:name => 'resource_quotas'}, {:name => 'limit_ranges'}, - {:name => 'persistent_volumes'}, {:name => 'persistent_volume_claims'}, - # workaround for: https://github.com/openshift/origin/issues/5865 - {:name => 'component_statuses', :default => []} + {:name => 'persistent_volumes'}, {:name => 'persistent_volume_claims'} ] def fetch_entities(client, entities) diff --git a/spec/models/manageiq/providers/kubernetes/container_manager/refresh_parser_spec.rb b/spec/models/manageiq/providers/kubernetes/container_manager/refresh_parser_spec.rb index a51cb5c954..6c91d02fba 100644 --- a/spec/models/manageiq/providers/kubernetes/container_manager/refresh_parser_spec.rb +++ b/spec/models/manageiq/providers/kubernetes/container_manager/refresh_parser_spec.rb @@ -413,57 +413,6 @@ end end - describe "parse_component_statuses" do - example_component_statuses = [ - { - :component_status => array_recursive_ostruct( - :metadata => {:name => "example-component-status1"}, - :conditions => [ - { - :type => "Healthy", - :status => "True", - :message => "{'health': 'true'}" - }, - ]), - :name => "example-component-status1", - :condition => "Healthy", - :status => "True", - :message => "{'health': 'true'}", - :error => nil - }, - { - :component_status => array_recursive_ostruct( - :metadata => {:name => "example-component-status2"}, - :conditions => [ - { - :type => "Healthy", - :status => "Unknown", - :error => "Get http://127.0.0.1:10251/healthz: dial tcp 127.0.0.1:10251: connection refused" - }, - ]), - :name => "example-component-status2", - :condition => "Healthy", - :status => "Unknown", - :message => nil, - :error => "Get http://127.0.0.1:10251/healthz: dial tcp 127.0.0.1:10251: connection refused" - } - ] - - example_component_statuses.each do |ex| - it "tests '#{ex[:name]}'" do - parsed_component_status = parser.send(:parse_component_status, ex[:component_status]) - - expect(parsed_component_status).to have_attributes( - :name => ex[:name], - :condition => ex[:condition], - :status => ex[:status], - :message => ex[:message], - :error => ex[:error] - ) - end - end - end - describe "parse_iec_number" do it "parse capacity hash correctly" do hash = {:storage => "10Gi", :foo => "10"} diff --git a/spec/models/manageiq/providers/kubernetes/container_manager/refresher_spec.rb b/spec/models/manageiq/providers/kubernetes/container_manager/refresher_spec.rb index ecb19bcef1..034f084e75 100644 --- a/spec/models/manageiq/providers/kubernetes/container_manager/refresher_spec.rb +++ b/spec/models/manageiq/providers/kubernetes/container_manager/refresher_spec.rb @@ -52,7 +52,6 @@ def full_refresh_test assert_specific_container_quota assert_specific_container_limit assert_specific_container_image_and_registry - assert_specific_container_component_status # Volumes, PVs, and PVCs are tested in _before_deletions VCR. end end @@ -74,7 +73,6 @@ def assert_table_counts expect(ContainerLimit.count).to eq(3) expect(ContainerImage.count).to eq(3) expect(ContainerImageRegistry.count).to eq(1) - expect(ContainerComponentStatus.count).to eq(3) expect(PersistentVolume.count).to eq(1) end @@ -371,14 +369,6 @@ def assert_specific_container_image_and_registry expect(@image.container_nodes.count).to eq(1) end - def assert_specific_container_component_status - @component_status = ContainerComponentStatus.find_by(:name => "etcd-0") - expect(@component_status).to have_attributes( - :condition => "Healthy", - :status => "True" - ) - end - def label_with_name_value(name, value) an_object_having_attributes( :section => 'labels', :source => 'kubernetes', diff --git a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/metrics_capture/hawkular_capture_context_refresh.yml b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/metrics_capture/hawkular_capture_context_refresh.yml index 33e2335a1d..bf0dc272e8 100644 --- a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/metrics_capture/hawkular_capture_context_refresh.yml +++ b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/metrics_capture/hawkular_capture_context_refresh.yml @@ -400,47 +400,4 @@ http_interactions: string: '{"kind":"PersistentVolumeClaimList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/persistentvolumeclaims","resourceVersion":"37621"},"items":[]} ' - http_version: - recorded_at: Thu, 06 Jul 2017 10:57:57 GMT -- request: - method: get - uri: https://capture.context.com:8443/api/v1/componentstatuses - body: - encoding: US-ASCII - string: '' - headers: - Accept: - - "*/*" - Accept-Encoding: - - gzip, deflate - User-Agent: - - rest-client/2.0.2 (linux-gnu x86_64) ruby/2.4.1p111 - Authorization: - - Bearer theToken - response: - status: - code: 200 - message: OK - headers: - Cache-Control: - - no-store - Content-Type: - - application/json - Date: - - Thu, 06 Jul 2017 10:57:57 GMT - Content-Length: - - '919' - body: - encoding: UTF-8 - string: '{"kind":"ComponentStatusList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/componentstatuses"},"items":[{"metadata":{"name":"controller-manager","selfLink":"/api/v1/componentstatusescontroller-manager","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - http://127.0.0.1:10252/healthz: dial tcp 127.0.0.1:10252: getsockopt: connection - refused"}]},{"metadata":{"name":"scheduler","selfLink":"/api/v1/componentstatusesscheduler","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - http://127.0.0.1:10251/healthz: dial tcp 127.0.0.1:10251: getsockopt: connection - refused"}]},{"metadata":{"name":"etcd-0","selfLink":"/api/v1/componentstatusesetcd-0","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - https://capture.context.com:4001/health: remote error: - tls: bad certificate"}]}]} - -' - http_version: - recorded_at: Thu, 06 Jul 2017 10:57:57 GMT recorded_with: VCR 3.0.3 diff --git a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/metrics_capture/prometheus_capture_context_refresh.yml b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/metrics_capture/prometheus_capture_context_refresh.yml index 19642cd7b1..677e8ee737 100644 --- a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/metrics_capture/prometheus_capture_context_refresh.yml +++ b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/metrics_capture/prometheus_capture_context_refresh.yml @@ -403,47 +403,6 @@ http_interactions: encoding: UTF-8 string: '{"kind":"PersistentVolumeClaimList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/persistentvolumeclaims","resourceVersion":"123394"},"items":[]} -' - http_version: - recorded_at: Wed, 12 Jul 2017 10:27:14 GMT -- request: - method: get - uri: https://capture.context.com:8443/api/v1/componentstatuses - body: - encoding: US-ASCII - string: '' - headers: - Accept: - - "*/*" - Accept-Encoding: - - gzip, deflate - User-Agent: - - rest-client/2.0.2 (linux-gnu x86_64) ruby/2.4.1p111 - Authorization: - - Bearer theToken - response: - status: - code: 200 - message: OK - headers: - Cache-Control: - - no-store - Content-Type: - - application/json - Date: - - Wed, 12 Jul 2017 10:27:14 GMT - Content-Length: - - '919' - body: - encoding: UTF-8 - string: '{"kind":"ComponentStatusList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/componentstatuses"},"items":[{"metadata":{"name":"controller-manager","selfLink":"/api/v1/componentstatusescontroller-manager","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - http://127.0.0.1:10252/healthz: dial tcp 127.0.0.1:10252: getsockopt: connection - refused"}]},{"metadata":{"name":"scheduler","selfLink":"/api/v1/componentstatusesscheduler","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - http://127.0.0.1:10251/healthz: dial tcp 127.0.0.1:10251: getsockopt: connection - refused"}]},{"metadata":{"name":"etcd-0","selfLink":"/api/v1/componentstatusesetcd-0","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - https://capture.context.com:4001/health: remote error: - tls: bad certificate"}]}]} - ' http_version: recorded_at: Wed, 12 Jul 2017 10:27:14 GMT diff --git a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher.yml b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher.yml index 9130d69adb..b009c08b24 100644 --- a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher.yml +++ b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher.yml @@ -574,37 +574,4 @@ http_interactions: string: '{"kind":"PersistentVolumeClaimList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/persistentvolumeclaims","resourceVersion":"1769278"}}' http_version: recorded_at: Mon, 07 Sep 2015 12:04:51 GMT -- request: - method: get - uri: https://10.35.0.169:6443/api/v1/componentstatuses - body: - encoding: US-ASCII - string: '' - headers: - Accept: - - "*/*" - Accept-Encoding: - - gzip, deflate - User-Agent: - - rest-client/2.0.0.rc1 (linux-gnu x86_64) ruby/2.2.1p85 - response: - status: - code: 200 - message: OK - headers: - Cache-Control: - - no-store - Content-Type: - - application/json - Date: - - Tue, 13 Oct 2015 13:03:20 GMT - Content-Length: - - '925' - body: - encoding: UTF-8 - string: '{"kind":"ComponentStatusList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/componentstatuses"},"items":[{"metadata":{"name":"controller-manager","selfLink":"/api/v1/namespaces/componentstatuses/controller-manager","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"Unknown","error":"Get - http://127.0.0.1:10252/healthz: dial tcp 127.0.0.1:10252: connection refused"}]},{"metadata":{"name":"scheduler","selfLink":"/api/v1/namespaces/componentstatuses/scheduler","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"Unknown","error":"Get - http://127.0.0.1:10251/healthz: dial tcp 127.0.0.1:10251: connection refused"}]},{"metadata":{"name":"etcd-0","selfLink":"/api/v1/namespaces/componentstatuses/etcd-0","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"True","message":"{\"health\":\"true\"}","error":"nil"}]}]}' - http_version: - recorded_at: Tue, 13 Oct 2015 13:03:20 GMT recorded_with: VCR 2.9.3 diff --git a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher_after_deletions.yml b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher_after_deletions.yml index 13f7cb7359..ada5122f57 100644 --- a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher_after_deletions.yml +++ b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher_after_deletions.yml @@ -401,48 +401,7 @@ http_interactions: string: '{"kind":"PersistentVolumeClaimList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/persistentvolumeclaims","resourceVersion":"2124022"},"items":[{"metadata":{"name":"my-persistentvolumeclaim-2","namespace":"my-project-2","selfLink":"/api/v1/namespaces/my-project-2/persistentvolumeclaims/my-persistentvolumeclaim-2","uid":"f05028a5-50ed-11e7-9a6c-001a4a162683","resourceVersion":"2123427","creationTimestamp":"2017-06-14T10:40:52Z"},"spec":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"8Gi"}}},"status":{"phase":"Pending"}},{"metadata":{"name":"metrics-cassandra-1","namespace":"openshift-infra","selfLink":"/api/v1/namespaces/openshift-infra/persistentvolumeclaims/metrics-cassandra-1","uid":"e21379dd-e6f9-11e6-a348-001a4a162683","resourceVersion":"973","creationTimestamp":"2017-01-30T14:39:19Z","labels":{"metrics-infra":"hawkular-cassandra"},"annotations":{"pv.kubernetes.io/bind-completed":"yes","pv.kubernetes.io/bound-by-controller":"yes"}},"spec":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"10Gi"}},"volumeName":"metrics-volume"},"status":{"phase":"Bound","accessModes":["ReadWriteOnce"],"capacity":{"storage":"10Gi"}}}]} ' - http_version: - recorded_at: Wed, 14 Jun 2017 10:54:31 GMT -- request: - method: get - uri: https://host.example.com:8443/api/v1/componentstatuses - body: - encoding: US-ASCII - string: '' - headers: - Accept: - - "*/*" - Accept-Encoding: - - gzip, deflate - User-Agent: - - rest-client/2.0.2 (linux-gnu x86_64) ruby/2.3.3p222 - Authorization: - - Bearer eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJrdWJlcm5ldGVzL3NlcnZpY2VhY2NvdW50Iiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9uYW1lc3BhY2UiOiJtYW5hZ2VtZW50LWluZnJhIiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9zZWNyZXQubmFtZSI6Im1hbmFnZW1lbnQtYWRtaW4tdG9rZW4tOHhlb2siLCJrdWJlcm5ldGVzLmlvL3NlcnZpY2VhY2NvdW50L3NlcnZpY2UtYWNjb3VudC5uYW1lIjoibWFuYWdlbWVudC1hZG1pbiIsImt1YmVybmV0ZXMuaW8vc2VydmljZWFjY291bnQvc2VydmljZS1hY2NvdW50LnVpZCI6IjI3Zjc0NTNlLWU2ZjgtMTFlNi1hMzQ4LTAwMWE0YTE2MjY4MyIsInN1YiI6InN5c3RlbTpzZXJ2aWNlYWNjb3VudDptYW5hZ2VtZW50LWluZnJhOm1hbmFnZW1lbnQtYWRtaW4ifQ.bPi4TnBvEHQ5URSYZ9pfhebq5KLSJBAgJCeQ3I4UATpxwvy-WkF1uy_E_k2nc_GKRIOTzHjxjxBwvwL4KFyyM-By-RQHSb1Uux4qU077n9c67drbaeeYZ3MJVdoxDANqDu96g00YnVxxODx7DSep36dr9mLzWlP_k2NwAyxBV5NukYULdGunCjvWuv7wEyPHmUMRN4xntbhd5EhZThpN93PD6AhzcYy-OV9ZUB41L7bslnZEPU0kpG9oQbvj9hRoKJR7FyRPnHaUqJD7riOXwYjB57vk7lTCaxzsQs1i21dlQvdetu83drMTdV-02V_XuB5zucYPvaCUx7v-PUUy3A - response: - status: - code: 200 - message: OK - headers: - Cache-Control: - - no-store - Content-Type: - - application/json - Date: - - Wed, 14 Jun 2017 10:52:57 GMT - Content-Length: - - '915' - body: - encoding: UTF-8 - string: '{"kind":"ComponentStatusList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/componentstatuses"},"items":[{"metadata":{"name":"scheduler","selfLink":"/api/v1/componentstatuses/scheduler","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - http://127.0.0.1:10251/healthz: dial tcp 127.0.0.1:10251: getsockopt: connection - refused"}]},{"metadata":{"name":"controller-manager","selfLink":"/api/v1/componentstatuses/controller-manager","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - http://127.0.0.1:10252/healthz: dial tcp 127.0.0.1:10252: getsockopt: connection - refused"}]},{"metadata":{"name":"etcd-0","selfLink":"/api/v1/componentstatuses/etcd-0","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - https://host.example.com:4001/health: remote error: tls: bad - certificate"}]}]} - -' - http_version: + http_version: recorded_at: Wed, 14 Jun 2017 10:54:31 GMT - request: method: get diff --git a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher_before_deletions.yml b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher_before_deletions.yml index 3292e38d29..5ab314a78d 100644 --- a/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher_before_deletions.yml +++ b/spec/vcr_cassettes/manageiq/providers/kubernetes/container_manager/refresher_before_deletions.yml @@ -401,48 +401,7 @@ http_interactions: string: '{"kind":"PersistentVolumeClaimList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/persistentvolumeclaims","resourceVersion":"2123778"},"items":[{"metadata":{"name":"my-persistentvolumeclaim-0","namespace":"my-project-0","selfLink":"/api/v1/namespaces/my-project-0/persistentvolumeclaims/my-persistentvolumeclaim-0","uid":"efdc4a5a-50ed-11e7-9a6c-001a4a162683","resourceVersion":"2123332","creationTimestamp":"2017-06-14T10:40:51Z"},"spec":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"8Gi"}}},"status":{"phase":"Pending"}},{"metadata":{"name":"my-persistentvolumeclaim-1","namespace":"my-project-1","selfLink":"/api/v1/namespaces/my-project-1/persistentvolumeclaims/my-persistentvolumeclaim-1","uid":"f01701c8-50ed-11e7-9a6c-001a4a162683","resourceVersion":"2123381","creationTimestamp":"2017-06-14T10:40:52Z"},"spec":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"8Gi"}}},"status":{"phase":"Pending"}},{"metadata":{"name":"my-persistentvolumeclaim-2","namespace":"my-project-2","selfLink":"/api/v1/namespaces/my-project-2/persistentvolumeclaims/my-persistentvolumeclaim-2","uid":"f05028a5-50ed-11e7-9a6c-001a4a162683","resourceVersion":"2123427","creationTimestamp":"2017-06-14T10:40:52Z"},"spec":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"8Gi"}}},"status":{"phase":"Pending"}},{"metadata":{"name":"metrics-cassandra-1","namespace":"openshift-infra","selfLink":"/api/v1/namespaces/openshift-infra/persistentvolumeclaims/metrics-cassandra-1","uid":"e21379dd-e6f9-11e6-a348-001a4a162683","resourceVersion":"973","creationTimestamp":"2017-01-30T14:39:19Z","labels":{"metrics-infra":"hawkular-cassandra"},"annotations":{"pv.kubernetes.io/bind-completed":"yes","pv.kubernetes.io/bound-by-controller":"yes"}},"spec":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"10Gi"}},"volumeName":"metrics-volume"},"status":{"phase":"Bound","accessModes":["ReadWriteOnce"],"capacity":{"storage":"10Gi"}}}]} ' - http_version: - recorded_at: Wed, 14 Jun 2017 10:50:37 GMT -- request: - method: get - uri: https://host.example.com:8443/api/v1/componentstatuses - body: - encoding: US-ASCII - string: '' - headers: - Accept: - - "*/*" - Accept-Encoding: - - gzip, deflate - User-Agent: - - rest-client/2.0.2 (linux-gnu x86_64) ruby/2.3.3p222 - Authorization: - - Bearer eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJrdWJlcm5ldGVzL3NlcnZpY2VhY2NvdW50Iiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9uYW1lc3BhY2UiOiJtYW5hZ2VtZW50LWluZnJhIiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9zZWNyZXQubmFtZSI6Im1hbmFnZW1lbnQtYWRtaW4tdG9rZW4tOHhlb2siLCJrdWJlcm5ldGVzLmlvL3NlcnZpY2VhY2NvdW50L3NlcnZpY2UtYWNjb3VudC5uYW1lIjoibWFuYWdlbWVudC1hZG1pbiIsImt1YmVybmV0ZXMuaW8vc2VydmljZWFjY291bnQvc2VydmljZS1hY2NvdW50LnVpZCI6IjI3Zjc0NTNlLWU2ZjgtMTFlNi1hMzQ4LTAwMWE0YTE2MjY4MyIsInN1YiI6InN5c3RlbTpzZXJ2aWNlYWNjb3VudDptYW5hZ2VtZW50LWluZnJhOm1hbmFnZW1lbnQtYWRtaW4ifQ.bPi4TnBvEHQ5URSYZ9pfhebq5KLSJBAgJCeQ3I4UATpxwvy-WkF1uy_E_k2nc_GKRIOTzHjxjxBwvwL4KFyyM-By-RQHSb1Uux4qU077n9c67drbaeeYZ3MJVdoxDANqDu96g00YnVxxODx7DSep36dr9mLzWlP_k2NwAyxBV5NukYULdGunCjvWuv7wEyPHmUMRN4xntbhd5EhZThpN93PD6AhzcYy-OV9ZUB41L7bslnZEPU0kpG9oQbvj9hRoKJR7FyRPnHaUqJD7riOXwYjB57vk7lTCaxzsQs1i21dlQvdetu83drMTdV-02V_XuB5zucYPvaCUx7v-PUUy3A - response: - status: - code: 200 - message: OK - headers: - Cache-Control: - - no-store - Content-Type: - - application/json - Date: - - Wed, 14 Jun 2017 10:49:03 GMT - Content-Length: - - '915' - body: - encoding: UTF-8 - string: '{"kind":"ComponentStatusList","apiVersion":"v1","metadata":{"selfLink":"/api/v1/componentstatuses"},"items":[{"metadata":{"name":"scheduler","selfLink":"/api/v1/componentstatuses/scheduler","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - http://127.0.0.1:10251/healthz: dial tcp 127.0.0.1:10251: getsockopt: connection - refused"}]},{"metadata":{"name":"controller-manager","selfLink":"/api/v1/componentstatuses/controller-manager","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - http://127.0.0.1:10252/healthz: dial tcp 127.0.0.1:10252: getsockopt: connection - refused"}]},{"metadata":{"name":"etcd-0","selfLink":"/api/v1/componentstatuses/etcd-0","creationTimestamp":null},"conditions":[{"type":"Healthy","status":"False","message":"Get - https://host.example.com:4001/health: remote error: tls: bad - certificate"}]}]} - -' - http_version: + http_version: recorded_at: Wed, 14 Jun 2017 10:50:38 GMT - request: method: get