Commit a29517dd authored by Jose Ivan Vargas's avatar Jose Ivan Vargas

Added tests for the repository_controller and repository_helper

Added specs for the deploy_keys_presenter and added a new method in the presenter
called #key_available?

Fixed some minor UX inconsistencies and added a concern to handle
redirection
parent 336b818b
module RedirectRequest
extend ActiveSupport::Concern
def redirect_to_repository_settings(project)
redirect_to namespace_project_settings_repository_path(project.namespace, project)
end
end
class Projects::DeployKeysController < Projects::ApplicationController class Projects::DeployKeysController < Projects::ApplicationController
include RedirectRequest
respond_to :html respond_to :html
# Authorize # Authorize
...@@ -7,32 +8,32 @@ class Projects::DeployKeysController < Projects::ApplicationController ...@@ -7,32 +8,32 @@ class Projects::DeployKeysController < Projects::ApplicationController
layout "project_settings" layout "project_settings"
def index def index
redirect_to namespace_project_settings_repository_path(@project.namespace, @project) redirect_to_repository_settings(@project)
end end
def new def new
redirect_to namespace_project_settings_repository_path(@project.namespace, @project) redirect_to_repository_settings(@project)
end end
def create def create
@key = DeployKey.new(deploy_key_params.merge(user: current_user)) @key = DeployKey.new(deploy_key_params.merge(user: current_user))
unless @key.valid? && @project.deploy_keys << @key unless @key.valid? && @project.deploy_keys << @key
flash[:alert] = @key.errors.full_messages.join(',').html_safe flash[:alert] = @key.errors.full_messages.join(', ').html_safe
end end
redirect_to namespace_project_settings_repository_path(@project.namespace, @project) redirect_to_repository_settings(@project)
end end
def enable def enable
Projects::EnableDeployKeyService.new(@project, current_user, params).execute Projects::EnableDeployKeyService.new(@project, current_user, params).execute
redirect_to namespace_project_settings_repository_path(@project.namespace, @project) redirect_to_repository_settings(@project)
end end
def disable def disable
@project.deploy_keys_projects.find_by(deploy_key_id: params[:id]).destroy @project.deploy_keys_projects.find_by(deploy_key_id: params[:id]).destroy
redirect_to namespace_project_settings_repository_path(@project.namespace, @project) redirect_to_repository_settings(@project)
end end
protected protected
......
class Projects::ProtectedBranchesController < Projects::ApplicationController class Projects::ProtectedBranchesController < Projects::ApplicationController
include RedirectRequest
# Authorize # Authorize
before_action :require_non_empty_project before_action :require_non_empty_project
before_action :authorize_admin_project! before_action :authorize_admin_project!
...@@ -7,15 +8,15 @@ class Projects::ProtectedBranchesController < Projects::ApplicationController ...@@ -7,15 +8,15 @@ class Projects::ProtectedBranchesController < Projects::ApplicationController
layout "project_settings" layout "project_settings"
def index def index
redirect_to namespace_project_settings_repository_path(@project.namespace, @project) redirect_to_repository_settings(@project)
end end
def create def create
@protected_branch = ::ProtectedBranches::CreateService.new(@project, current_user, protected_branch_params).execute @protected_branch = ::ProtectedBranches::CreateService.new(@project, current_user, protected_branch_params).execute
unless @protected_branch.persisted? unless @protected_branch.persisted?
flash[:alert] = @protected_branches.errors.full_messages.join(',').html_safe flash[:alert] = @protected_branches.errors.full_messages.join(', ').html_safe
end end
redirect_to namespace_project_settings_repository_path(@project.namespace, @project) redirect_to_repository_settings(@project)
end end
def show def show
...@@ -40,7 +41,7 @@ class Projects::ProtectedBranchesController < Projects::ApplicationController ...@@ -40,7 +41,7 @@ class Projects::ProtectedBranchesController < Projects::ApplicationController
@protected_branch.destroy @protected_branch.destroy
respond_to do |format| respond_to do |format|
format.html { redirect_to namespace_project_settings_repository_path } format.html { redirect_to_repository_settings(@project) }
format.js { head :ok } format.js { head :ok }
end end
end end
...@@ -56,8 +57,4 @@ class Projects::ProtectedBranchesController < Projects::ApplicationController ...@@ -56,8 +57,4 @@ class Projects::ProtectedBranchesController < Projects::ApplicationController
merge_access_levels_attributes: [:access_level, :id], merge_access_levels_attributes: [:access_level, :id],
push_access_levels_attributes: [:access_level, :id]) push_access_levels_attributes: [:access_level, :id])
end end
def load_protected_branches
@protected_branches = @project.protected_branches.order(:name).page(params[:page])
end
end end
...@@ -4,25 +4,25 @@ module Projects ...@@ -4,25 +4,25 @@ module Projects
include RepositoryHelper include RepositoryHelper
before_action :authorize_admin_project! before_action :authorize_admin_project!
before_action :load_protected_branches, only: [:show]
def show def show
@deploy_keys = DeployKeysPresenter @deploy_keys = DeployKeysPresenter
.new(@project, current_user: @current_user) .new(@project, current_user: @current_user)
define_protected_branches_controller define_protected_branches
end
def load_protected_branches
@protected_branches = @project.protected_branches.order(:name).page(params[:page])
end end
private private
def define_protected_branches_controller def define_protected_branches
load_protected_branches
@protected_branch = @project.protected_branches.new @protected_branch = @project.protected_branches.new
load_gon_index load_gon_index
end end
def load_protected_branches
@protected_branches = @project.protected_branches.order(:name).page(params[:page])
end
end end
end end
end end
...@@ -2,16 +2,22 @@ module RepositoryHelper ...@@ -2,16 +2,22 @@ module RepositoryHelper
def access_levels_options def access_levels_options
{ {
push_access_levels: { push_access_levels: {
"Roles" => ProtectedBranch::PushAccessLevel.human_access_levels.map { |id, text| { id: id, text: text, before_divider: true } }, "Roles" => ProtectedBranch::PushAccessLevel.human_access_levels.map do |id, text|
{ id: id, text: text, before_divider: true }
end
}, },
merge_access_levels: { merge_access_levels: {
"Roles" => ProtectedBranch::MergeAccessLevel.human_access_levels.map { |id, text| { id: id, text: text, before_divider: true } } "Roles" => ProtectedBranch::MergeAccessLevel.human_access_levels.map do |id, text|
{ id: id, text: text, before_divider: true }
end
} }
} }
end end
def load_gon_index def load_gon_index
params = { open_branches: @project.open_branches.map { |br| { text: br.name, id: br.name, title: br.name } } } params = { open_branches: @project.open_branches.map do |br|
{ text: br.name, id: br.name, title: br.name }
end }
gon.push(params.merge(access_levels_options)) gon.push(params.merge(access_levels_options))
end end
end end
...@@ -35,6 +35,10 @@ module Projects ...@@ -35,6 +35,10 @@ module Projects
available_project_keys.size available_project_keys.size
end end
def key_available?(deploy_key)
available_keys.include?(deploy_key)
end
def available_public_keys def available_public_keys
return @available_public_keys if defined?(@available_public_keys) return @available_public_keys if defined?(@available_public_keys)
......
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
%span.key-created-at %span.key-created-at
created #{time_ago_with_tooltip(deploy_key.created_at)} created #{time_ago_with_tooltip(deploy_key.created_at)}
.visible-xs-block.visible-sm-block .visible-xs-block.visible-sm-block
- if @deploy_keys.available_keys.include?(deploy_key) - if @deploy_keys.key_available?(deploy_key)
= link_to enable_namespace_project_deploy_key_path(@project.namespace, @project, deploy_key), class: "btn btn-sm prepend-left-10", method: :put do = link_to enable_namespace_project_deploy_key_path(@project.namespace, @project, deploy_key), class: "btn btn-sm prepend-left-10", method: :put do
Enable Enable
- else - else
......
...@@ -19,7 +19,7 @@ ...@@ -19,7 +19,7 @@
= render partial: 'projects/deploy_keys/deploy_key', locals: {deploy_key: enabled_key} = render partial: 'projects/deploy_keys/deploy_key', locals: {deploy_key: enabled_key}
- else - else
.settings-message.text-center .settings-message.text-center
No deploy keys found. Create one with the form above or add existing one below. No deploy keys found. Create one with the form above.
%h5.prepend-top-default %h5.prepend-top-default
Deploy keys from projects you have access to (#{@deploy_keys.available_project_keys_size}) Deploy keys from projects you have access to (#{@deploy_keys.available_project_keys_size})
- if @deploy_keys.any_available_project_keys_enabled? - if @deploy_keys.any_available_project_keys_enabled?
......
--- ---
title: Combined deploy keys and push rules settings options into a single one called title: Combined deploy keys, push rules, protect branches and mirror repository settings options into a single one called
Repository Repository
merge_request: merge_request:
author: author:
require 'spec_helper'
describe Projects::Settings::IntegrationsController do
let(:project) { create(:empty_project, :public) }
let(:user) { create(:user) }
before do
project.team << [user, :master]
sign_in(user)
end
describe 'GET show' do
it 'renders show with 200 status code' do
get :show, namespace_id: project.namespace, project_id: project
expect(response).to have_http_status(200)
expect(response).to render_template(:show)
end
end
end
require 'spec_helper'
describe RepositoryHelper do
let(:user) { create(:user, :admin) }
let(:project) { create(:project, :repository) }
before do
project.protected_branches.create(name: 'master')
end
describe 'Access Level Options' do
it 'has three push access levels' do
push_access_levels = helper.access_levels_options[:push_access_levels]["Roles"]
expect(push_access_levels.size).to eq(3)
end
it 'has one merge access level' do
merge_access_levels = helper.access_levels_options[:merge_access_levels]["Roles"]
expect(merge_access_levels.size).to eq(2)
end
end
end
...@@ -3,6 +3,11 @@ require 'spec_helper' ...@@ -3,6 +3,11 @@ require 'spec_helper'
describe Projects::Settings::DeployKeysPresenter do describe Projects::Settings::DeployKeysPresenter do
let(:project) { create(:empty_project) } let(:project) { create(:empty_project) }
let(:user) { create(:user) } let(:user) { create(:user) }
let(:deploy_key) { create(:deploy_key, public: true) }
let!(:deploy_keys_project) do
create(:deploy_keys_project, project: project, deploy_key: deploy_key)
end
subject(:presenter) do subject(:presenter) do
described_class.new(project, current_user: user) described_class.new(project, current_user: user)
...@@ -13,16 +18,42 @@ describe Projects::Settings::DeployKeysPresenter do ...@@ -13,16 +18,42 @@ describe Projects::Settings::DeployKeysPresenter do
end end
describe '#enabled_keys' do describe '#enabled_keys' do
let(:deploy_key) do it 'returns currently enabled keys' do
create(:deploy_keys_project, project: project).deploy_key expect(presenter.enabled_keys).to eq [deploy_keys_project.deploy_key]
end
it 'returns project keys' do
expect(presenter.enabled_keys).to eq [deploy_key]
end end
it 'does not contain enabled_keys inside available_keys' do it 'does not contain enabled_keys inside available_keys' do
expect(presenter.available_keys).not_to include deploy_key expect(presenter.available_keys).not_to include deploy_key
end end
it 'returns the enabled_keys size' do
expect(presenter.enabled_keys_size).to eq(1)
end
it 'returns true if there is any enabled_keys' do
expect(presenter.any_keys_enabled?).to eq(true)
end
end
describe '#available_keys/#available_project_keys' do
it 'returns the current available_keys' do
expect(presenter.available_keys).to be_empty
end
it 'returns the current available_project_keys' do
expect(presenter.available_project_keys).to be_empty
end
it 'returns if any available_project_keys are enabled' do
expect(presenter.any_available_project_keys_enabled?).to eq(false)
end
it 'returns the available_project_keys size' do
expect(presenter.available_project_keys_size).to eq(0)
end
it 'shows if there is an available key' do
expect(presenter.key_available?(deploy_key)).to eq(false)
end
end end
end end
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