mirror of
https://github.com/glitch-soc/mastodon.git
synced 2025-01-21 15:13:01 -05:00
0cec9077a4
Conflicts: - `spec/requests/api/v2/instance_spec.rb`: Upstream added a test for a new attribute, next to a line we modified in glitch-soc because of a different default value. Updated as upstream's did, keeping glitch-soc's default value.
68 lines
1.7 KiB
Ruby
68 lines
1.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
describe 'Instances' do
|
|
let(:user) { Fabricate(:user) }
|
|
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id) }
|
|
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
|
|
|
|
describe 'GET /api/v2/instance' do
|
|
context 'when logged out' do
|
|
it 'returns http success and json' do
|
|
get api_v2_instance_path
|
|
|
|
expect(response)
|
|
.to have_http_status(200)
|
|
|
|
expect(body_as_json)
|
|
.to be_present
|
|
.and include(title: 'Mastodon Glitch Edition')
|
|
.and include_api_versions
|
|
.and include_configuration_limits
|
|
end
|
|
end
|
|
|
|
context 'when logged in' do
|
|
it 'returns http success and json' do
|
|
get api_v2_instance_path, headers: headers
|
|
|
|
expect(response)
|
|
.to have_http_status(200)
|
|
|
|
expect(body_as_json)
|
|
.to be_present
|
|
.and include(title: 'Mastodon Glitch Edition')
|
|
.and include_api_versions
|
|
.and include_configuration_limits
|
|
end
|
|
end
|
|
|
|
def include_configuration_limits
|
|
include(
|
|
configuration: include(
|
|
accounts: include(
|
|
max_featured_tags: FeaturedTag::LIMIT,
|
|
max_pinned_statuses: StatusPinValidator::PIN_LIMIT
|
|
),
|
|
statuses: include(
|
|
max_characters: StatusLengthValidator::MAX_CHARS,
|
|
max_media_attachments: Status::MEDIA_ATTACHMENTS_LIMIT
|
|
),
|
|
polls: include(
|
|
max_options: PollValidator::MAX_OPTIONS
|
|
)
|
|
)
|
|
)
|
|
end
|
|
|
|
def include_api_versions
|
|
include(
|
|
api_versions: include(
|
|
mastodon: anything
|
|
)
|
|
)
|
|
end
|
|
end
|
|
end
|