5 changed files with 22 additions and 63 deletions
@ -1,10 +0,0 @@ |
|||||||
# frozen_string_literal: true |
|
||||||
|
|
||||||
class Vacuum::ApplicationsVacuum |
|
||||||
def perform |
|
||||||
Doorkeeper::Application.where(owner_id: nil) |
|
||||||
.where.missing(:created_users, :access_tokens, :access_grants) |
|
||||||
.where(created_at: ...1.day.ago) |
|
||||||
.in_batches.delete_all |
|
||||||
end |
|
||||||
end |
|
||||||
@ -1,48 +0,0 @@ |
|||||||
# frozen_string_literal: true |
|
||||||
|
|
||||||
require 'rails_helper' |
|
||||||
|
|
||||||
RSpec.describe Vacuum::ApplicationsVacuum do |
|
||||||
subject { described_class.new } |
|
||||||
|
|
||||||
describe '#perform' do |
|
||||||
let!(:app_with_token) { Fabricate(:application, created_at: 1.month.ago) } |
|
||||||
let!(:app_with_grant) { Fabricate(:application, created_at: 1.month.ago) } |
|
||||||
let!(:app_with_signup) { Fabricate(:application, created_at: 1.month.ago) } |
|
||||||
let!(:app_with_owner) { Fabricate(:application, created_at: 1.month.ago, owner: Fabricate(:user)) } |
|
||||||
let!(:unused_app) { Fabricate(:application, created_at: 1.month.ago) } |
|
||||||
let!(:recent_app) { Fabricate(:application, created_at: 1.hour.ago) } |
|
||||||
|
|
||||||
let!(:active_access_token) { Fabricate(:access_token, application: app_with_token) } |
|
||||||
let!(:active_access_grant) { Fabricate(:access_grant, application: app_with_grant) } |
|
||||||
let!(:user) { Fabricate(:user, created_by_application: app_with_signup) } |
|
||||||
|
|
||||||
before do |
|
||||||
subject.perform |
|
||||||
end |
|
||||||
|
|
||||||
it 'does not delete applications with valid access tokens' do |
|
||||||
expect { app_with_token.reload }.to_not raise_error |
|
||||||
end |
|
||||||
|
|
||||||
it 'does not delete applications with valid access grants' do |
|
||||||
expect { app_with_grant.reload }.to_not raise_error |
|
||||||
end |
|
||||||
|
|
||||||
it 'does not delete applications that were used to create users' do |
|
||||||
expect { app_with_signup.reload }.to_not raise_error |
|
||||||
end |
|
||||||
|
|
||||||
it 'does not delete owned applications' do |
|
||||||
expect { app_with_owner.reload }.to_not raise_error |
|
||||||
end |
|
||||||
|
|
||||||
it 'does not delete applications registered less than a day ago' do |
|
||||||
expect { recent_app.reload }.to_not raise_error |
|
||||||
end |
|
||||||
|
|
||||||
it 'deletes unused applications' do |
|
||||||
expect { unused_app.reload }.to raise_error ActiveRecord::RecordNotFound |
|
||||||
end |
|
||||||
end |
|
||||||
end |
|
||||||
Loading…
Reference in new issue