Add allowed_actions options to SnippetInputAction

We introduce an `allowed_action` param to the
SnippetInputAction to restrict which actions, despite
of being valid, are allowed to be present.
parent 6c09ab66
...@@ -18,12 +18,14 @@ class SnippetInputAction ...@@ -18,12 +18,14 @@ class SnippetInputAction
validates :file_path, presence: true validates :file_path, presence: true
validates :content, presence: true, if: -> (action) { action.create_action? || action.update_action? } validates :content, presence: true, if: -> (action) { action.create_action? || action.update_action? }
validate :ensure_same_file_path_and_previous_path, if: :update_action? validate :ensure_same_file_path_and_previous_path, if: :update_action?
validate :ensure_allowed_action
def initialize(action: nil, previous_path: nil, file_path: nil, content: nil) def initialize(action: nil, previous_path: nil, file_path: nil, content: nil, allowed_actions: nil)
@action = action&.to_sym @action = action&.to_sym
@previous_path = previous_path @previous_path = previous_path
@file_path = file_path @file_path = file_path
@content = content @content = content
@allowed_actions = Array(allowed_actions).map(&:to_sym)
end end
def to_commit_action def to_commit_action
...@@ -49,4 +51,12 @@ class SnippetInputAction ...@@ -49,4 +51,12 @@ class SnippetInputAction
errors.add(:file_path, "can't be different from the previous_path attribute") errors.add(:file_path, "can't be different from the previous_path attribute")
end end
def ensure_allowed_action
return if @allowed_actions.empty?
unless @allowed_actions.include?(action)
errors.add(:action, 'is not allowed')
end
end
end end
...@@ -7,8 +7,8 @@ class SnippetInputActionCollection ...@@ -7,8 +7,8 @@ class SnippetInputActionCollection
delegate :empty?, :any?, :[], to: :actions delegate :empty?, :any?, :[], to: :actions
def initialize(actions = []) def initialize(actions = [], allowed_actions: nil)
@actions = actions.map { |action| SnippetInputAction.new(action) } @actions = actions.map { |action| SnippetInputAction.new(action.merge(allowed_actions: allowed_actions)) }
end end
def to_commit_actions def to_commit_actions
......
---
title: Add allowed actions to snippet input action
merge_request: 34499
author:
type: changed
...@@ -36,4 +36,12 @@ describe SnippetInputActionCollection do ...@@ -36,4 +36,12 @@ describe SnippetInputActionCollection do
end end
end end
end end
context 'when allowed_actions param is passed' do
it 'builds SnippetInputAction with that param' do
expect(SnippetInputAction).to receive(:new).with(hash_including(allowed_actions: :create))
described_class.new([action], allowed_actions: :create)
end
end
end end
...@@ -6,34 +6,42 @@ describe SnippetInputAction do ...@@ -6,34 +6,42 @@ describe SnippetInputAction do
describe 'validations' do describe 'validations' do
using RSpec::Parameterized::TableSyntax using RSpec::Parameterized::TableSyntax
where(:action, :file_path, :content, :previous_path, :is_valid, :invalid_field) do where(:action, :file_path, :content, :previous_path, :allowed_actions, :is_valid, :invalid_field) do
:create | 'foobar' | 'foobar' | 'foobar' | true | nil :create | 'foobar' | 'foobar' | 'foobar' | nil | true | nil
:move | 'foobar' | 'foobar' | 'foobar' | true | nil :move | 'foobar' | 'foobar' | 'foobar' | nil | true | nil
:delete | 'foobar' | 'foobar' | 'foobar' | true | nil :delete | 'foobar' | 'foobar' | 'foobar' | nil | true | nil
:update | 'foobar' | 'foobar' | 'foobar' | true | nil :update | 'foobar' | 'foobar' | 'foobar' | nil | true | nil
:foo | 'foobar' | 'foobar' | 'foobar' | false | :action :foo | 'foobar' | 'foobar' | 'foobar' | nil | false | :action
'create' | 'foobar' | 'foobar' | 'foobar' | true | nil 'create' | 'foobar' | 'foobar' | 'foobar' | nil | true | nil
'move' | 'foobar' | 'foobar' | 'foobar' | true | nil 'move' | 'foobar' | 'foobar' | 'foobar' | nil | true | nil
'delete' | 'foobar' | 'foobar' | 'foobar' | true | nil 'delete' | 'foobar' | 'foobar' | 'foobar' | nil | true | nil
'update' | 'foobar' | 'foobar' | 'foobar' | true | nil 'update' | 'foobar' | 'foobar' | 'foobar' | nil | true | nil
'foo' | 'foobar' | 'foobar' | 'foobar' | false | :action 'foo' | 'foobar' | 'foobar' | 'foobar' | nil | false | :action
nil | 'foobar' | 'foobar' | 'foobar' | false | :action nil | 'foobar' | 'foobar' | 'foobar' | nil | false | :action
'' | 'foobar' | 'foobar' | 'foobar' | false | :action '' | 'foobar' | 'foobar' | 'foobar' | nil | false | :action
:move | 'foobar' | 'foobar' | nil | false | :previous_path :move | 'foobar' | 'foobar' | nil | nil | false | :previous_path
:move | 'foobar' | 'foobar' | '' | false | :previous_path :move | 'foobar' | 'foobar' | '' | nil | false | :previous_path
:create | 'foobar' | nil | 'foobar' | false | :content :create | 'foobar' | nil | 'foobar' | nil | false | :content
:create | 'foobar' | '' | 'foobar' | false | :content :create | 'foobar' | '' | 'foobar' | nil | false | :content
:create | nil | 'foobar' | 'foobar' | false | :file_path :create | nil | 'foobar' | 'foobar' | nil | false | :file_path
:create | '' | 'foobar' | 'foobar' | false | :file_path :create | '' | 'foobar' | 'foobar' | nil | false | :file_path
:update | 'foobar' | nil | 'foobar' | false | :content :update | 'foobar' | nil | 'foobar' | nil | false | :content
:update | 'foobar' | '' | 'foobar' | false | :content :update | 'foobar' | '' | 'foobar' | nil | false | :content
:update | 'other' | 'foobar' | 'foobar' | false | :file_path :update | 'other' | 'foobar' | 'foobar' | nil | false | :file_path
:update | 'foobar' | 'foobar' | nil | true | nil :update | 'foobar' | 'foobar' | nil | nil | true | nil
:update | 'foobar' | 'foobar' | '' | true | nil :update | 'foobar' | 'foobar' | '' | nil | true | nil
:update | 'foobar' | 'foobar' | '' | :update | true | nil
:update | 'foobar' | 'foobar' | '' | 'update' | true | nil
:update | 'foobar' | 'foobar' | '' | [:update] | true | nil
:update | 'foobar' | 'foobar' | '' | [:update, :create] | true | nil
:update | 'foobar' | 'foobar' | '' | :create | false | :action
:update | 'foobar' | 'foobar' | '' | 'create' | false | :action
:update | 'foobar' | 'foobar' | '' | [:create] | false | :action
:foo | 'foobar' | 'foobar' | '' | :foo | false | :action
end end
with_them do with_them do
subject { described_class.new(action: action, file_path: file_path, content: content, previous_path: previous_path) } subject { described_class.new(action: action, file_path: file_path, content: content, previous_path: previous_path, allowed_actions: allowed_actions) }
specify do specify do
expect(subject.valid?).to be is_valid expect(subject.valid?).to be is_valid
......
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