Commit 607fabd8 authored by Dylan Griffith's avatar Dylan Griffith

Merge branch 'mo-add-regex-validation-json-schema' into 'master'

Validate filename for json schema validator

See merge request gitlab-org/gitlab!33542
parents 51ddaad7 1be6dd33
...@@ -10,8 +10,12 @@ ...@@ -10,8 +10,12 @@
# end # end
# #
class JsonSchemaValidator < ActiveModel::EachValidator class JsonSchemaValidator < ActiveModel::EachValidator
FILENAME_ALLOWED = /\A[a-z0-9_-]*\Z/.freeze
FilenameError = Class.new(StandardError)
def initialize(options) def initialize(options)
raise ArgumentError, "Expected 'filename' as an argument" unless options[:filename] raise ArgumentError, "Expected 'filename' as an argument" unless options[:filename]
raise FilenameError, "Must be a valid 'filename'" unless options[:filename].match?(FILENAME_ALLOWED)
super(options) super(options)
end end
......
...@@ -8,7 +8,7 @@ describe JsonSchemaValidator do ...@@ -8,7 +8,7 @@ describe JsonSchemaValidator do
subject { validator.validate(build_report_result) } subject { validator.validate(build_report_result) }
context 'when file_path is set' do context 'when filename is set' do
let(:validator) { described_class.new(attributes: [:data], filename: "build_report_result_data") } let(:validator) { described_class.new(attributes: [:data], filename: "build_report_result_data") }
context 'when data is valid' do context 'when data is valid' do
...@@ -31,12 +31,20 @@ describe JsonSchemaValidator do ...@@ -31,12 +31,20 @@ describe JsonSchemaValidator do
end end
end end
context 'when file_path is not set' do context 'when filename is not set' do
let(:validator) { described_class.new(attributes: [:data]) } let(:validator) { described_class.new(attributes: [:data]) }
it 'raises an ArgumentError' do it 'raises an ArgumentError' do
expect { subject }.to raise_error(ArgumentError) expect { subject }.to raise_error(ArgumentError)
end end
end end
context 'when filename is invalid' do
let(:validator) { described_class.new(attributes: [:data], filename: "invalid$filename") }
it 'raises a FilenameError' do
expect { subject }.to raise_error(described_class::FilenameError)
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