202 lines
6.2 KiB
Ruby
202 lines
6.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe EnvironmentEntity do
|
|
include KubernetesHelpers
|
|
include Gitlab::Routing.url_helpers
|
|
|
|
let(:request) { double('request', current_user: user, project: project) }
|
|
let(:entity) do
|
|
described_class.new(environment, request: request)
|
|
end
|
|
|
|
let_it_be(:user) { create(:user) }
|
|
let_it_be(:project) { create(:project, :repository) }
|
|
let_it_be(:environment, refind: true) { create(:environment, project: project) }
|
|
|
|
before_all do
|
|
project.add_developer(user)
|
|
end
|
|
|
|
before do
|
|
allow(request).to receive(:current_user).and_return(user)
|
|
allow(request).to receive(:project).and_return(project)
|
|
end
|
|
|
|
subject { entity.as_json }
|
|
|
|
it 'exposes latest deployment' do
|
|
expect(subject).to include(:last_deployment)
|
|
end
|
|
|
|
it 'exposes core elements of environment' do
|
|
expect(subject).to include(:id, :global_id, :name, :state, :environment_path, :tier)
|
|
end
|
|
|
|
it 'exposes folder path' do
|
|
expect(subject).to include(:folder_path)
|
|
end
|
|
|
|
context 'when there is a successful deployment' do
|
|
let!(:pipeline) { create(:ci_pipeline, :success, project: project) }
|
|
let!(:deployable) { create(:ci_build, :success, project: project, pipeline: pipeline) }
|
|
let!(:deployment) { create(:deployment, :success, project: project, environment: environment, deployable: deployable) }
|
|
|
|
it 'exposes it as the latest deployment' do
|
|
expect(subject[:last_deployment][:sha]).to eq(deployment.sha)
|
|
end
|
|
|
|
it 'does not expose it as an upcoming deployment' do
|
|
expect(subject[:upcoming_deployment]).to be_nil
|
|
end
|
|
|
|
context 'when the deployment pipeline has the other manual job' do
|
|
let!(:manual_job) { create(:ci_build, :manual, name: 'stop-review', project: project, pipeline: pipeline) }
|
|
|
|
it 'exposes the manual job in the latest deployment' do
|
|
expect(subject[:last_deployment][:manual_actions].first[:name])
|
|
.to eq(manual_job.name)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when there is a running deployment' do
|
|
let!(:pipeline) { create(:ci_pipeline, :running, project: project) }
|
|
let!(:deployable) { create(:ci_build, :running, project: project, pipeline: pipeline) }
|
|
let!(:deployment) { create(:deployment, :running, project: project, environment: environment, deployable: deployable) }
|
|
|
|
it 'does not expose it as the latest deployment' do
|
|
expect(subject[:last_deployment]).to be_nil
|
|
end
|
|
|
|
it 'exposes it as an upcoming deployment' do
|
|
expect(subject[:upcoming_deployment][:sha]).to eq(deployment.sha)
|
|
end
|
|
|
|
context 'when the deployment pipeline has the other manual job' do
|
|
let!(:manual_job) { create(:ci_build, :manual, name: 'stop-review', project: project, pipeline: pipeline) }
|
|
|
|
it 'does not expose the manual job in the latest deployment' do
|
|
expect(subject[:upcoming_deployment][:manual_actions]).to be_nil
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'metrics disabled' do
|
|
before do
|
|
allow(environment).to receive(:has_metrics?).and_return(false)
|
|
end
|
|
|
|
it "doesn't expose metrics path" do
|
|
expect(subject).not_to include(:metrics_path)
|
|
end
|
|
end
|
|
|
|
context 'metrics enabled' do
|
|
before do
|
|
allow(environment).to receive(:has_metrics?).and_return(true)
|
|
end
|
|
|
|
it 'exposes metrics path' do
|
|
expect(subject).to include(:metrics_path)
|
|
end
|
|
end
|
|
|
|
context 'with deployment platform' do
|
|
let(:project) { create(:project, :repository) }
|
|
let(:environment) { create(:environment, project: project) }
|
|
|
|
context 'when deployment platform is a cluster' do
|
|
before do
|
|
create(:cluster,
|
|
:provided_by_gcp,
|
|
:project,
|
|
environment_scope: '*',
|
|
projects: [project])
|
|
end
|
|
|
|
it 'includes cluster_type' do
|
|
expect(subject).to include(:cluster_type)
|
|
expect(subject[:cluster_type]).to eq('project_type')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with auto_stop_in' do
|
|
let(:environment) { create(:environment, :will_auto_stop, project: project) }
|
|
|
|
it 'exposes auto stop related information' do
|
|
project.add_maintainer(user)
|
|
|
|
expect(subject).to include(:cancel_auto_stop_path, :auto_stop_at)
|
|
end
|
|
end
|
|
|
|
context 'pod_logs' do
|
|
context 'with reporter access' do
|
|
before do
|
|
project.add_reporter(user)
|
|
end
|
|
|
|
it 'does not expose logs keys' do
|
|
expect(subject).not_to include(:logs_path)
|
|
expect(subject).not_to include(:logs_api_path)
|
|
expect(subject).not_to include(:enable_advanced_logs_querying)
|
|
end
|
|
end
|
|
|
|
context 'with developer access' do
|
|
before do
|
|
project.add_developer(user)
|
|
end
|
|
|
|
it 'exposes logs keys' do
|
|
expect(subject).to include(:logs_path)
|
|
expect(subject).to include(:logs_api_path)
|
|
expect(subject).to include(:enable_advanced_logs_querying)
|
|
end
|
|
|
|
it 'uses k8s api when ES is not available' do
|
|
expect(subject[:logs_api_path]).to eq(k8s_project_logs_path(project, environment_name: environment.name, format: :json))
|
|
end
|
|
|
|
it 'uses ES api when ES is available' do
|
|
allow(environment).to receive(:elastic_stack_available?).and_return(true)
|
|
|
|
expect(subject[:logs_api_path]).to eq(elasticsearch_project_logs_path(project, environment_name: environment.name, format: :json))
|
|
end
|
|
|
|
context 'with feature flag disabled' do
|
|
before do
|
|
stub_feature_flags(monitor_logging: false)
|
|
end
|
|
|
|
it 'does not expose logs keys' do
|
|
expect(subject).not_to include(:logs_path)
|
|
expect(subject).not_to include(:logs_api_path)
|
|
expect(subject).not_to include(:enable_advanced_logs_querying)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with deployment service ready' do
|
|
before do
|
|
allow(environment).to receive(:has_terminals?).and_return(true)
|
|
allow(environment).to receive(:rollout_status).and_return(kube_deployment_rollout_status)
|
|
end
|
|
|
|
it 'exposes rollout_status' do
|
|
expect(subject).to include(:rollout_status)
|
|
end
|
|
end
|
|
|
|
context 'with deployment service not ready' do
|
|
let(:user) { create(:user) }
|
|
|
|
it 'does not expose rollout_status' do
|
|
expect(subject).not_to include(:rollout_status)
|
|
end
|
|
end
|
|
end
|