Commit 96482cac authored by Philip Cunningham's avatar Philip Cunningham Committed by Robert Speicher

Clean up DAST site tokens when site deleted

parent fe8576d0
...@@ -11,8 +11,14 @@ class DastSite < ApplicationRecord ...@@ -11,8 +11,14 @@ class DastSite < ApplicationRecord
validates :project_id, presence: true validates :project_id, presence: true
validate :dast_site_validation_project_id_fk validate :dast_site_validation_project_id_fk
after_destroy :cleanup_dast_site_token
private private
def cleanup_dast_site_token
DastSiteToken.where(project_id: project.id, url: url).delete_all
end
def dast_site_validation_project_id_fk def dast_site_validation_project_id_fk
return unless dast_site_validation_id return unless dast_site_validation_id
......
...@@ -44,4 +44,16 @@ RSpec.describe DastSite, type: :model do ...@@ -44,4 +44,16 @@ RSpec.describe DastSite, type: :model do
end end
end end
end end
describe 'callbacks' do
context 'when there is a related site token' do
let_it_be(:dast_site) { create(:dast_site, project: project) }
let_it_be(:dast_site_token) { create(:dast_site_token, project: dast_site.project, url: dast_site.url) }
let_it_be(:dast_site_validations) { create_list(:dast_site_validation, 5, dast_site_token: dast_site_token) }
it 'ensures it and associated site validations cleaned up on destroy' do
expect { dast_site.destroy! }.to change { DastSiteToken.count }.from(1).to(0).and change { DastSiteValidation.count }.from(5).to(0)
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