Commit cf21f45c authored by GitLab Bot's avatar GitLab Bot

Automatic merge of gitlab-org/gitlab-ce master

parents 8f066ece 0a69dbd2
...@@ -18,7 +18,7 @@ export default () => { ...@@ -18,7 +18,7 @@ export default () => {
new MilestoneSelect(); new MilestoneSelect();
new IssuableTemplateSelectors(); new IssuableTemplateSelectors();
if (gon.features.issueSuggestions && gon.features.graphql) { if (gon.features.graphql) {
initSuggestions(); initSuggestions();
} }
......
...@@ -43,6 +43,6 @@ class GraphqlController < ApplicationController ...@@ -43,6 +43,6 @@ class GraphqlController < ApplicationController
end end
def check_graphql_feature_flag! def check_graphql_feature_flag!
render_404 unless Feature.enabled?(:graphql) render_404 unless Gitlab::Graphql.enabled?
end end
end end
...@@ -270,7 +270,6 @@ class Projects::IssuesController < Projects::ApplicationController ...@@ -270,7 +270,6 @@ class Projects::IssuesController < Projects::ApplicationController
end end
def set_suggested_issues_feature_flags def set_suggested_issues_feature_flags
push_frontend_feature_flag(:graphql) push_frontend_feature_flag(:graphql, default_enabled: true)
push_frontend_feature_flag(:issue_suggestions)
end end
end end
...@@ -12,6 +12,14 @@ module Clusters ...@@ -12,6 +12,14 @@ module Clusters
can?(current_user, :update_cluster, cluster) && created? can?(current_user, :update_cluster, cluster) && created?
end end
def cluster_type_description
if cluster.project_type?
s_("ClusterIntegration|Project cluster")
elsif cluster.group_type?
s_("ClusterIntegration|Group cluster")
end
end
def show_path def show_path
if cluster.project_type? if cluster.project_type?
project_cluster_path(project, cluster) project_cluster_path(project, cluster)
......
...@@ -13,4 +13,4 @@ ...@@ -13,4 +13,4 @@
.table-mobile-header{ role: "rowheader" } .table-mobile-header{ role: "rowheader" }
.table-mobile-content .table-mobile-content
%span.badge.badge-light %span.badge.badge-light
= cluster.project_type? ? s_("ClusterIntegration|Project cluster") : s_("ClusterIntegration|Group cluster") = cluster.cluster_type_description
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
= render 'shared/issuable/form/template_selector', issuable: issuable = render 'shared/issuable/form/template_selector', issuable: issuable
= render 'shared/issuable/form/title', issuable: issuable, form: form, has_wip_commits: commits && commits.detect(&:work_in_progress?) = render 'shared/issuable/form/title', issuable: issuable, form: form, has_wip_commits: commits && commits.detect(&:work_in_progress?)
- if Feature.enabled?(:issue_suggestions) && Feature.enabled?(:graphql) - if Gitlab::Graphql.enabled?
#js-suggestions{ data: { project_path: @project.full_path } } #js-suggestions{ data: { project_path: @project.full_path } }
= render 'shared/form_elements/description', model: issuable, form: form, project: project = render 'shared/form_elements/description', model: issuable, form: form, project: project
......
constraints(::Constraints::FeatureConstrainer.new(:graphql)) do constraints(::Constraints::FeatureConstrainer.new(:graphql, default_enabled: true)) do
post '/api/graphql', to: 'graphql#execute' post '/api/graphql', to: 'graphql#execute'
mount GraphiQL::Rails::Engine, at: '/-/graphql-explorer', graphql_path: '/api/graphql' mount GraphiQL::Rails::Engine, at: '/-/graphql-explorer', graphql_path: '/api/graphql'
end end
......
...@@ -2,14 +2,14 @@ ...@@ -2,14 +2,14 @@
module Constraints module Constraints
class FeatureConstrainer class FeatureConstrainer
attr_reader :feature attr_reader :args
def initialize(feature) def initialize(*args)
@feature = feature @args = args
end end
def matches?(_request) def matches?(_request)
Feature.enabled?(feature) Feature.enabled?(*args)
end end
end end
end end
...@@ -3,5 +3,9 @@ ...@@ -3,5 +3,9 @@
module Gitlab module Gitlab
module Graphql module Graphql
StandardGraphqlError = Class.new(StandardError) StandardGraphqlError = Class.new(StandardError)
def self.enabled?
Feature.enabled?(:graphql, default_enabled: true)
end
end end
end end
# frozen_string_literal: true
require "spec_helper" require "spec_helper"
describe "User creates issue" do describe "User creates issue" do
...@@ -64,10 +66,10 @@ describe "User creates issue" do ...@@ -64,10 +66,10 @@ describe "User creates issue" do
end end
context "with labels" do context "with labels" do
LABEL_TITLES = %w(bug feature enhancement).freeze let(:label_titles) { %w(bug feature enhancement) }
before do before do
LABEL_TITLES.each do |title| label_titles.each do |title|
create(:label, project: project, title: title) create(:label, project: project, title: title)
end end
end end
...@@ -77,13 +79,13 @@ describe "User creates issue" do ...@@ -77,13 +79,13 @@ describe "User creates issue" do
fill_in("Title", with: issue_title) fill_in("Title", with: issue_title)
click_button("Label") click_button("Label")
click_link(LABEL_TITLES.first) click_link(label_titles.first)
click_button("Submit issue") click_button("Submit issue")
expect(page).to have_content(issue_title) expect(page).to have_content(issue_title)
.and have_content(user.name) .and have_content(user.name)
.and have_content(project.name) .and have_content(project.name)
.and have_content(LABEL_TITLES.first) .and have_content(label_titles.first)
end end
end end
end end
......
# frozen_string_literal: true
require "spec_helper" require "spec_helper"
describe "User views labels" do describe "User views labels" do
set(:project) { create(:project_empty_repo, :public) } set(:project) { create(:project_empty_repo, :public) }
set(:user) { create(:user) } set(:user) { create(:user) }
LABEL_TITLES = %w[bug enhancement feature].freeze let(:label_titles) { %w[bug enhancement feature] }
before do before do
LABEL_TITLES.each { |title| create(:label, project: project, title: title) } label_titles.each { |title| create(:label, project: project, title: title) }
project.add_guest(user) project.add_guest(user)
sign_in(user) sign_in(user)
...@@ -17,7 +19,7 @@ describe "User views labels" do ...@@ -17,7 +19,7 @@ describe "User views labels" do
it "shows all labels" do it "shows all labels" do
page.within('.other-labels .manage-labels-list') do page.within('.other-labels .manage-labels-list') do
LABEL_TITLES.each { |title| expect(page).to have_content(title) } label_titles.each { |title| expect(page).to have_content(title) }
end end
end end
end end
require 'spec_helper'
describe Constraints::FeatureConstrainer do
describe '#matches' do
it 'calls Feature.enabled? with the correct arguments' do
expect(Feature).to receive(:enabled?).with(:feature_name, "an object", default_enabled: true)
described_class.new(:feature_name, "an object", default_enabled: true).matches?(double('request'))
end
end
end
...@@ -6,8 +6,18 @@ describe Gitlab::BackgroundMigration::MigrateBuildStage, :migration, schema: 201 ...@@ -6,8 +6,18 @@ describe Gitlab::BackgroundMigration::MigrateBuildStage, :migration, schema: 201
let(:stages) { table(:ci_stages) } let(:stages) { table(:ci_stages) }
let(:jobs) { table(:ci_builds) } let(:jobs) { table(:ci_builds) }
STATUSES = { created: 0, pending: 1, running: 2, success: 3, let(:statuses) do
failed: 4, canceled: 5, skipped: 6, manual: 7 }.freeze {
created: 0,
pending: 1,
running: 2,
success: 3,
failed: 4,
canceled: 5,
skipped: 6,
manual: 7
}
end
before do before do
projects.create!(id: 123, name: 'gitlab', path: 'gitlab-ce') projects.create!(id: 123, name: 'gitlab', path: 'gitlab-ce')
...@@ -36,9 +46,9 @@ describe Gitlab::BackgroundMigration::MigrateBuildStage, :migration, schema: 201 ...@@ -36,9 +46,9 @@ describe Gitlab::BackgroundMigration::MigrateBuildStage, :migration, schema: 201
expect(stages.all.pluck(:name)).to match_array %w[test build deploy] expect(stages.all.pluck(:name)).to match_array %w[test build deploy]
expect(jobs.where(stage_id: nil)).to be_one expect(jobs.where(stage_id: nil)).to be_one
expect(jobs.find_by(stage_id: nil).id).to eq 6 expect(jobs.find_by(stage_id: nil).id).to eq 6
expect(stages.all.pluck(:status)).to match_array [STATUSES[:success], expect(stages.all.pluck(:status)).to match_array [statuses[:success],
STATUSES[:failed], statuses[:failed],
STATUSES[:pending]] statuses[:pending]]
end end
it 'recovers from unique constraint violation only twice' do it 'recovers from unique constraint violation only twice' do
......
# frozen_string_literal: true
require 'spec_helper' require 'spec_helper'
describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20170711145320 do describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20170711145320 do
...@@ -6,8 +8,18 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20 ...@@ -6,8 +8,18 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20
let(:stages) { table(:ci_stages) } let(:stages) { table(:ci_stages) }
let(:jobs) { table(:ci_builds) } let(:jobs) { table(:ci_builds) }
STATUSES = { created: 0, pending: 1, running: 2, success: 3, let(:statuses) do
failed: 4, canceled: 5, skipped: 6, manual: 7 }.freeze {
created: 0,
pending: 1,
running: 2,
success: 3,
failed: 4,
canceled: 5,
skipped: 6,
manual: 7
}
end
before do before do
projects.create!(id: 1, name: 'gitlab1', path: 'gitlab1') projects.create!(id: 1, name: 'gitlab1', path: 'gitlab1')
...@@ -26,8 +38,8 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20 ...@@ -26,8 +38,8 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20
it 'sets a correct stage status' do it 'sets a correct stage status' do
described_class.new.perform(1, 2) described_class.new.perform(1, 2)
expect(stages.first.status).to eq STATUSES[:running] expect(stages.first.status).to eq statuses[:running]
expect(stages.second.status).to eq STATUSES[:failed] expect(stages.second.status).to eq statuses[:failed]
end end
end end
...@@ -35,8 +47,8 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20 ...@@ -35,8 +47,8 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20
it 'sets a skipped stage status' do it 'sets a skipped stage status' do
described_class.new.perform(1, 2) described_class.new.perform(1, 2)
expect(stages.first.status).to eq STATUSES[:skipped] expect(stages.first.status).to eq statuses[:skipped]
expect(stages.second.status).to eq STATUSES[:skipped] expect(stages.second.status).to eq statuses[:skipped]
end end
end end
...@@ -50,8 +62,8 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20 ...@@ -50,8 +62,8 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20
it 'sets a correct stage status' do it 'sets a correct stage status' do
described_class.new.perform(1, 2) described_class.new.perform(1, 2)
expect(stages.first.status).to eq STATUSES[:canceled] expect(stages.first.status).to eq statuses[:canceled]
expect(stages.second.status).to eq STATUSES[:success] expect(stages.second.status).to eq statuses[:success]
end end
end end
...@@ -65,8 +77,8 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20 ...@@ -65,8 +77,8 @@ describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20
it 'sets a correct stage status' do it 'sets a correct stage status' do
described_class.new.perform(1, 2) described_class.new.perform(1, 2)
expect(stages.first.status).to eq STATUSES[:manual] expect(stages.first.status).to eq statuses[:manual]
expect(stages.second.status).to eq STATUSES[:success] expect(stages.second.status).to eq statuses[:success]
end end
end end
......
...@@ -74,6 +74,20 @@ describe Clusters::ClusterPresenter do ...@@ -74,6 +74,20 @@ describe Clusters::ClusterPresenter do
end end
end end
describe '#cluster_type_description' do
subject { described_class.new(cluster).cluster_type_description }
context 'project_type cluster' do
it { is_expected.to eq('Project cluster') }
end
context 'group_type cluster' do
let(:cluster) { create(:cluster, :provided_by_gcp, :group) }
it { is_expected.to eq('Group cluster') }
end
end
describe '#show_path' do describe '#show_path' do
subject { described_class.new(cluster).show_path } subject { described_class.new(cluster).show_path }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment