mastodon/spec/controllers/accounts_controller_spec.rb
Eugen Rochko 8c45cd0e36 Improve ActivityPub representations (#3844)
* Improve webfinger templates and make tests more flexible

* Clean up AS2 representation of actor

* Refactor outbox

* Create activities representation

* Add representations of followers/following collections, do not redirect /users/:username route if format is empty

* Remove unused translations

* ActivityPub endpoint for single statuses, add ActivityPub::TagManager for better
URL/URI generation

* Add ActivityPub::TagManager#to

* Represent all attachments as Document instead of Image/Video specifically
(Because for remote ones we may not know for sure)

Add mentions and hashtags representation to AP notes

* Add AP-resolvable hashtag URIs

* Use ActiveModelSerializers for ActivityPub

* Clean up unused translations

* Separate route for object and activity

* Adjust cc/to matrices

* Add to/cc to activities, ensure announce activity embeds target status and
not the wrapper status, add "id" to all collections
2017-07-15 03:01:39 +02:00

74 lines
2.1 KiB
Ruby

require 'rails_helper'
RSpec.describe AccountsController, type: :controller do
render_views
let(:alice) { Fabricate(:account, username: 'alice') }
describe 'GET #show' do
let!(:status1) { Status.create!(account: alice, text: 'Hello world') }
let!(:status2) { Status.create!(account: alice, text: 'Boop', thread: status1) }
let!(:status3) { Status.create!(account: alice, text: 'Picture!') }
let!(:status4) { Status.create!(account: alice, text: 'Mentioning @alice') }
before do
status3.media_attachments.create!(account: alice, file: fixture_file_upload('files/attachment.jpg', 'image/jpeg'))
end
context 'atom' do
before do
get :show, params: { username: alice.username, max_id: status4.stream_entry.id, since_id: status1.stream_entry.id }, format: 'atom'
end
it 'assigns @account' do
expect(assigns(:account)).to eq alice
end
it 'assigns @entries' do
entries = assigns(:entries).to_a
expect(entries.size).to eq 2
expect(entries[0].status).to eq status3
expect(entries[1].status).to eq status2
end
it 'returns http success with Atom' do
expect(response).to have_http_status(:success)
end
end
context 'activitystreams2' do
before do
get :show, params: { username: alice.username }, format: 'json'
end
it 'assigns @account' do
expect(assigns(:account)).to eq alice
end
it 'returns http success with Activity Streams 2.0' do
expect(response).to have_http_status(:success)
end
end
context 'html' do
before do
get :show, params: { username: alice.username, max_id: status4.id, since_id: status1.id }
end
it 'assigns @account' do
expect(assigns(:account)).to eq alice
end
it 'assigns @statuses' do
statuses = assigns(:statuses).to_a
expect(statuses.size).to eq 2
expect(statuses[0]).to eq status3
expect(statuses[1]).to eq status2
end
it 'returns http success' do
expect(response).to have_http_status(:success)
end
end
end
end