From c8020b210505b2e16f8384ea4ed347a98d20b029 Mon Sep 17 00:00:00 2001 From: "Akihiko Odaki (@fn_aki@pawoo.net)" Date: Mon, 19 Jun 2017 18:30:27 +0900 Subject: [PATCH] Cover Export more (#3840) --- .../media_attachment_fabricator.rb | 1 + spec/models/export_spec.rb | 49 ++++++++++++++----- 2 files changed, 39 insertions(+), 11 deletions(-) diff --git a/spec/fabricators/media_attachment_fabricator.rb b/spec/fabricators/media_attachment_fabricator.rb index dc91d708f3..c5dfe12e53 100644 --- a/spec/fabricators/media_attachment_fabricator.rb +++ b/spec/fabricators/media_attachment_fabricator.rb @@ -1,3 +1,4 @@ Fabricator(:media_attachment) do account + file { [attachment_fixture(['attachment.gif', 'attachment.jpg', 'attachment.webm'].sample), nil].sample } end diff --git a/spec/models/export_spec.rb b/spec/models/export_spec.rb index 3ee042fb63..6daa461457 100644 --- a/spec/models/export_spec.rb +++ b/spec/models/export_spec.rb @@ -1,17 +1,16 @@ require 'rails_helper' describe Export do + let(:account) { Fabricate(:account) } + let(:target_accounts) do + [ {}, { username: 'one', domain: 'local.host' } ].map(&method(:Fabricate).curry(2).call(:account)) + end + describe 'to_csv' do - before do - one = Account.new(username: 'one', domain: 'local.host') - two = Account.new(username: 'two', domain: 'local.host') - accounts = [one, two] - - @account = double(blocking: accounts, muting: accounts, following: accounts) - end - it 'returns a csv of the blocked accounts' do - export = Export.new(@account).to_blocked_accounts_csv + target_accounts.each(&account.method(:block!)) + + export = Export.new(account).to_blocked_accounts_csv results = export.strip.split expect(results.size).to eq 2 @@ -19,7 +18,9 @@ describe Export do end it 'returns a csv of the muted accounts' do - export = Export.new(@account).to_muted_accounts_csv + target_accounts.each(&account.method(:mute!)) + + export = Export.new(account).to_muted_accounts_csv results = export.strip.split expect(results.size).to eq 2 @@ -27,11 +28,37 @@ describe Export do end it 'returns a csv of the following accounts' do - export = Export.new(@account).to_following_accounts_csv + target_accounts.each(&account.method(:follow!)) + + export = Export.new(account).to_following_accounts_csv results = export.strip.split expect(results.size).to eq 2 expect(results.first).to eq 'one@local.host' end end + + describe 'total_storage' do + it 'returns the total size of the media attachments' do + media_attachment = Fabricate(:media_attachment, account: account) + expect(Export.new(account).total_storage).to eq media_attachment.file_file_size || 0 + end + end + + describe 'total_follows' do + it 'returns the total number of the followed accounts' do + target_accounts.each(&account.method(:follow!)) + expect(Export.new(account).total_follows).to eq 2 + end + + it 'returns the total number of the blocked accounts' do + target_accounts.each(&account.method(:block!)) + expect(Export.new(account).total_blocks).to eq 2 + end + + it 'returns the total number of the muted accounts' do + target_accounts.each(&account.method(:mute!)) + expect(Export.new(account).total_mutes).to eq 2 + end + end end