Merge commit 'fab95b8dae3db411318638804a01675dd5b38a01' into glitch-soc/merge-upstream

This commit is contained in:
Claire
2025-07-22 23:17:48 +02:00
24 changed files with 234 additions and 133 deletions

View File

@@ -6,13 +6,49 @@ RSpec.describe 'invites' do
let(:invite) { Fabricate(:invite) }
context 'when requesting a JSON document' do
it 'returns a JSON document with expected attributes' do
get "/invite/#{invite.code}", headers: { 'Accept' => 'application/activity+json' }
subject { get "/invite/#{invite.code}", headers: { 'Accept' => 'application/activity+json' } }
expect(response).to have_http_status(200)
expect(response.media_type).to eq 'application/json'
context 'when invite is valid' do
it 'returns a JSON document with expected attributes' do
subject
expect(response.parsed_body[:invite_code]).to eq invite.code
expect(response)
.to have_http_status(200)
expect(response.media_type)
.to eq 'application/json'
expect(response.parsed_body)
.to include(invite_code: invite.code)
end
end
context 'when invite is expired' do
before { invite.update(expires_at: 3.days.ago) }
it 'returns a JSON document with error details' do
subject
expect(response)
.to have_http_status(401)
expect(response.media_type)
.to eq 'application/json'
expect(response.parsed_body)
.to include(error: I18n.t('invites.invalid'))
end
end
context 'when user IP is blocked' do
before { Fabricate :ip_block, severity: :sign_up_block, ip: '127.0.0.1' }
it 'returns a JSON document with error details' do
subject
expect(response)
.to have_http_status(403)
expect(response.media_type)
.to eq 'application/json'
expect(response.parsed_body)
.to include(error: /This action is not allowed/)
end
end
end