]> cat aescling's git repositories - mastodon.git/commitdiff
Spec Settings::Exports (#3384)
authorAkihiko Odaki <akihiko.odaki.4i@stu.hosei.ac.jp>
Mon, 29 May 2017 16:05:01 +0000 (01:05 +0900)
committerEugen Rochko <eugen@zeonfederated.com>
Mon, 29 May 2017 16:05:01 +0000 (18:05 +0200)
* Spec output of Settings::Exports::BlockedAccountsController

* Spec output of Settings::Exports::FollowingAccountsController

* Spec output of Settings::Exports::MutedAccountsController

* Spec Settings::Exports::BaseController

This commit removes duplicate specs in classes inheriting
Settings::Exports::BaseController as well.

spec/controllers/settings/exports/base_controller_spec.rb [new file with mode: 0644]
spec/controllers/settings/exports/blocked_accounts_controller_spec.rb
spec/controllers/settings/exports/following_accounts_controller_spec.rb
spec/controllers/settings/exports/muted_accounts_controller_spec.rb

diff --git a/spec/controllers/settings/exports/base_controller_spec.rb b/spec/controllers/settings/exports/base_controller_spec.rb
new file mode 100644 (file)
index 0000000..c924d44
--- /dev/null
@@ -0,0 +1,29 @@
+# frozen_string_literal: true
+
+require 'rails_helper'
+
+describe Settings::Exports::BaseController do
+  controller do
+    def export_data
+      @export.account.username
+    end
+  end
+
+  describe 'GET #index' do
+    it 'returns a csv of the exported data when signed in' do
+      user = Fabricate(:user)
+      sign_in user
+      get :index, format: :csv
+
+      expect(response).to have_http_status(:success)
+      expect(response.content_type).to eq 'text/csv'
+      expect(response.headers['Content-Disposition']).to eq 'attachment; filename="base.csv"'
+      expect(response.body).to eq user.account.username
+    end
+
+    it 'returns unauthorized when not signed in' do
+      get :index, format: :csv
+      expect(response).to have_http_status(:unauthorized)
+    end
+  end
+end
index e79a6729a6b6edff6f74ce4fb618ff8bf6f0dd67..5ff41b7fcd8d38a787145811fc456ec752a6107e 100644 (file)
@@ -3,17 +3,15 @@ require 'rails_helper'
 describe Settings::Exports::BlockedAccountsController do
   render_views
 
-  before do
-    sign_in Fabricate(:user), scope: :user
-  end
-
   describe 'GET #index' do
     it 'returns a csv of the blocking accounts' do
+      user = Fabricate(:user)
+      user.account.block!(Fabricate(:account, username: 'username', domain: 'domain'))
+
+      sign_in user, scope: :user
       get :index, format: :csv
 
-      expect(response).to have_http_status(:success)
-      expect(response.content_type).to eq 'text/csv'
-      expect(response.headers['Content-Disposition']).to eq 'attachment; filename="blocked_accounts.csv"'
+      expect(response.body).to eq "username@domain\n"
     end
   end
 end
index 503455feaa4b9d504d6b371d5317be213c1ceb87..786769d2459e6d0d9f69af427a7ec46117c01615 100644 (file)
@@ -3,17 +3,15 @@ require 'rails_helper'
 describe Settings::Exports::FollowingAccountsController do
   render_views
 
-  before do
-    sign_in Fabricate(:user), scope: :user
-  end
-
   describe 'GET #index' do
     it 'returns a csv of the following accounts' do
+      user = Fabricate(:user)
+      user.account.follow!(Fabricate(:account, username: 'username', domain: 'domain'))
+
+      sign_in user, scope: :user
       get :index, format: :csv
 
-      expect(response).to have_http_status(:success)
-      expect(response.content_type).to eq 'text/csv'
-      expect(response.headers['Content-Disposition']).to eq 'attachment; filename="following_accounts.csv"'
+      expect(response.body).to eq "username@domain\n"
     end
   end
 end
index 37c3a0fcfe828ff727e2e99f237d3f2df7324132..f42d7881ed95bbb0fa01241680adbc57570da8fa 100644 (file)
@@ -3,17 +3,15 @@ require 'rails_helper'
 describe Settings::Exports::MutedAccountsController do
   render_views
 
-  before do
-    sign_in Fabricate(:user), scope: :user
-  end
-
   describe 'GET #index' do
     it 'returns a csv of the muting accounts' do
+      user = Fabricate(:user)
+      user.account.mute!(Fabricate(:account, username: 'username', domain: 'domain'))
+
+      sign_in user, scope: :user
       get :index, format: :csv
 
-      expect(response).to have_http_status(:success)
-      expect(response.content_type).to eq 'text/csv'
-      expect(response.headers['Content-Disposition']).to eq 'attachment; filename="muted_accounts.csv"'
+      expect(response.body).to eq "username@domain\n"
     end
   end
 end