Commit 74b5a36e authored by Alex Pooley's avatar Alex Pooley Committed by Dmitry Gruzd

Dast meta tag valid case

parent 0cf05541
...@@ -3,7 +3,9 @@ ...@@ -3,7 +3,9 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe DastSiteValidation, type: :model do RSpec.describe DastSiteValidation, type: :model do
subject { create(:dast_site_validation) } let_it_be(:dast_site_token) { create(:dast_site_token) }
subject { create(:dast_site_validation, dast_site_token: dast_site_token) }
let_it_be(:another_dast_site_validation) { create(:dast_site_validation) } let_it_be(:another_dast_site_validation) { create(:dast_site_validation) }
...@@ -17,15 +19,19 @@ RSpec.describe DastSiteValidation, type: :model do ...@@ -17,15 +19,19 @@ RSpec.describe DastSiteValidation, type: :model do
it { is_expected.to validate_presence_of(:dast_site_token_id) } it { is_expected.to validate_presence_of(:dast_site_token_id) }
context 'when strategy is meta_tag' do context 'when strategy is meta_tag' do
shared_examples 'meta tag validation is disabled' do subject { build(:dast_site_validation, dast_site_token: dast_site_token, validation_strategy: :meta_tag) }
subject { build(:dast_site_validation, validation_strategy: :meta_tag) }
shared_examples 'meta tag validation is disabled' do
it 'is not valid', :aggregate_failures do it 'is not valid', :aggregate_failures do
expect(subject).not_to be_valid expect(subject).not_to be_valid
expect(subject.errors.full_messages).to include('Meta tag validation is not enabled') expect(subject.errors.full_messages).to include('Meta tag validation is not enabled')
end end
end end
context 'when dast_meta_tag_validation and dast_runner_site_validation are enabled' do
it { is_expected.to be_valid }
end
context 'when dast_meta_tag_validation is disabled' do context 'when dast_meta_tag_validation is disabled' do
before do before do
stub_feature_flags(dast_meta_tag_validation: false) stub_feature_flags(dast_meta_tag_validation: false)
...@@ -46,13 +52,11 @@ RSpec.describe DastSiteValidation, type: :model do ...@@ -46,13 +52,11 @@ RSpec.describe DastSiteValidation, type: :model do
describe 'before_create' do describe 'before_create' do
describe '#set_normalized_url_base' do describe '#set_normalized_url_base' do
subject do let_it_be(:dast_site_token) do
dast_site_token = create( create(
:dast_site_token, :dast_site_token,
url: generate(:url) + '/' + SecureRandom.hex + '?' + { param: SecureRandom.hex }.to_query url: generate(:url) + '/' + SecureRandom.hex + '?' + { param: SecureRandom.hex }.to_query
) )
create(:dast_site_validation, dast_site_token: dast_site_token)
end end
it 'normalizes the dast_site_token url' do it 'normalizes the dast_site_token url' do
...@@ -152,7 +156,7 @@ RSpec.describe DastSiteValidation, type: :model do ...@@ -152,7 +156,7 @@ RSpec.describe DastSiteValidation, type: :model do
describe '#retry' do describe '#retry' do
context 'when state=failed' do context 'when state=failed' do
subject { create(:dast_site_validation, state: :failed) } subject { create(:dast_site_validation, state: :failed, dast_site_token: dast_site_token) }
it 'returns true' do it 'returns true' do
expect(subject.retry).to eq(true) expect(subject.retry).to eq(true)
...@@ -182,7 +186,7 @@ RSpec.describe DastSiteValidation, type: :model do ...@@ -182,7 +186,7 @@ RSpec.describe DastSiteValidation, type: :model do
describe '#fail_op' do describe '#fail_op' do
context 'when state=failed' do context 'when state=failed' do
subject { create(:dast_site_validation, state: :failed) } subject { create(:dast_site_validation, state: :failed, dast_site_token: dast_site_token) }
it 'returns false' do it 'returns false' do
expect(subject.fail_op).to eq(false) expect(subject.fail_op).to eq(false)
...@@ -212,7 +216,7 @@ RSpec.describe DastSiteValidation, type: :model do ...@@ -212,7 +216,7 @@ RSpec.describe DastSiteValidation, type: :model do
describe '#pass' do describe '#pass' do
context 'when state=inprogress' do context 'when state=inprogress' do
subject { create(:dast_site_validation, state: :inprogress) } subject { create(:dast_site_validation, state: :inprogress, dast_site_token: dast_site_token) }
it 'returns true' do it 'returns true' do
expect(subject.pass).to eq(true) expect(subject.pass).to eq(true)
......
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