* Fix mastodon version * テーブル作成 * Wip: フレンドサーバーフォローの承認を受信 * Wip: フレンド申請拒否を受信 * Wip: フォローリクエストを受理 * Wip: 相手からのフォロー・アンフォローを受理 * 普通のフォローとフレンドサーバーのフォローを区別するテストを追加 * ドメインブロックによるフォロー拒否 * ドメインブロックしたあと、申請中のフォロリクを取り下げる処理 * スタブに条件を追加 * Wip: 相手からのDelete信号に対応 * DB定義が消えていたので修正 * Wip: ローカル公開投稿をフレンドに送信する処理など * Wip: 未収載+誰でもの投稿をフレンドに送る設定 * Wip: ローカル公開をそのまま送信する設定を考慮 * Fix test * Wip: 他サーバーからのローカル公開投稿の受け入れ * Wip: Web画面作成 * Fix test * Wip: ローカル公開を連合TLに流す * Wip: フレンドサーバーの削除ボタン * Wip: メール通知や設定のテストなど * Wip: 翻訳を作成 * Fix: 却下されたあとフォローボタンが表示されない問題 * Wip: 編集できない問題 * 有効にしていないフレンドサーバーをリストで無効表示
122 lines
3.6 KiB
Ruby
122 lines
3.6 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe ActivityPub::Activity::Accept do
|
|
let(:sender) { Fabricate(:account) }
|
|
let(:recipient) { Fabricate(:account) }
|
|
|
|
let(:json) do
|
|
{
|
|
'@context': 'https://www.w3.org/ns/activitystreams',
|
|
id: 'foo',
|
|
type: 'Accept',
|
|
actor: ActivityPub::TagManager.instance.uri_for(sender),
|
|
object: {
|
|
id: 'bar',
|
|
type: 'Follow',
|
|
actor: ActivityPub::TagManager.instance.uri_for(recipient),
|
|
object: ActivityPub::TagManager.instance.uri_for(sender),
|
|
},
|
|
}.with_indifferent_access
|
|
end
|
|
|
|
describe '#perform' do
|
|
subject { described_class.new(json, sender) }
|
|
|
|
before do
|
|
allow(RemoteAccountRefreshWorker).to receive(:perform_async)
|
|
Fabricate(:follow_request, account: recipient, target_account: sender)
|
|
subject.perform
|
|
end
|
|
|
|
it 'creates a follow relationship' do
|
|
expect(recipient.following?(sender)).to be true
|
|
end
|
|
|
|
it 'removes the follow request' do
|
|
expect(recipient.requested?(sender)).to be false
|
|
end
|
|
|
|
it 'queues a refresh' do
|
|
expect(RemoteAccountRefreshWorker).to have_received(:perform_async).with(sender.id)
|
|
end
|
|
end
|
|
|
|
context 'when sender is from friend server' do
|
|
subject { described_class.new(json, sender) }
|
|
|
|
let(:sender) { Fabricate(:account, domain: 'abc.com', url: 'https://abc.com/#actor') }
|
|
let!(:friend) { Fabricate(:friend_domain, domain: 'abc.com', active_state: :pending, active_follow_activity_id: 'https://abc-123/456') }
|
|
|
|
before do
|
|
allow(RemoteAccountRefreshWorker).to receive(:perform_async)
|
|
Fabricate(:follow_request, account: recipient, target_account: sender)
|
|
subject.perform
|
|
end
|
|
|
|
it 'creates a follow relationship' do
|
|
expect(recipient.following?(sender)).to be true
|
|
end
|
|
|
|
it 'removes the follow request' do
|
|
expect(recipient.requested?(sender)).to be false
|
|
end
|
|
|
|
it 'queues a refresh' do
|
|
expect(RemoteAccountRefreshWorker).to have_received(:perform_async).with(sender.id)
|
|
end
|
|
|
|
it 'friend server is not changed' do
|
|
expect(friend.reload.i_am_pending?).to be true
|
|
end
|
|
end
|
|
|
|
context 'when given a relay' do
|
|
subject { described_class.new(json, sender) }
|
|
|
|
let!(:relay) { Fabricate(:relay, state: :pending, follow_activity_id: 'https://abc-123/456') }
|
|
|
|
let(:json) do
|
|
{
|
|
'@context': 'https://www.w3.org/ns/activitystreams',
|
|
id: 'foo',
|
|
type: 'Accept',
|
|
actor: ActivityPub::TagManager.instance.uri_for(sender),
|
|
object: {
|
|
id: 'https://abc-123/456',
|
|
type: 'Follow',
|
|
actor: ActivityPub::TagManager.instance.uri_for(recipient),
|
|
object: ActivityPub::TagManager.instance.uri_for(sender),
|
|
},
|
|
}.with_indifferent_access
|
|
end
|
|
|
|
it 'marks the relay as accepted' do
|
|
subject.perform
|
|
expect(relay.reload.accepted?).to be true
|
|
end
|
|
end
|
|
|
|
context 'when given a friend server' do
|
|
subject { described_class.new(json, sender) }
|
|
|
|
let(:sender) { Fabricate(:account, domain: 'abc.com', url: 'https://abc.com/#actor') }
|
|
let!(:friend) { Fabricate(:friend_domain, domain: 'abc.com', active_state: :pending, active_follow_activity_id: 'https://abc-123/456') }
|
|
|
|
let(:json) do
|
|
{
|
|
'@context': 'https://www.w3.org/ns/activitystreams',
|
|
id: 'foo',
|
|
type: 'Accept',
|
|
actor: ActivityPub::TagManager.instance.uri_for(sender),
|
|
object: 'https://abc-123/456',
|
|
}.with_indifferent_access
|
|
end
|
|
|
|
it 'marks the friend as accepted' do
|
|
subject.perform
|
|
expect(friend.reload.i_am_accepted?).to be true
|
|
end
|
|
end
|
|
end
|