Welcome to mirror list, hosted at ThFree Co, Russian Federation.

functions_finder_spec.rb « serverless « projects « finders « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 8aea45b457c24e65fd886e6214e8c57a1c4dea16 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
# frozen_string_literal: true

require 'spec_helper'

describe Projects::Serverless::FunctionsFinder do
  include KubernetesHelpers
  include PrometheusHelpers
  include ReactiveCachingHelpers

  let(:user) { create(:user) }
  let(:cluster) { create(:cluster, :project, :provided_by_gcp) }
  let(:service) { cluster.platform_kubernetes }
  let(:project) { cluster.project }

  let(:namespace) do
    create(:cluster_kubernetes_namespace,
      cluster: cluster,
      cluster_project: cluster.cluster_project,
      project: cluster.cluster_project.project)
  end

  before do
    project.add_maintainer(user)
  end

  describe '#installed' do
    it 'when reactive_caching is still fetching data' do
      expect(described_class.new(project).knative_installed).to eq 'checking'
    end

    context 'when reactive_caching has finished' do
      let(:knative_services_finder) { project.clusters.first.knative_services_finder(project) }

      before do
        allow_any_instance_of(Clusters::Cluster)
          .to receive(:knative_services_finder)
          .and_return(knative_services_finder)
        synchronous_reactive_cache(knative_services_finder)
      end

      context 'when knative is not installed' do
        it 'returns false' do
          stub_kubeclient_discover_knative_not_found(service.api_url)

          expect(described_class.new(project).knative_installed).to eq false
        end
      end

      context 'reactive_caching is finished and knative is installed' do
        let(:knative_services_finder) { project.clusters.first.knative_services_finder(project) }

        it 'returns true' do
          stub_kubeclient_knative_services(namespace: namespace.namespace)
          stub_kubeclient_service_pods(nil, namespace: namespace.namespace)

          expect(described_class.new(project).knative_installed).to be true
        end
      end
    end
  end

  describe 'retrieve data from knative' do
    context 'does not have knative installed' do
      it { expect(described_class.new(project).execute).to be_empty }
    end

    context 'has knative installed' do
      let!(:knative) { create(:clusters_applications_knative, :installed, cluster: cluster) }
      let(:finder) { described_class.new(project) }

      it 'there are no functions' do
        expect(finder.execute).to be_empty
      end

      it 'there are functions', :use_clean_rails_memory_store_caching do
        stub_kubeclient_service_pods
        stub_reactive_cache(cluster.knative_services_finder(project),
          {
            services: kube_knative_services_body(namespace: namespace.namespace, name: cluster.project.name)["items"],
            pods: kube_knative_pods_body(cluster.project.name, namespace.namespace)["items"]
          },
          *cluster.knative_services_finder(project).cache_args)

        expect(finder.execute).not_to be_empty
      end

      it 'has a function', :use_clean_rails_memory_store_caching do
        stub_kubeclient_service_pods
        stub_reactive_cache(cluster.knative_services_finder(project),
          {
            services: kube_knative_services_body(namespace: namespace.namespace, name: cluster.project.name)["items"],
            pods: kube_knative_pods_body(cluster.project.name, namespace.namespace)["items"]
          },
          *cluster.knative_services_finder(project).cache_args)

        result = finder.service(cluster.environment_scope, cluster.project.name)
        expect(result).not_to be_empty
        expect(result["metadata"]["name"]).to be_eql(cluster.project.name)
      end

      it 'has metrics', :use_clean_rails_memory_store_caching do
      end
    end

    context 'has prometheus' do
      let(:prometheus_adapter) { double('prometheus_adapter', can_query?: true) }
      let!(:knative) { create(:clusters_applications_knative, :installed, cluster: cluster) }
      let!(:prometheus) { create(:clusters_applications_prometheus, :installed, cluster: cluster) }
      let(:finder) { described_class.new(project) }

      before do
        allow(finder).to receive(:prometheus_adapter).and_return(prometheus_adapter)
        allow(prometheus_adapter).to receive(:query).and_return(prometheus_empty_body('matrix'))
      end

      it 'is available' do
        expect(finder.has_prometheus?("*")).to be true
      end

      it 'has query data' do
        expect(finder.invocation_metrics("*", cluster.project.name)).not_to be_nil
      end
    end
  end
end