2023-02-14 00:04:26 +09:00
|
|
|
# frozen_string_literal: true
|
2023-02-20 14:58:28 +09:00
|
|
|
|
2017-06-01 04:36:24 +09:00
|
|
|
require 'rails_helper'
|
|
|
|
|
2024-09-04 14:12:25 +09:00
|
|
|
RSpec.describe 'API V1 Accounts Statuses' do
|
2024-03-02 01:24:45 +09:00
|
|
|
let(:user) { Fabricate(:user) }
|
|
|
|
let(:scopes) { 'read:statuses' }
|
|
|
|
let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
|
|
|
|
let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
|
2017-06-01 04:36:24 +09:00
|
|
|
|
2024-03-02 01:24:45 +09:00
|
|
|
describe 'GET /api/v1/accounts/:account_id/statuses' do
|
2023-10-13 21:42:09 +09:00
|
|
|
it 'returns expected headers', :aggregate_failures do
|
2024-07-12 17:30:52 +09:00
|
|
|
status = Fabricate(:status, account: user.account)
|
2024-03-02 01:24:45 +09:00
|
|
|
get "/api/v1/accounts/#{user.account.id}/statuses", params: { limit: 1 }, headers: headers
|
2017-06-01 04:36:24 +09:00
|
|
|
|
2024-07-12 17:30:52 +09:00
|
|
|
expect(response)
|
|
|
|
.to have_http_status(200)
|
|
|
|
.and include_pagination_headers(
|
|
|
|
prev: api_v1_account_statuses_url(limit: 1, min_id: status.id),
|
|
|
|
next: api_v1_account_statuses_url(limit: 1, max_id: status.id)
|
|
|
|
)
|
2024-09-20 22:13:04 +09:00
|
|
|
expect(response.content_type)
|
|
|
|
.to start_with('application/json')
|
2017-06-01 04:36:24 +09:00
|
|
|
end
|
|
|
|
|
2017-08-25 08:41:18 +09:00
|
|
|
context 'with only media' do
|
|
|
|
it 'returns http success' do
|
2024-03-02 01:24:45 +09:00
|
|
|
get "/api/v1/accounts/#{user.account.id}/statuses", params: { only_media: true }, headers: headers
|
2017-06-01 04:36:24 +09:00
|
|
|
|
2023-02-20 11:16:40 +09:00
|
|
|
expect(response).to have_http_status(200)
|
2024-09-20 22:13:04 +09:00
|
|
|
expect(response.content_type)
|
|
|
|
.to start_with('application/json')
|
2017-08-25 08:41:18 +09:00
|
|
|
end
|
2017-06-01 04:36:24 +09:00
|
|
|
end
|
|
|
|
|
2017-08-25 08:41:18 +09:00
|
|
|
context 'with exclude replies' do
|
2023-02-14 00:04:26 +09:00
|
|
|
let!(:status) { Fabricate(:status, account: user.account) }
|
|
|
|
let!(:status_self_reply) { Fabricate(:status, account: user.account, thread: status) }
|
|
|
|
|
2017-08-25 08:41:18 +09:00
|
|
|
before do
|
2023-02-14 00:04:26 +09:00
|
|
|
Fabricate(:status, account: user.account, thread: Fabricate(:status)) # Reply to another user
|
2024-03-02 01:24:45 +09:00
|
|
|
get "/api/v1/accounts/#{user.account.id}/statuses", params: { exclude_replies: true }, headers: headers
|
2017-08-25 08:41:18 +09:00
|
|
|
end
|
2017-06-01 04:36:24 +09:00
|
|
|
|
2023-10-13 21:42:09 +09:00
|
|
|
it 'returns posts along with self replies', :aggregate_failures do
|
2024-01-26 23:10:26 +09:00
|
|
|
expect(response)
|
|
|
|
.to have_http_status(200)
|
2024-09-20 22:13:04 +09:00
|
|
|
expect(response.content_type)
|
|
|
|
.to start_with('application/json')
|
2024-09-06 18:58:46 +09:00
|
|
|
expect(response.parsed_body)
|
2024-01-26 23:10:26 +09:00
|
|
|
.to have_attributes(size: 2)
|
|
|
|
.and contain_exactly(
|
|
|
|
include(id: status.id.to_s),
|
|
|
|
include(id: status_self_reply.id.to_s)
|
|
|
|
)
|
2017-08-25 08:41:18 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-01-17 08:49:55 +09:00
|
|
|
context 'with only own pinned' do
|
2017-08-25 08:41:18 +09:00
|
|
|
before do
|
|
|
|
Fabricate(:status_pin, account: user.account, status: Fabricate(:status, account: user.account))
|
|
|
|
end
|
|
|
|
|
2024-02-29 23:21:56 +09:00
|
|
|
it 'returns http success and includes a header link' do
|
2024-03-02 01:24:45 +09:00
|
|
|
get "/api/v1/accounts/#{user.account.id}/statuses", params: { pinned: true }, headers: headers
|
2017-08-25 08:41:18 +09:00
|
|
|
|
2024-07-12 17:30:52 +09:00
|
|
|
expect(response)
|
|
|
|
.to have_http_status(200)
|
|
|
|
.and include_pagination_headers(prev: api_v1_account_statuses_url(pinned: true, min_id: Status.first.id))
|
2024-09-20 22:13:04 +09:00
|
|
|
expect(response.content_type)
|
|
|
|
.to start_with('application/json')
|
2024-02-29 23:21:56 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with enough pinned statuses to paginate' do
|
|
|
|
before do
|
|
|
|
stub_const 'Api::BaseController::DEFAULT_STATUSES_LIMIT', 1
|
|
|
|
2.times { Fabricate(:status_pin, account: user.account) }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns http success and header pagination links to prev and next' do
|
2024-03-02 01:24:45 +09:00
|
|
|
get "/api/v1/accounts/#{user.account.id}/statuses", params: { pinned: true }, headers: headers
|
2024-02-29 23:21:56 +09:00
|
|
|
|
2024-07-12 17:30:52 +09:00
|
|
|
expect(response)
|
|
|
|
.to have_http_status(200)
|
|
|
|
.and include_pagination_headers(
|
|
|
|
prev: api_v1_account_statuses_url(pinned: true, min_id: Status.first.id),
|
|
|
|
next: api_v1_account_statuses_url(pinned: true, max_id: Status.first.id)
|
2024-02-29 23:21:56 +09:00
|
|
|
)
|
2024-09-20 22:13:04 +09:00
|
|
|
expect(response.content_type)
|
|
|
|
.to start_with('application/json')
|
2017-08-25 08:41:18 +09:00
|
|
|
end
|
2017-06-01 04:36:24 +09:00
|
|
|
end
|
2022-01-17 08:49:55 +09:00
|
|
|
|
|
|
|
context "with someone else's pinned statuses" do
|
|
|
|
let(:account) { Fabricate(:account, username: 'bob', domain: 'example.com') }
|
|
|
|
let(:status) { Fabricate(:status, account: account) }
|
|
|
|
let(:private_status) { Fabricate(:status, account: account, visibility: :private) }
|
2023-02-14 00:04:26 +09:00
|
|
|
|
|
|
|
before do
|
|
|
|
Fabricate(:status_pin, account: account, status: status)
|
|
|
|
Fabricate(:status_pin, account: account, status: private_status)
|
|
|
|
end
|
2022-01-17 08:49:55 +09:00
|
|
|
|
|
|
|
it 'returns http success' do
|
2024-03-02 01:24:45 +09:00
|
|
|
get "/api/v1/accounts/#{account.id}/statuses", params: { pinned: true }, headers: headers
|
|
|
|
|
2023-02-20 11:16:40 +09:00
|
|
|
expect(response).to have_http_status(200)
|
2024-09-20 22:13:04 +09:00
|
|
|
expect(response.content_type)
|
|
|
|
.to start_with('application/json')
|
2022-01-17 08:49:55 +09:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when user does not follow account' do
|
|
|
|
it 'lists the public status only' do
|
2024-03-02 01:24:45 +09:00
|
|
|
get "/api/v1/accounts/#{account.id}/statuses", params: { pinned: true }, headers: headers
|
|
|
|
|
2024-09-06 18:58:46 +09:00
|
|
|
expect(response.parsed_body)
|
2024-03-02 01:24:45 +09:00
|
|
|
.to contain_exactly(
|
|
|
|
a_hash_including(id: status.id.to_s)
|
|
|
|
)
|
2022-01-17 08:49:55 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when user follows account' do
|
|
|
|
before do
|
|
|
|
user.account.follow!(account)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'lists both the public and the private statuses' do
|
2024-03-02 01:24:45 +09:00
|
|
|
get "/api/v1/accounts/#{account.id}/statuses", params: { pinned: true }, headers: headers
|
|
|
|
|
2024-09-06 18:58:46 +09:00
|
|
|
expect(response.parsed_body)
|
2024-03-02 01:24:45 +09:00
|
|
|
.to contain_exactly(
|
|
|
|
a_hash_including(id: status.id.to_s),
|
|
|
|
a_hash_including(id: private_status.id.to_s)
|
|
|
|
)
|
2024-09-20 22:13:04 +09:00
|
|
|
expect(response.content_type)
|
|
|
|
.to start_with('application/json')
|
2022-01-17 08:49:55 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-06-01 04:36:24 +09:00
|
|
|
end
|
|
|
|
end
|