debian-mirror-gitlab/spec/controllers/every_controller_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

71 lines
2.5 KiB
Ruby
Raw Permalink Normal View History

2020-07-28 23:09:34 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
2020-07-28 23:09:34 +05:30
RSpec.describe "Every controller" do
context "feature categories" do
let_it_be(:feature_categories) do
2021-11-18 22:05:49 +05:30
Gitlab::FeatureCategories.default.categories.map(&:to_sym).to_set
2020-07-28 23:09:34 +05:30
end
let_it_be(:controller_actions) do
2021-11-18 22:05:49 +05:30
Gitlab::RequestEndpoints.all_controller_actions
2020-07-28 23:09:34 +05:30
end
let_it_be(:routes_without_category) do
controller_actions.map do |controller, action|
2021-01-03 14:25:43 +05:30
next if controller.feature_category_for_action(action)
"#{controller}##{action}"
2020-07-28 23:09:34 +05:30
end.compact
end
it "has feature categories" do
2021-01-03 14:25:43 +05:30
expect(routes_without_category).to be_empty, "#{routes_without_category} did not have a category"
2020-07-28 23:09:34 +05:30
end
it "completed controllers don't get new routes without categories" do
completed_controllers = [Projects::MergeRequestsController].map(&:to_s)
newly_introduced_missing_category = routes_without_category.select do |route|
completed_controllers.any? { |controller| route.start_with?(controller) }
end
expect(newly_introduced_missing_category).to be_empty
end
it "recognizes the feature categories" do
routes_unknown_category = controller_actions.map do |controller, action|
used_category = controller.feature_category_for_action(action)
next unless used_category
next if used_category == :not_owned
["#{controller}##{action}", used_category] unless feature_categories.include?(used_category)
end.compact
expect(routes_unknown_category).to be_empty, "#{routes_unknown_category.first(10)} had an unknown category"
end
it "doesn't define or exclude categories on removed actions", :aggregate_failures do
controller_actions.group_by(&:first).each do |controller, controller_action|
existing_actions = controller_action.map(&:last)
used_actions = actions_defined_in_feature_category_config(controller)
non_existing_used_actions = used_actions - existing_actions
expect(non_existing_used_actions).to be_empty,
2023-05-27 22:25:52 +05:30
"#{controller} used #{non_existing_used_actions} to define feature category, but the route does not exist"
2020-07-28 23:09:34 +05:30
end
end
end
def constantize_controller(name)
"#{name.camelize}Controller".constantize
rescue NameError
nil # some controllers, like the omniauth ones are dynamic
end
def actions_defined_in_feature_category_config(controller)
2021-11-18 22:05:49 +05:30
controller.send(:class_attributes)[:endpoint_attributes_config].defined_actions
2020-07-28 23:09:34 +05:30
end
end