diff options
author | Francisco Javier López <fjlopez@gitlab.com> | 2019-03-04 18:36:34 +0000 |
---|---|---|
committer | Yorick Peterse <yorickpeterse@gmail.com> | 2019-03-04 18:36:34 +0000 |
commit | ebf16ada856efb85424a98848c141f21e609886a (patch) | |
tree | e9700c1c392644f035302c61fc8f9c2dc6095a92 /spec/validators | |
parent | adedcb329464783165db2c233b3a6fd9578d2c25 (diff) | |
download | gitlab-ce-ebf16ada856efb85424a98848c141f21e609886a.tar.gz |
Arbitrary file read via MergeRequestDiff
Diffstat (limited to 'spec/validators')
-rw-r--r-- | spec/validators/sha_validator_spec.rb | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/spec/validators/sha_validator_spec.rb b/spec/validators/sha_validator_spec.rb new file mode 100644 index 00000000000..b9242ef931e --- /dev/null +++ b/spec/validators/sha_validator_spec.rb @@ -0,0 +1,40 @@ +require 'spec_helper' + +describe ShaValidator do + let(:validator) { described_class.new(attributes: [:base_commit_sha]) } + let(:merge_diff) { build(:merge_request_diff) } + + subject { validator.validate_each(merge_diff, :base_commit_sha, value) } + + context 'with empty value' do + let(:value) { nil } + + it 'does not add any error if value is empty' do + subject + + expect(merge_diff.errors).to be_empty + end + end + + context 'with valid sha' do + let(:value) { Digest::SHA1.hexdigest(SecureRandom.hex) } + + it 'does not add any error if value is empty' do + subject + + expect(merge_diff.errors).to be_empty + end + end + + context 'with invalid sha' do + let(:value) { 'foo' } + + it 'adds error to the record' do + expect(merge_diff.errors).to be_empty + + subject + + expect(merge_diff.errors).not_to be_empty + end + end +end |