Commit 1b60502b authored by James Edwards-Jones's avatar James Edwards-Jones

Renamed ProtectedTag push_access_levels to create_access_levels

parent 43acb71b
...@@ -11,20 +11,20 @@ ...@@ -11,20 +11,20 @@
} }
buildDropdowns() { buildDropdowns() {
const $allowedToPushDropdown = this.$wrap.find('.js-allowed-to-push'); const $allowedToCreateDropdown = this.$wrap.find('.js-allowed-to-create');
// Cache callback // Cache callback
this.onSelectCallback = this.onSelect.bind(this); this.onSelectCallback = this.onSelect.bind(this);
// Allowed to Push dropdown // Allowed to Create dropdown
new gl.ProtectedTagAccessDropdown({ new gl.ProtectedTagAccessDropdown({
$dropdown: $allowedToPushDropdown, $dropdown: $allowedToCreateDropdown,
data: gon.push_access_levels, data: gon.create_access_levels,
onSelect: this.onSelectCallback onSelect: this.onSelectCallback
}); });
// Select default // Select default
$allowedToPushDropdown.data('glDropdown').selectRowAtIndex(0); $allowedToCreateDropdown.data('glDropdown').selectRowAtIndex(0);
// Protected tag dropdown // Protected tag dropdown
new ProtectedTagDropdown({ new ProtectedTagDropdown({
...@@ -37,9 +37,9 @@ ...@@ -37,9 +37,9 @@
onSelect() { onSelect() {
// Enable submit button // Enable submit button
const $tagInput = this.$wrap.find('input[name="protected_tag[name]"]'); const $tagInput = this.$wrap.find('input[name="protected_tag[name]"]');
const $allowedToPushInput = this.$wrap.find('input[name="protected_tag[push_access_levels_attributes][0][access_level]"]'); const $allowedToCreateInput = this.$wrap.find('input[name="protected_tag[create_access_levels_attributes][0][access_level]"]');
this.$form.find('input[type="submit"]').attr('disabled', !($tagInput.val() && $allowedToPushInput.length)); this.$form.find('input[type="submit"]').attr('disabled', !($tagInput.val() && $allowedToCreateInput.length));
} }
}; };
})(window); })(window);
...@@ -7,27 +7,27 @@ ...@@ -7,27 +7,27 @@
gl.ProtectedTagEdit = class { gl.ProtectedTagEdit = class {
constructor(options) { constructor(options) {
this.$wrap = options.$wrap; this.$wrap = options.$wrap;
this.$allowedToPushDropdown = this.$wrap.find('.js-allowed-to-push'); this.$allowedToCreateDropdown = this.$wrap.find('.js-allowed-to-create');
this.buildDropdowns(); this.buildDropdowns();
} }
buildDropdowns() { buildDropdowns() {
// Allowed to push dropdown // Allowed to create dropdown
new gl.ProtectedTagAccessDropdown({ new gl.ProtectedTagAccessDropdown({
$dropdown: this.$allowedToPushDropdown, $dropdown: this.$allowedToCreateDropdown,
data: gon.push_access_levels, data: gon.create_access_levels,
onSelect: this.onSelect.bind(this) onSelect: this.onSelect.bind(this)
}); });
} }
onSelect() { onSelect() {
const $allowedToPushInput = this.$wrap.find(`input[name="${this.$allowedToPushDropdown.data('fieldName')}"]`); const $allowedToCreateInput = this.$wrap.find(`input[name="${this.$allowedToCreateDropdown.data('fieldName')}"]`);
// Do not update if one dropdown has not selected any option // Do not update if one dropdown has not selected any option
if (!$allowedToPushInput.length) return; if (!$allowedToCreateInput.length) return;
this.$allowedToPushDropdown.disable(); this.$allowedToCreateDropdown.disable();
$.ajax({ $.ajax({
type: 'POST', type: 'POST',
...@@ -36,9 +36,9 @@ ...@@ -36,9 +36,9 @@
data: { data: {
_method: 'PATCH', _method: 'PATCH',
protected_tag: { protected_tag: {
push_access_levels_attributes: [{ create_access_levels_attributes: [{
id: this.$allowedToPushDropdown.data('access-level-id'), id: this.$allowedToCreateDropdown.data('access-level-id'),
access_level: $allowedToPushInput.val() access_level: $allowedToCreateInput.val()
}] }]
} }
}, },
...@@ -47,7 +47,7 @@ ...@@ -47,7 +47,7 @@
new Flash('Failed to update tag!'); new Flash('Failed to update tag!');
} }
}).always(() => { }).always(() => {
this.$allowedToPushDropdown.enable(); this.$allowedToCreateDropdown.enable();
}); });
} }
}; };
......
...@@ -30,6 +30,6 @@ class Projects::ProtectedTagsController < Projects::ProtectedRefsController ...@@ -30,6 +30,6 @@ class Projects::ProtectedTagsController < Projects::ProtectedRefsController
end end
def protected_ref_params def protected_ref_params
params.require(:protected_tag).permit(:name, push_access_levels_attributes: [:access_level, :id]) params.require(:protected_tag).permit(:name, create_access_levels_attributes: [:access_level, :id])
end end
end end
...@@ -21,18 +21,17 @@ module Projects ...@@ -21,18 +21,17 @@ module Projects
def define_protected_refs def define_protected_refs
@protected_branches = @project.protected_branches.order(:name).page(params[:page]) @protected_branches = @project.protected_branches.order(:name).page(params[:page])
@protected_tags = @project.protected_tags.order(:name).page(params[:page]) #TODO duplicated pagination param? @protected_tags = @project.protected_tags.order(:name).page(params[:page])
@protected_branch = @project.protected_branches.new @protected_branch = @project.protected_branches.new
@protected_tag = @project.protected_tags.new @protected_tag = @project.protected_tags.new
load_gon_index load_gon_index
end end
def access_levels_options def access_levels_options
#TODO: consider protected tags
#TODO: Refactor ProtectedBranch::PushAccessLevel so it doesn't mention branches
{ {
selected_merge_access_levels: @protected_branch.merge_access_levels.map { |access_level| access_level.user_id || access_level.access_level }, selected_merge_access_levels: @protected_branch.merge_access_levels.map { |access_level| access_level.user_id || access_level.access_level },
selected_push_access_levels: @protected_branch.push_access_levels.map { |access_level| access_level.user_id || access_level.access_level }, selected_push_access_levels: @protected_branch.push_access_levels.map { |access_level| access_level.user_id || access_level.access_level },
create_access_levels: levels_for_dropdown(ProtectedTag::CreateAccessLevel),
push_access_levels: levels_for_dropdown(ProtectedBranch::PushAccessLevel), push_access_levels: levels_for_dropdown(ProtectedBranch::PushAccessLevel),
merge_access_levels: levels_for_dropdown(ProtectedBranch::MergeAccessLevel) merge_access_levels: levels_for_dropdown(ProtectedBranch::MergeAccessLevel)
} }
......
...@@ -2,11 +2,11 @@ class ProtectedTag < ActiveRecord::Base ...@@ -2,11 +2,11 @@ class ProtectedTag < ActiveRecord::Base
include Gitlab::ShellAdapter include Gitlab::ShellAdapter
include ProtectedRef include ProtectedRef
has_many :push_access_levels, dependent: :destroy has_many :create_access_levels, dependent: :destroy
validates :push_access_levels, length: { is: 1, message: "are restricted to a single instance per protected tag." } validates :create_access_levels, length: { is: 1, message: "are restricted to a single instance per protected tag." }
accepts_nested_attributes_for :push_access_levels accepts_nested_attributes_for :create_access_levels
def self.protected?(project, ref_name) def self.protected?(project, ref_name)
self.matching(ref_name, protected_refs: project.protected_tags).present? self.matching(ref_name, protected_refs: project.protected_tags).present?
......
class ProtectedTag::PushAccessLevel < ActiveRecord::Base class ProtectedTag::CreateAccessLevel < ActiveRecord::Base
include ProtectedTagAccess include ProtectedTagAccess
validates :access_level, presence: true, inclusion: { in: [Gitlab::Access::MASTER, validates :access_level, presence: true, inclusion: { in: [Gitlab::Access::MASTER,
......
...@@ -19,14 +19,14 @@ ...@@ -19,14 +19,14 @@
%code production/* %code production/*
are supported are supported
.form-group .form-group
%label.col-md-2.text-right{ for: 'push_access_levels_attributes' } %label.col-md-2.text-right{ for: 'create_access_levels_attributes' }
Allowed to push: Allowed to create:
.col-md-10 .col-md-10
.push_access_levels-container .create_access_levels-container
= dropdown_tag('Select', = dropdown_tag('Select',
options: { toggle_class: 'js-allowed-to-push wide', options: { toggle_class: 'js-allowed-to-create wide',
dropdown_class: 'dropdown-menu-selectable', dropdown_class: 'dropdown-menu-selectable',
data: { field_name: 'protected_tag[push_access_levels_attributes][0][access_level]', input_id: 'push_access_levels_attributes' }}) data: { field_name: 'protected_tag[create_access_levels_attributes][0][access_level]', input_id: 'create_access_levels_attributes' }})
.panel-footer .panel-footer
= f.submit 'Protect', class: 'btn-create btn', disabled: true = f.submit 'Protect', class: 'btn-create btn', disabled: true
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
%tr %tr
%th Protected tag (#{@protected_tags.size}) %th Protected tag (#{@protected_tags.size})
%th Last commit %th Last commit
%th Allowed to push %th Allowed to create
- if can_admin_project - if can_admin_project
%th %th
%tbody %tbody
......
%td %td
= hidden_field_tag "allowed_to_push_#{protected_tag.id}", protected_tag.push_access_levels.first.access_level = hidden_field_tag "allowed_to_create_#{protected_tag.id}", protected_tag.create_access_levels.first.access_level
= dropdown_tag( (protected_tag.push_access_levels.first.humanize || 'Select') , = dropdown_tag( (protected_tag.create_access_levels.first.humanize || 'Select') ,
options: { toggle_class: 'js-allowed-to-push', dropdown_class: 'dropdown-menu-selectable js-allowed-to-push-container', options: { toggle_class: 'js-allowed-to-create', dropdown_class: 'dropdown-menu-selectable js-allowed-to-create-container',
data: { field_name: "allowed_to_push_#{protected_tag.id}", access_level_id: protected_tag.push_access_levels.first.id }}) data: { field_name: "allowed_to_create_#{protected_tag.id}", access_level_id: protected_tag.create_access_levels.first.id }})
...@@ -15,14 +15,14 @@ class CreateProtectedTags < ActiveRecord::Migration ...@@ -15,14 +15,14 @@ class CreateProtectedTags < ActiveRecord::Migration
add_index :protected_tags, :project_id add_index :protected_tags, :project_id
create_table :protected_tag_push_access_levels do |t| create_table :protected_tag_create_access_levels do |t|
t.references :protected_tag, index: { name: "index_protected_tag_push_access" }, foreign_key: true, null: false t.references :protected_tag, index: { name: "index_protected_tag_create_access" }, foreign_key: true, null: false
t.integer :access_level, default: GITLAB_ACCESS_MASTER, null: true t.integer :access_level, default: GITLAB_ACCESS_MASTER, null: true
t.references :user, foreign_key: true, index: true t.references :user, foreign_key: true, index: true
t.integer :group_id#TODO: Should this have an index? Doesn't appear in brances #, index: true t.integer :group_id
t.timestamps null: false t.timestamps null: false
end end
add_foreign_key :protected_tag_push_access_levels, :namespaces, column: :group_id # rubocop: disable Migration/AddConcurrentForeignKey add_foreign_key :protected_tag_create_access_levels, :namespaces, column: :group_id # rubocop: disable Migration/AddConcurrentForeignKey
end end
end end
...@@ -1124,7 +1124,7 @@ ActiveRecord::Schema.define(version: 20170402231018) do ...@@ -1124,7 +1124,7 @@ ActiveRecord::Schema.define(version: 20170402231018) do
add_index "protected_branches", ["project_id"], name: "index_protected_branches_on_project_id", using: :btree add_index "protected_branches", ["project_id"], name: "index_protected_branches_on_project_id", using: :btree
create_table "protected_tag_push_access_levels", force: :cascade do |t| create_table "protected_tag_create_access_levels", force: :cascade do |t|
t.integer "protected_tag_id", null: false t.integer "protected_tag_id", null: false
t.integer "access_level", default: 40 t.integer "access_level", default: 40
t.integer "user_id" t.integer "user_id"
...@@ -1133,8 +1133,8 @@ ActiveRecord::Schema.define(version: 20170402231018) do ...@@ -1133,8 +1133,8 @@ ActiveRecord::Schema.define(version: 20170402231018) do
t.datetime "updated_at", null: false t.datetime "updated_at", null: false
end end
add_index "protected_tag_push_access_levels", ["protected_tag_id"], name: "index_protected_tag_push_access", using: :btree add_index "protected_tag_create_access_levels", ["protected_tag_id"], name: "index_protected_tag_create_access", using: :btree
add_index "protected_tag_push_access_levels", ["user_id"], name: "index_protected_tag_push_access_levels_on_user_id", using: :btree add_index "protected_tag_create_access_levels", ["user_id"], name: "index_protected_tag_create_access_levels_on_user_id", using: :btree
create_table "protected_tags", force: :cascade do |t| create_table "protected_tags", force: :cascade do |t|
t.integer "project_id", null: false t.integer "project_id", null: false
...@@ -1546,9 +1546,9 @@ ActiveRecord::Schema.define(version: 20170402231018) do ...@@ -1546,9 +1546,9 @@ ActiveRecord::Schema.define(version: 20170402231018) do
add_foreign_key "protected_branch_push_access_levels", "namespaces", column: "group_id" add_foreign_key "protected_branch_push_access_levels", "namespaces", column: "group_id"
add_foreign_key "protected_branch_push_access_levels", "protected_branches" add_foreign_key "protected_branch_push_access_levels", "protected_branches"
add_foreign_key "protected_branch_push_access_levels", "users" add_foreign_key "protected_branch_push_access_levels", "users"
add_foreign_key "protected_tag_push_access_levels", "namespaces", column: "group_id" add_foreign_key "protected_tag_create_access_levels", "namespaces", column: "group_id"
add_foreign_key "protected_tag_push_access_levels", "protected_tags" add_foreign_key "protected_tag_create_access_levels", "protected_tags"
add_foreign_key "protected_tag_push_access_levels", "users" add_foreign_key "protected_tag_create_access_levels", "users"
add_foreign_key "remote_mirrors", "projects" add_foreign_key "remote_mirrors", "projects"
add_foreign_key "subscriptions", "projects", on_delete: :cascade add_foreign_key "subscriptions", "projects", on_delete: :cascade
add_foreign_key "system_note_metadata", "notes", name: "fk_d83a918cb1", on_delete: :cascade add_foreign_key "system_note_metadata", "notes", name: "fk_d83a918cb1", on_delete: :cascade
......
...@@ -47,7 +47,7 @@ project_tree: ...@@ -47,7 +47,7 @@ project_tree:
- :merge_access_levels - :merge_access_levels
- :push_access_levels - :push_access_levels
- protected_tags: - protected_tags:
- :push_access_levels - :create_access_levels
- :project_feature - :project_feature
# Only include the following attributes for the models specified. # Only include the following attributes for the models specified.
......
...@@ -9,7 +9,7 @@ module Gitlab ...@@ -9,7 +9,7 @@ module Gitlab
hooks: 'ProjectHook', hooks: 'ProjectHook',
merge_access_levels: 'ProtectedBranch::MergeAccessLevel', merge_access_levels: 'ProtectedBranch::MergeAccessLevel',
push_access_levels: 'ProtectedBranch::PushAccessLevel', push_access_levels: 'ProtectedBranch::PushAccessLevel',
#TODO: How to add?- push_access_levels: 'ProtectedTag::PushAccessLevel', create_access_levels: 'ProtectedTag::CreateAccessLevel',
labels: :project_labels, labels: :project_labels,
priorities: :label_priorities, priorities: :label_priorities,
label: :project_label }.freeze label: :project_label }.freeze
......
...@@ -4,18 +4,18 @@ FactoryGirl.define do ...@@ -4,18 +4,18 @@ FactoryGirl.define do
project project
after(:build) do |protected_tag| after(:build) do |protected_tag|
protected_tag.push_access_levels.new(access_level: Gitlab::Access::MASTER) protected_tag.create_access_levels.new(access_level: Gitlab::Access::MASTER)
end end
trait :developers_can_push do trait :developers_can_create do
after(:create) do |protected_tag| after(:create) do |protected_tag|
protected_tag.push_access_levels.first.update!(access_level: Gitlab::Access::DEVELOPER) protected_tag.create_access_levels.first.update!(access_level: Gitlab::Access::DEVELOPER)
end end
end end
trait :no_one_can_push do trait :no_one_can_create do
after(:create) do |protected_tag| after(:create) do |protected_tag|
protected_tag.push_access_levels.first.update!(access_level: Gitlab::Access::NO_ACCESS) protected_tag.create_access_levels.first.update!(access_level: Gitlab::Access::NO_ACCESS)
end end
end end
end end
......
RSpec.shared_examples "protected tags > access control > CE" do RSpec.shared_examples "protected tags > access control > CE" do
ProtectedTag::PushAccessLevel.human_access_levels.each do |(access_type_id, access_type_name)| ProtectedTag::CreateAccessLevel.human_access_levels.each do |(access_type_id, access_type_name)|
it "allows creating protected tags that #{access_type_name} can push to" do it "allows creating protected tags that #{access_type_name} can create" do
visit namespace_project_protected_tags_path(project.namespace, project) visit namespace_project_protected_tags_path(project.namespace, project)
set_protected_tag_name('master') set_protected_tag_name('master')
within('.new_protected_tag') do within('.new_protected_tag') do
allowed_to_push_button = find(".js-allowed-to-push") allowed_to_create_button = find(".js-allowed-to-create")
unless allowed_to_push_button.text == access_type_name unless allowed_to_create_button.text == access_type_name
allowed_to_push_button.click allowed_to_create_button.click
within(".dropdown.open .dropdown-menu") { click_on access_type_name } within(".dropdown.open .dropdown-menu") { click_on access_type_name }
end end
end end
click_on "Protect" click_on "Protect"
expect(ProtectedTag.count).to eq(1) expect(ProtectedTag.count).to eq(1)
expect(ProtectedTag.last.push_access_levels.map(&:access_level)).to eq([access_type_id]) expect(ProtectedTag.last.create_access_levels.map(&:access_level)).to eq([access_type_id])
end end
it "allows updating protected tags so that #{access_type_name} can push to them" do it "allows updating protected tags so that #{access_type_name} can create them" do
visit namespace_project_protected_tags_path(project.namespace, project) visit namespace_project_protected_tags_path(project.namespace, project)
set_protected_tag_name('master') set_protected_tag_name('master')
click_on "Protect" click_on "Protect"
...@@ -25,16 +25,16 @@ RSpec.shared_examples "protected tags > access control > CE" do ...@@ -25,16 +25,16 @@ RSpec.shared_examples "protected tags > access control > CE" do
expect(ProtectedTag.count).to eq(1) expect(ProtectedTag.count).to eq(1)
within(".protected-tags-list") do within(".protected-tags-list") do
find(".js-allowed-to-push").click find(".js-allowed-to-create").click
within('.js-allowed-to-push-container') do within('.js-allowed-to-create-container') do
expect(first("li")).to have_content("Roles") expect(first("li")).to have_content("Roles")
click_on access_type_name click_on access_type_name
end end
end end
wait_for_ajax wait_for_ajax
expect(ProtectedTag.last.push_access_levels.map(&:access_level)).to include(access_type_id) expect(ProtectedTag.last.create_access_levels.map(&:access_level)).to include(access_type_id)
end end
end end
end end
...@@ -86,7 +86,7 @@ describe Gitlab::Checks::ChangeAccess, lib: true do ...@@ -86,7 +86,7 @@ describe Gitlab::Checks::ChangeAccess, lib: true do
end end
context 'when user has access' do context 'when user has access' do
let!(:protected_tag) { create(:protected_tag, :developers_can_push, project: project, name: 'v*') } let!(:protected_tag) { create(:protected_tag, :developers_can_create, project: project, name: 'v*') }
it 'allows tag creation' do it 'allows tag creation' do
expect(subject.status).to be(true) expect(subject.status).to be(true)
......
...@@ -118,7 +118,7 @@ protected_branches: ...@@ -118,7 +118,7 @@ protected_branches:
- push_access_levels - push_access_levels
protected_tags: protected_tags:
- project - project
- push_access_levels - create_access_levels
merge_access_levels: merge_access_levels:
- user - user
- protected_branch - protected_branch
...@@ -126,8 +126,9 @@ merge_access_levels: ...@@ -126,8 +126,9 @@ merge_access_levels:
push_access_levels: push_access_levels:
- user - user
- protected_branch - protected_branch
- protected_tag
- group - group
create_access_levels:
- protected_tag
project: project:
- taggings - taggings
- base_tags - base_tags
......
...@@ -189,7 +189,7 @@ describe Gitlab::UserAccess, lib: true do ...@@ -189,7 +189,7 @@ describe Gitlab::UserAccess, lib: true do
describe 'push to protected tag if allowed for developers' do describe 'push to protected tag if allowed for developers' do
before do before do
@tag = create(:protected_tag, :developers_can_push, project: project) @tag = create(:protected_tag, :developers_can_create, project: project)
end end
it 'returns true if user is a master' do it 'returns true if user is a master' do
......
...@@ -6,7 +6,7 @@ describe ProtectedTags::CreateService, services: true do ...@@ -6,7 +6,7 @@ describe ProtectedTags::CreateService, services: true do
let(:params) do let(:params) do
{ {
name: 'master', name: 'master',
push_access_levels_attributes: [{ access_level: Gitlab::Access::MASTER }] create_access_levels_attributes: [{ access_level: Gitlab::Access::MASTER }]
} }
end end
...@@ -15,7 +15,7 @@ describe ProtectedTags::CreateService, services: true do ...@@ -15,7 +15,7 @@ describe ProtectedTags::CreateService, services: true do
it 'creates a new protected tag' do it 'creates a new protected tag' do
expect { service.execute }.to change(ProtectedTag, :count).by(1) expect { service.execute }.to change(ProtectedTag, :count).by(1)
expect(project.protected_tags.last.push_access_levels.map(&:access_level)).to eq([Gitlab::Access::MASTER]) expect(project.protected_tags.last.create_access_levels.map(&:access_level)).to eq([Gitlab::Access::MASTER])
end 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