123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- require 'rails_helper'
- RSpec.describe Settings::ProfilesController, type: :controller do
- render_views
- before do
- @user = Fabricate(:user)
- sign_in @user, scope: :user
- end
- describe "GET #show" do
- it "returns http success" do
- get :show
- expect(response).to have_http_status(200)
- end
- end
- describe 'PUT #update' do
- it 'updates the user profile' do
- allow(ActivityPub::UpdateDistributionWorker).to receive(:perform_async)
- account = Fabricate(:account, user: @user, display_name: 'Old name')
- put :update, params: { account: { display_name: 'New name' } }
- expect(account.reload.display_name).to eq 'New name'
- expect(response).to redirect_to(settings_profile_path)
- expect(ActivityPub::UpdateDistributionWorker).to have_received(:perform_async).with(account.id)
- end
- end
- describe 'PUT #update with new profile image' do
- it 'updates profile image' do
- allow(ActivityPub::UpdateDistributionWorker).to receive(:perform_async)
- account = Fabricate(:account, user: @user, display_name: 'AvatarTest')
- expect(account.avatar.instance.avatar_file_name).to be_nil
- put :update, params: { account: { avatar: fixture_file_upload('files/avatar.gif', 'image/gif') } }
- expect(response).to redirect_to(settings_profile_path)
- expect(account.reload.avatar.instance.avatar_file_name).not_to be_nil
- expect(ActivityPub::UpdateDistributionWorker).to have_received(:perform_async).with(account.id)
- end
- end
- describe 'PUT #update with oversized image' do
- it 'gives the user an error message' do
- allow(ActivityPub::UpdateDistributionWorker).to receive(:perform_async)
- account = Fabricate(:account, user: @user, display_name: 'AvatarTest')
- put :update, params: { account: { avatar: fixture_file_upload('files/4096x4097.png', 'image/png') } }
- expect(response.body).to include('images are not supported')
- end
- end
- end
|