123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- require 'rails_helper'
- RSpec.describe Vacuum::MediaAttachmentsVacuum do
- let(:retention_period) { 7.days }
- subject { described_class.new(retention_period) }
- let(:remote_status) { Fabricate(:status, account: Fabricate(:account, domain: 'example.com')) }
- let(:local_status) { Fabricate(:status) }
- describe '#perform' do
- let!(:old_remote_media) { Fabricate(:media_attachment, remote_url: 'https://example.com/foo.png', status: remote_status, created_at: (retention_period + 1.day).ago, updated_at: (retention_period + 1.day).ago) }
- let!(:old_local_media) { Fabricate(:media_attachment, status: local_status, created_at: (retention_period + 1.day).ago, updated_at: (retention_period + 1.day).ago) }
- let!(:new_remote_media) { Fabricate(:media_attachment, remote_url: 'https://example.com/foo.png', status: remote_status) }
- let!(:new_local_media) { Fabricate(:media_attachment, status: local_status) }
- let!(:old_unattached_media) { Fabricate(:media_attachment, account_id: nil, created_at: 10.days.ago) }
- let!(:new_unattached_media) { Fabricate(:media_attachment, account_id: nil, created_at: 1.hour.ago) }
- before do
- subject.perform
- end
- it 'deletes cache of remote media attachments past the retention period' do
- expect(old_remote_media.reload.file).to be_blank
- end
- it 'does not touch local media attachments past the retention period' do
- expect(old_local_media.reload.file).to_not be_blank
- end
- it 'does not delete cache of remote media attachments within the retention period' do
- expect(new_remote_media.reload.file).to_not be_blank
- end
- it 'does not touch local media attachments within the retention period' do
- expect(new_local_media.reload.file).to_not be_blank
- end
- it 'deletes unattached media attachments past TTL' do
- expect { old_unattached_media.reload }.to raise_error(ActiveRecord::RecordNotFound)
- end
- it 'does not delete unattached media attachments within TTL' do
- expect(new_unattached_media.reload).to be_persisted
- end
- end
- end
|