Convert invites controller spec to system/request specs (#31755)
This commit is contained in:
		
							parent
							
								
									5b1ae15a36
								
							
						
					
					
						commit
						e820cc30b8
					
				@ -1,4 +1,4 @@
 | 
				
			|||||||
%tr
 | 
					%tr{ id: dom_id(invite) }
 | 
				
			||||||
  %td
 | 
					  %td
 | 
				
			||||||
    .input-copy
 | 
					    .input-copy
 | 
				
			||||||
      .input-copy__wrapper
 | 
					      .input-copy__wrapper
 | 
				
			||||||
 | 
				
			|||||||
@ -1,84 +0,0 @@
 | 
				
			|||||||
# frozen_string_literal: true
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
require 'rails_helper'
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RSpec.describe InvitesController do
 | 
					 | 
				
			||||||
  render_views
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  let(:user) { Fabricate(:user) }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  before do
 | 
					 | 
				
			||||||
    sign_in user
 | 
					 | 
				
			||||||
  end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  describe 'GET #index' do
 | 
					 | 
				
			||||||
    before do
 | 
					 | 
				
			||||||
      Fabricate(:invite, user: user)
 | 
					 | 
				
			||||||
    end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    context 'when everyone can invite' do
 | 
					 | 
				
			||||||
      before do
 | 
					 | 
				
			||||||
        UserRole.everyone.update(permissions: UserRole.everyone.permissions | UserRole::FLAGS[:invite_users])
 | 
					 | 
				
			||||||
        get :index
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      it 'returns http success' do
 | 
					 | 
				
			||||||
        expect(response).to have_http_status(:success)
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      it 'returns private cache control headers' do
 | 
					 | 
				
			||||||
        expect(response.headers['Cache-Control']).to include('private, no-store')
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
    end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    context 'when not everyone can invite' do
 | 
					 | 
				
			||||||
      before do
 | 
					 | 
				
			||||||
        UserRole.everyone.update(permissions: UserRole.everyone.permissions & ~UserRole::FLAGS[:invite_users])
 | 
					 | 
				
			||||||
        get :index
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      it 'returns http forbidden' do
 | 
					 | 
				
			||||||
        expect(response).to have_http_status(403)
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
    end
 | 
					 | 
				
			||||||
  end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  describe 'POST #create' do
 | 
					 | 
				
			||||||
    subject { post :create, params: { invite: { max_uses: '10', expires_in: 1800 } } }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    context 'when everyone can invite' do
 | 
					 | 
				
			||||||
      before do
 | 
					 | 
				
			||||||
        UserRole.everyone.update(permissions: UserRole.everyone.permissions | UserRole::FLAGS[:invite_users])
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      it 'succeeds to create a invite' do
 | 
					 | 
				
			||||||
        expect { subject }.to change(Invite, :count).by(1)
 | 
					 | 
				
			||||||
        expect(subject).to redirect_to invites_path
 | 
					 | 
				
			||||||
        expect(Invite.last).to have_attributes(user_id: user.id, max_uses: 10)
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
    end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    context 'when not everyone can invite' do
 | 
					 | 
				
			||||||
      before do
 | 
					 | 
				
			||||||
        UserRole.everyone.update(permissions: UserRole.everyone.permissions & ~UserRole::FLAGS[:invite_users])
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      it 'returns http forbidden' do
 | 
					 | 
				
			||||||
        expect(subject).to have_http_status(403)
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
    end
 | 
					 | 
				
			||||||
  end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  describe 'DELETE #destroy' do
 | 
					 | 
				
			||||||
    subject { delete :destroy, params: { id: invite.id } }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    let(:invite) { Fabricate(:invite, user: user, expires_at: nil) }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    it 'expires invite and redirects' do
 | 
					 | 
				
			||||||
      expect { subject }
 | 
					 | 
				
			||||||
        .to(change { invite.reload.expired? }.to(true))
 | 
					 | 
				
			||||||
      expect(response)
 | 
					 | 
				
			||||||
        .to redirect_to invites_path
 | 
					 | 
				
			||||||
    end
 | 
					 | 
				
			||||||
  end
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
							
								
								
									
										31
									
								
								spec/requests/invites_spec.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								spec/requests/invites_spec.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,31 @@
 | 
				
			|||||||
 | 
					# frozen_string_literal: true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					require 'rails_helper'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					RSpec.describe 'Invites' do
 | 
				
			||||||
 | 
					  let(:user) { Fabricate(:user) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  before { sign_in user }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  context 'when not everyone can invite' do
 | 
				
			||||||
 | 
					    before { UserRole.everyone.update(permissions: UserRole.everyone.permissions & ~UserRole::FLAGS[:invite_users]) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    describe 'GET /invites' do
 | 
				
			||||||
 | 
					      it 'returns http forbidden' do
 | 
				
			||||||
 | 
					        get invites_path
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        expect(response)
 | 
				
			||||||
 | 
					          .to have_http_status(403)
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    describe 'POST /invites' do
 | 
				
			||||||
 | 
					      it 'returns http forbidden' do
 | 
				
			||||||
 | 
					        post invites_path, params: { invite: { max_users: '10', expires_in: 1800 } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        expect(response)
 | 
				
			||||||
 | 
					          .to have_http_status(403)
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
							
								
								
									
										14
									
								
								spec/support/matchers/private_cache_control.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								spec/support/matchers/private_cache_control.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,14 @@
 | 
				
			|||||||
 | 
					# frozen_string_literal: true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					RSpec::Matchers.define :have_private_cache_control do
 | 
				
			||||||
 | 
					  match do |page|
 | 
				
			||||||
 | 
					    page.response_headers['Cache-Control'] == 'private, no-store'
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  failure_message do |page|
 | 
				
			||||||
 | 
					    <<~ERROR
 | 
				
			||||||
 | 
					      Expected page to have `Cache-Control` header with `private, no-store` but it has:
 | 
				
			||||||
 | 
					        #{page.response_headers['Cache-Control']}
 | 
				
			||||||
 | 
					    ERROR
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
							
								
								
									
										86
									
								
								spec/system/invites_spec.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								spec/system/invites_spec.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,86 @@
 | 
				
			|||||||
 | 
					# frozen_string_literal: true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					require 'rails_helper'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					RSpec.describe 'Invites' do
 | 
				
			||||||
 | 
					  include ActionView::RecordIdentifier
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  let(:user) { Fabricate :user }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  before do
 | 
				
			||||||
 | 
					    host! 'localhost:3000' # TODO: Move into before for all system specs?
 | 
				
			||||||
 | 
					    sign_in user
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'Viewing invites' do
 | 
				
			||||||
 | 
					    it 'Lists existing user invites' do
 | 
				
			||||||
 | 
					      invite = Fabricate :invite, user: user
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      visit invites_path
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      within css_id(invite) do
 | 
				
			||||||
 | 
					        expect(page)
 | 
				
			||||||
 | 
					          .to have_content(invite.uses)
 | 
				
			||||||
 | 
					          .and have_private_cache_control
 | 
				
			||||||
 | 
					        expect(copyable_field.value)
 | 
				
			||||||
 | 
					          .to eq(public_invite_url(invite_code: invite.code))
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'Creating a new invite' do
 | 
				
			||||||
 | 
					    it 'Saves the invite for the user' do
 | 
				
			||||||
 | 
					      visit invites_path
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      fill_invite_form
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      expect { submit_form }
 | 
				
			||||||
 | 
					        .to change(user.invites, :count).by(1)
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe 'Deleting an existing invite' do
 | 
				
			||||||
 | 
					    it 'Expires the invite' do
 | 
				
			||||||
 | 
					      invite = Fabricate :invite, user: user
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      visit invites_path
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      expect { delete_invite(invite) }
 | 
				
			||||||
 | 
					        .to change { invite.reload.expired? }.to(true)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      within css_id(invite) do
 | 
				
			||||||
 | 
					        expect(page).to have_content I18n.t('invites.expired')
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  private
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  def css_id(record)
 | 
				
			||||||
 | 
					    "##{dom_id(record)}" # TODO: Extract to system spec helper?
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  def copyable_field
 | 
				
			||||||
 | 
					    within '.input-copy' do
 | 
				
			||||||
 | 
					      find(:field, type: :text, readonly: true)
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  def submit_form
 | 
				
			||||||
 | 
					    click_on I18n.t('invites.generate')
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  def delete_invite(invite)
 | 
				
			||||||
 | 
					    within css_id(invite) do
 | 
				
			||||||
 | 
					      click_on I18n.t('invites.delete')
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  def fill_invite_form
 | 
				
			||||||
 | 
					    select I18n.t('invites.max_uses', count: 100),
 | 
				
			||||||
 | 
					           from: I18n.t('simple_form.labels.defaults.max_uses')
 | 
				
			||||||
 | 
					    select I18n.t("invites.expires_in.#{30.minutes.to_i}"),
 | 
				
			||||||
 | 
					           from: I18n.t('simple_form.labels.defaults.expires_in')
 | 
				
			||||||
 | 
					    check I18n.t('simple_form.labels.defaults.autofollow')
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
@ -6,11 +6,14 @@ RSpec.describe 'Tags' do
 | 
				
			|||||||
  describe 'Viewing a tag' do
 | 
					  describe 'Viewing a tag' do
 | 
				
			||||||
    let(:tag) { Fabricate(:tag, name: 'test') }
 | 
					    let(:tag) { Fabricate(:tag, name: 'test') }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    before { sign_in Fabricate(:user) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    it 'visits the tag page and renders the web app' do
 | 
					    it 'visits the tag page and renders the web app' do
 | 
				
			||||||
      visit tag_path(tag)
 | 
					      visit tag_path(tag)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      expect(page)
 | 
					      expect(page)
 | 
				
			||||||
        .to have_css('noscript', text: /Mastodon/)
 | 
					        .to have_css('noscript', text: /Mastodon/)
 | 
				
			||||||
 | 
					        .and have_private_cache_control
 | 
				
			||||||
    end
 | 
					    end
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user