2023-02-22 00:55:31 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-08-08 19:52:15 +00:00
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
RSpec.describe ActivityPub::Activity::Create do
|
2019-03-04 00:13:42 +00:00
|
|
|
let(:sender) { Fabricate(:account, followers_url: 'http://example.com/followers', domain: 'example.com', uri: 'https://example.com/actor') }
|
2017-08-08 19:52:15 +00:00
|
|
|
|
|
|
|
let(:json) do
|
|
|
|
{
|
|
|
|
'@context': 'https://www.w3.org/ns/activitystreams',
|
2018-01-08 04:00:23 +00:00
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#foo'].join,
|
2017-08-08 19:52:15 +00:00
|
|
|
type: 'Create',
|
|
|
|
actor: ActivityPub::TagManager.instance.uri_for(sender),
|
|
|
|
object: object_json,
|
|
|
|
}.with_indifferent_access
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
2018-01-08 04:00:23 +00:00
|
|
|
sender.update(uri: ActivityPub::TagManager.instance.uri_for(sender))
|
|
|
|
|
2017-08-08 19:52:15 +00:00
|
|
|
stub_request(:get, 'http://example.com/attachment.png').to_return(request_fixture('avatar.txt'))
|
2017-09-19 00:42:40 +00:00
|
|
|
stub_request(:get, 'http://example.com/emoji.png').to_return(body: attachment_fixture('emojo.png'))
|
2020-08-02 09:21:10 +00:00
|
|
|
stub_request(:get, 'http://example.com/emojib.png').to_return(body: attachment_fixture('emojo.png'), headers: { 'Content-Type' => 'application/octet-stream' })
|
2017-08-08 19:52:15 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
describe '#perform' do
|
2019-02-17 02:38:25 +00:00
|
|
|
context 'when fetching' do
|
|
|
|
subject { described_class.new(json, sender) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
subject.perform
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when object has been edited' do
|
2022-04-26 19:25:26 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
published: '2022-01-22T15:00:00Z',
|
|
|
|
updated: '2022-01-22T16:00:00Z',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.text).to eq 'Lorem ipsum'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'marks status as edited' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
2023-02-20 05:14:50 +00:00
|
|
|
expect(status.edited?).to be true
|
2022-04-26 19:25:26 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when object has update date equal to creation date' do
|
2022-04-26 19:25:26 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
published: '2022-01-22T15:00:00Z',
|
|
|
|
updated: '2022-01-22T15:00:00Z',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.text).to eq 'Lorem ipsum'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not mark status as edited' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
2023-02-20 05:14:50 +00:00
|
|
|
expect(status.edited?).to be false
|
2022-04-26 19:25:26 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'with an unknown object type' do
|
2019-03-05 02:46:36 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Banana',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not create a status' do
|
|
|
|
expect(sender.statuses.count).to be_zero
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'with a standalone' do
|
2019-02-17 02:38:25 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.text).to eq 'Lorem ipsum'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'missing to/cc defaults to direct privacy' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'direct'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when public with explicit public address' do
|
2019-02-17 02:38:25 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
to: 'https://www.w3.org/ns/activitystreams#Public',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'public'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when public with as:Public' do
|
2021-03-24 09:19:40 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
to: 'as:Public',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'public'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when public with Public' do
|
2021-03-24 09:19:40 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
to: 'Public',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'public'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when unlisted with explicit public address' do
|
2019-02-17 02:38:25 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
cc: 'https://www.w3.org/ns/activitystreams#Public',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'unlisted'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when unlisted with as:Public' do
|
2021-03-24 09:19:40 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
cc: 'as:Public',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'unlisted'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when unlisted with Public' do
|
2021-03-24 09:19:40 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
cc: 'Public',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'unlisted'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when private' do
|
2019-02-17 02:38:25 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
to: 'http://example.com/followers',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'private'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when private with inlined Collection in audience' do
|
2020-08-24 12:11:47 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
to: {
|
2023-02-18 02:23:49 +00:00
|
|
|
type: 'OrderedCollection',
|
|
|
|
id: 'http://example.com/followers',
|
|
|
|
first: 'http://example.com/followers?page=true',
|
2023-02-18 14:33:41 +00:00
|
|
|
},
|
2020-08-24 12:11:47 +00:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'private'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when limited' do
|
2019-02-17 02:38:25 +00:00
|
|
|
let(:recipient) { Fabricate(:account) }
|
|
|
|
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
to: ActivityPub::TagManager.instance.uri_for(recipient),
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'limited'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates silent mention' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
expect(status.mentions.first).to be_silent
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
Merge commit '0d919f27beb6e4e7a562a6eed8f354415b5c217e' into glitch-soc/merge-upstream
Conflicts:
- `.github/dependabot.yml`:
Upstream made changes, but we had removed it.
Discarded upstream changes.
- `.rubocop_todo.yml`:
Upstream regenerated the file, we had some glitch-soc-specific ignores.
- `app/models/account_statuses_filter.rb`:
Minor upstream code style change where glitch-soc had slightly different code
due to handling of local-only posts.
Updated to match upstream's code style.
- `app/models/status.rb`:
Upstream moved ActiveRecord callback definitions, glitch-soc had an extra one.
Moved the definitions as upstream did.
- `app/services/backup_service.rb`:
Upstream rewrote a lot of the backup service, glitch-soc had changes because
of exporting local-only posts.
Took upstream changes and added back code to deal with local-only posts.
- `config/routes.rb`:
Upstream split the file into different files, while glitch-soc had a few
extra routes.
Extra routes added to `config/routes/settings.rb`, `config/routes/api.rb`
and `config/routes/admin.rb`
- `db/schema.rb`:
Upstream has new migrations, while glitch-soc had an extra migration.
Updated the expected serial number to match upstream's.
- `lib/mastodon/version.rb`:
Upstream added support to set version tags from environment variables, while
glitch-soc has an extra `+glitch` tag.
Changed the code to support upstream's feature but prepending a `+glitch`.
- `spec/lib/activitypub/activity/create_spec.rb`:
Minor code style change upstream, while glitch-soc has extra tests due to
`directMessage` handling.
Applied upstream's changes while keeping glitch-soc's extra tests.
- `spec/models/concerns/account_interactions_spec.rb`:
Minor code style change upstream, while glitch-soc has extra tests.
Applied upstream's changes while keeping glitch-soc's extra tests.
2023-05-08 17:05:55 +00:00
|
|
|
context 'when directMessage attribute is false' do
|
2020-08-03 09:55:39 +00:00
|
|
|
let(:recipient) { Fabricate(:account) }
|
|
|
|
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
directMessage: false,
|
|
|
|
to: ActivityPub::TagManager.instance.uri_for(recipient),
|
|
|
|
tag: {
|
|
|
|
type: 'Mention',
|
|
|
|
href: ActivityPub::TagManager.instance.uri_for(recipient),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
Merge commit '0d919f27beb6e4e7a562a6eed8f354415b5c217e' into glitch-soc/merge-upstream
Conflicts:
- `.github/dependabot.yml`:
Upstream made changes, but we had removed it.
Discarded upstream changes.
- `.rubocop_todo.yml`:
Upstream regenerated the file, we had some glitch-soc-specific ignores.
- `app/models/account_statuses_filter.rb`:
Minor upstream code style change where glitch-soc had slightly different code
due to handling of local-only posts.
Updated to match upstream's code style.
- `app/models/status.rb`:
Upstream moved ActiveRecord callback definitions, glitch-soc had an extra one.
Moved the definitions as upstream did.
- `app/services/backup_service.rb`:
Upstream rewrote a lot of the backup service, glitch-soc had changes because
of exporting local-only posts.
Took upstream changes and added back code to deal with local-only posts.
- `config/routes.rb`:
Upstream split the file into different files, while glitch-soc had a few
extra routes.
Extra routes added to `config/routes/settings.rb`, `config/routes/api.rb`
and `config/routes/admin.rb`
- `db/schema.rb`:
Upstream has new migrations, while glitch-soc had an extra migration.
Updated the expected serial number to match upstream's.
- `lib/mastodon/version.rb`:
Upstream added support to set version tags from environment variables, while
glitch-soc has an extra `+glitch` tag.
Changed the code to support upstream's feature but prepending a `+glitch`.
- `spec/lib/activitypub/activity/create_spec.rb`:
Minor code style change upstream, while glitch-soc has extra tests due to
`directMessage` handling.
Applied upstream's changes while keeping glitch-soc's extra tests.
- `spec/models/concerns/account_interactions_spec.rb`:
Minor code style change upstream, while glitch-soc has extra tests.
Applied upstream's changes while keeping glitch-soc's extra tests.
2023-05-08 17:05:55 +00:00
|
|
|
it 'creates status with limited visibility' do
|
2020-08-03 09:55:39 +00:00
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'limited'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'when direct' do
|
2019-02-17 02:38:25 +00:00
|
|
|
let(:recipient) { Fabricate(:account) }
|
|
|
|
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
to: ActivityPub::TagManager.instance.uri_for(recipient),
|
|
|
|
tag: {
|
|
|
|
type: 'Mention',
|
|
|
|
href: ActivityPub::TagManager.instance.uri_for(recipient),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
Merge commit '0d919f27beb6e4e7a562a6eed8f354415b5c217e' into glitch-soc/merge-upstream
Conflicts:
- `.github/dependabot.yml`:
Upstream made changes, but we had removed it.
Discarded upstream changes.
- `.rubocop_todo.yml`:
Upstream regenerated the file, we had some glitch-soc-specific ignores.
- `app/models/account_statuses_filter.rb`:
Minor upstream code style change where glitch-soc had slightly different code
due to handling of local-only posts.
Updated to match upstream's code style.
- `app/models/status.rb`:
Upstream moved ActiveRecord callback definitions, glitch-soc had an extra one.
Moved the definitions as upstream did.
- `app/services/backup_service.rb`:
Upstream rewrote a lot of the backup service, glitch-soc had changes because
of exporting local-only posts.
Took upstream changes and added back code to deal with local-only posts.
- `config/routes.rb`:
Upstream split the file into different files, while glitch-soc had a few
extra routes.
Extra routes added to `config/routes/settings.rb`, `config/routes/api.rb`
and `config/routes/admin.rb`
- `db/schema.rb`:
Upstream has new migrations, while glitch-soc had an extra migration.
Updated the expected serial number to match upstream's.
- `lib/mastodon/version.rb`:
Upstream added support to set version tags from environment variables, while
glitch-soc has an extra `+glitch` tag.
Changed the code to support upstream's feature but prepending a `+glitch`.
- `spec/lib/activitypub/activity/create_spec.rb`:
Minor code style change upstream, while glitch-soc has extra tests due to
`directMessage` handling.
Applied upstream's changes while keeping glitch-soc's extra tests.
- `spec/models/concerns/account_interactions_spec.rb`:
Minor code style change upstream, while glitch-soc has extra tests.
Applied upstream's changes while keeping glitch-soc's extra tests.
2023-05-08 17:05:55 +00:00
|
|
|
it 'creates status with direct visibility' do
|
2019-02-17 02:38:25 +00:00
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'direct'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
Merge commit '0d919f27beb6e4e7a562a6eed8f354415b5c217e' into glitch-soc/merge-upstream
Conflicts:
- `.github/dependabot.yml`:
Upstream made changes, but we had removed it.
Discarded upstream changes.
- `.rubocop_todo.yml`:
Upstream regenerated the file, we had some glitch-soc-specific ignores.
- `app/models/account_statuses_filter.rb`:
Minor upstream code style change where glitch-soc had slightly different code
due to handling of local-only posts.
Updated to match upstream's code style.
- `app/models/status.rb`:
Upstream moved ActiveRecord callback definitions, glitch-soc had an extra one.
Moved the definitions as upstream did.
- `app/services/backup_service.rb`:
Upstream rewrote a lot of the backup service, glitch-soc had changes because
of exporting local-only posts.
Took upstream changes and added back code to deal with local-only posts.
- `config/routes.rb`:
Upstream split the file into different files, while glitch-soc had a few
extra routes.
Extra routes added to `config/routes/settings.rb`, `config/routes/api.rb`
and `config/routes/admin.rb`
- `db/schema.rb`:
Upstream has new migrations, while glitch-soc had an extra migration.
Updated the expected serial number to match upstream's.
- `lib/mastodon/version.rb`:
Upstream added support to set version tags from environment variables, while
glitch-soc has an extra `+glitch` tag.
Changed the code to support upstream's feature but prepending a `+glitch`.
- `spec/lib/activitypub/activity/create_spec.rb`:
Minor code style change upstream, while glitch-soc has extra tests due to
`directMessage` handling.
Applied upstream's changes while keeping glitch-soc's extra tests.
- `spec/models/concerns/account_interactions_spec.rb`:
Minor code style change upstream, while glitch-soc has extra tests.
Applied upstream's changes while keeping glitch-soc's extra tests.
2023-05-08 17:05:55 +00:00
|
|
|
context 'when directMessage attribute is true' do
|
2020-08-03 09:55:39 +00:00
|
|
|
let(:recipient) { Fabricate(:account) }
|
|
|
|
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
to: ActivityPub::TagManager.instance.uri_for(recipient),
|
|
|
|
directMessage: true,
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.visibility).to eq 'direct'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 03:49:08 +00:00
|
|
|
context 'with a reply' do
|
2019-02-17 02:38:25 +00:00
|
|
|
let(:original_status) { Fabricate(:status) }
|
|
|
|
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
inReplyTo: ActivityPub::TagManager.instance.uri_for(original_status),
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.thread).to eq original_status
|
|
|
|
expect(status.reply?).to be true
|
|
|
|
expect(status.in_reply_to_account).to eq original_status.account
|
|
|
|
expect(status.conversation).to eq original_status.conversation
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with mentions' do
|
|
|
|
let(:recipient) { Fabricate(:account) }
|
|
|
|
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
tag: [
|
|
|
|
{
|
|
|
|
type: 'Mention',
|
|
|
|
href: ActivityPub::TagManager.instance.uri_for(recipient),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.mentions.map(&:account)).to include(recipient)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with mentions missing href' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
tag: [
|
|
|
|
{
|
|
|
|
type: 'Mention',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with media attachments' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
attachment: [
|
|
|
|
{
|
|
|
|
type: 'Document',
|
|
|
|
mediaType: 'image/png',
|
|
|
|
url: 'http://example.com/attachment.png',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.media_attachments.map(&:remote_url)).to include('http://example.com/attachment.png')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-11-04 12:00:16 +00:00
|
|
|
context 'with media attachments with long description' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
attachment: [
|
|
|
|
{
|
|
|
|
type: 'Document',
|
|
|
|
mediaType: 'image/png',
|
|
|
|
url: 'http://example.com/attachment.png',
|
|
|
|
name: '*' * 1500,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.media_attachments.map(&:description)).to include('*' * 1500)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-05-15 15:08:59 +00:00
|
|
|
context 'with media attachments with long description as summary' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
attachment: [
|
|
|
|
{
|
|
|
|
type: 'Document',
|
|
|
|
mediaType: 'image/png',
|
|
|
|
url: 'http://example.com/attachment.png',
|
|
|
|
summary: '*' * 1500,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.media_attachments.map(&:description)).to include('*' * 1500)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
context 'with media attachments with focal points' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
attachment: [
|
|
|
|
{
|
|
|
|
type: 'Document',
|
|
|
|
mediaType: 'image/png',
|
|
|
|
url: 'http://example.com/attachment.png',
|
|
|
|
focalPoint: [0.5, -0.7],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.media_attachments.map(&:focus)).to include('0.5,-0.7')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with media attachments missing url' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
attachment: [
|
|
|
|
{
|
|
|
|
type: 'Document',
|
|
|
|
mediaType: 'image/png',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with hashtags' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
tag: [
|
|
|
|
{
|
|
|
|
type: 'Hashtag',
|
|
|
|
href: 'http://example.com/blah',
|
|
|
|
name: '#test',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.tags.map(&:name)).to include('test')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with hashtags missing name' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
tag: [
|
|
|
|
{
|
|
|
|
type: 'Hashtag',
|
|
|
|
href: 'http://example.com/blah',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-12-17 12:31:56 +00:00
|
|
|
context 'with hashtags invalid name' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
tag: [
|
|
|
|
{
|
|
|
|
type: 'Hashtag',
|
|
|
|
href: 'http://example.com/blah',
|
|
|
|
name: 'foo, #eh !',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
context 'with emojis' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum :tinking:',
|
|
|
|
tag: [
|
|
|
|
{
|
|
|
|
type: 'Emoji',
|
|
|
|
icon: {
|
|
|
|
url: 'http://example.com/emoji.png',
|
|
|
|
},
|
|
|
|
name: 'tinking',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.emojis.map(&:shortcode)).to include('tinking')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-08-02 09:21:10 +00:00
|
|
|
context 'with emojis served with invalid content-type' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum :tinkong:',
|
|
|
|
tag: [
|
|
|
|
{
|
|
|
|
type: 'Emoji',
|
|
|
|
icon: {
|
|
|
|
url: 'http://example.com/emojib.png',
|
|
|
|
},
|
|
|
|
name: 'tinkong',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.emojis.map(&:shortcode)).to include('tinkong')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
context 'with emojis missing name' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum :tinking:',
|
|
|
|
tag: [
|
|
|
|
{
|
|
|
|
type: 'Emoji',
|
|
|
|
icon: {
|
|
|
|
url: 'http://example.com/emoji.png',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with emojis missing icon' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum :tinking:',
|
|
|
|
tag: [
|
|
|
|
{
|
|
|
|
type: 'Emoji',
|
|
|
|
name: 'tinking',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
2017-08-08 19:52:15 +00:00
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
end
|
2017-08-08 19:52:15 +00:00
|
|
|
end
|
2019-03-04 00:13:42 +00:00
|
|
|
|
|
|
|
context 'with poll' do
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Question',
|
|
|
|
content: 'Which color was the submarine?',
|
|
|
|
oneOf: [
|
|
|
|
{
|
|
|
|
name: 'Yellow',
|
|
|
|
replies: {
|
|
|
|
type: 'Collection',
|
|
|
|
totalItems: 10,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Blue',
|
|
|
|
replies: {
|
|
|
|
type: 'Collection',
|
|
|
|
totalItems: 3,
|
2023-02-18 14:33:41 +00:00
|
|
|
},
|
2019-03-04 00:13:42 +00:00
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
expect(status).to_not be_nil
|
|
|
|
expect(status.poll).to_not be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates a poll' do
|
|
|
|
poll = sender.polls.first
|
|
|
|
expect(poll).to_not be_nil
|
|
|
|
expect(poll.status).to_not be_nil
|
|
|
|
expect(poll.options).to eq %w(Yellow Blue)
|
|
|
|
expect(poll.cached_tallies).to eq [10, 3]
|
|
|
|
end
|
|
|
|
end
|
2019-03-04 21:51:23 +00:00
|
|
|
|
|
|
|
context 'when a vote to a local poll' do
|
|
|
|
let(:poll) { Fabricate(:poll, options: %w(Yellow Blue)) }
|
2019-03-28 03:44:59 +00:00
|
|
|
let!(:local_status) { Fabricate(:status, poll: poll) }
|
2019-03-04 21:51:23 +00:00
|
|
|
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
name: 'Yellow',
|
2023-02-18 14:33:41 +00:00
|
|
|
inReplyTo: ActivityPub::TagManager.instance.uri_for(local_status),
|
2019-03-04 21:51:23 +00:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'adds a vote to the poll with correct uri' do
|
|
|
|
vote = poll.votes.first
|
|
|
|
expect(vote).to_not be_nil
|
|
|
|
expect(vote.uri).to eq object_json[:id]
|
|
|
|
expect(poll.reload.cached_tallies).to eq [1, 0]
|
|
|
|
end
|
|
|
|
end
|
2019-03-07 23:54:50 +00:00
|
|
|
|
|
|
|
context 'when a vote to an expired local poll' do
|
|
|
|
let(:poll) do
|
|
|
|
poll = Fabricate.build(:poll, options: %w(Yellow Blue), expires_at: 1.day.ago)
|
|
|
|
poll.save(validate: false)
|
|
|
|
poll
|
|
|
|
end
|
2019-03-28 03:44:59 +00:00
|
|
|
let!(:local_status) { Fabricate(:status, poll: poll) }
|
2019-03-07 23:54:50 +00:00
|
|
|
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
name: 'Yellow',
|
2023-02-18 14:33:41 +00:00
|
|
|
inReplyTo: ActivityPub::TagManager.instance.uri_for(local_status),
|
2019-03-07 23:54:50 +00:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not add a vote to the poll' do
|
|
|
|
expect(poll.votes.first).to be_nil
|
|
|
|
end
|
|
|
|
end
|
2017-08-08 19:52:15 +00:00
|
|
|
end
|
|
|
|
|
2020-06-02 17:24:53 +00:00
|
|
|
context 'with an encrypted message' do
|
|
|
|
subject { described_class.new(json, sender, delivery: true, delivered_to_account_id: recipient.id) }
|
|
|
|
|
|
|
|
let(:recipient) { Fabricate(:account) }
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'EncryptedMessage',
|
|
|
|
attributedTo: {
|
|
|
|
type: 'Device',
|
|
|
|
deviceId: '1234',
|
|
|
|
},
|
|
|
|
to: {
|
|
|
|
type: 'Device',
|
|
|
|
deviceId: target_device.device_id,
|
|
|
|
},
|
|
|
|
messageType: 1,
|
|
|
|
cipherText: 'Foo',
|
|
|
|
messageFranking: 'Baz678',
|
|
|
|
digest: {
|
|
|
|
digestAlgorithm: 'Bar456',
|
|
|
|
digestValue: 'Foo123',
|
|
|
|
},
|
|
|
|
}
|
|
|
|
end
|
2023-02-20 02:17:41 +00:00
|
|
|
let(:target_device) { Fabricate(:device, account: recipient) }
|
2020-06-02 17:24:53 +00:00
|
|
|
|
|
|
|
before do
|
|
|
|
subject.perform
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates an encrypted message' do
|
|
|
|
encrypted_message = target_device.encrypted_messages.reload.first
|
|
|
|
|
|
|
|
expect(encrypted_message).to_not be_nil
|
|
|
|
expect(encrypted_message.from_device_id).to eq '1234'
|
|
|
|
expect(encrypted_message.from_account).to eq sender
|
|
|
|
expect(encrypted_message.type).to eq 1
|
|
|
|
expect(encrypted_message.body).to eq 'Foo'
|
|
|
|
expect(encrypted_message.digest).to eq 'Foo123'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates a message franking' do
|
|
|
|
encrypted_message = target_device.encrypted_messages.reload.first
|
|
|
|
message_franking = encrypted_message.message_franking
|
|
|
|
|
|
|
|
crypt = ActiveSupport::MessageEncryptor.new(SystemKey.current_key, serializer: Oj)
|
|
|
|
json = crypt.decrypt_and_verify(message_franking)
|
|
|
|
|
|
|
|
expect(json['source_account_id']).to eq sender.id
|
|
|
|
expect(json['target_account_id']).to eq recipient.id
|
|
|
|
expect(json['original_franking']).to eq 'Baz678'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
context 'when sender is followed by local users' do
|
|
|
|
subject { described_class.new(json, sender, delivery: true) }
|
2017-08-08 19:52:15 +00:00
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
before do
|
|
|
|
Fabricate(:account).follow!(sender)
|
|
|
|
subject.perform
|
2017-08-08 19:52:15 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
let(:object_json) do
|
|
|
|
{
|
2018-01-08 04:00:23 +00:00
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
2017-08-08 19:52:15 +00:00
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
2019-02-17 02:38:25 +00:00
|
|
|
expect(status.text).to eq 'Lorem ipsum'
|
2017-08-08 19:52:15 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
context 'when sender replies to local status' do
|
|
|
|
subject { described_class.new(json, sender, delivery: true) }
|
2018-10-17 15:13:04 +00:00
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
let!(:local_status) { Fabricate(:status) }
|
2017-08-08 19:52:15 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
2018-01-08 04:00:23 +00:00
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
2017-08-08 19:52:15 +00:00
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
2019-02-17 02:38:25 +00:00
|
|
|
inReplyTo: ActivityPub::TagManager.instance.uri_for(local_status),
|
2017-08-08 19:52:15 +00:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2023-02-20 02:17:41 +00:00
|
|
|
before do
|
|
|
|
subject.perform
|
|
|
|
end
|
|
|
|
|
2017-08-08 19:52:15 +00:00
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
2019-02-17 02:38:25 +00:00
|
|
|
expect(status.text).to eq 'Lorem ipsum'
|
2017-08-08 19:52:15 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
context 'when sender targets a local user' do
|
|
|
|
subject { described_class.new(json, sender, delivery: true) }
|
2017-08-08 19:52:15 +00:00
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
let!(:local_account) { Fabricate(:account) }
|
2017-08-08 19:52:15 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
2018-01-08 04:00:23 +00:00
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
2017-08-08 19:52:15 +00:00
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
2019-02-17 02:38:25 +00:00
|
|
|
to: ActivityPub::TagManager.instance.uri_for(local_account),
|
2017-08-08 19:52:15 +00:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2023-02-20 02:17:41 +00:00
|
|
|
before do
|
|
|
|
subject.perform
|
|
|
|
end
|
|
|
|
|
2017-08-08 19:52:15 +00:00
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
2019-02-17 02:38:25 +00:00
|
|
|
expect(status.text).to eq 'Lorem ipsum'
|
2017-09-25 16:33:11 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
context 'when sender cc\'s a local user' do
|
|
|
|
subject { described_class.new(json, sender, delivery: true) }
|
2017-08-08 19:52:15 +00:00
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
let!(:local_account) { Fabricate(:account) }
|
2018-03-04 06:21:41 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
2019-02-17 02:38:25 +00:00
|
|
|
cc: ActivityPub::TagManager.instance.uri_for(local_account),
|
2018-03-04 06:21:41 +00:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2023-02-20 02:17:41 +00:00
|
|
|
before do
|
|
|
|
subject.perform
|
|
|
|
end
|
|
|
|
|
2018-03-04 06:21:41 +00:00
|
|
|
it 'creates status' do
|
|
|
|
status = sender.statuses.first
|
|
|
|
|
|
|
|
expect(status).to_not be_nil
|
2019-02-17 02:38:25 +00:00
|
|
|
expect(status.text).to eq 'Lorem ipsum'
|
2018-03-04 06:21:41 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
context 'when the sender has no relevance to local activity' do
|
|
|
|
subject { described_class.new(json, sender, delivery: true) }
|
2017-09-25 16:33:11 +00:00
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
before do
|
|
|
|
subject.perform
|
2017-09-25 16:33:11 +00:00
|
|
|
end
|
|
|
|
|
2017-08-08 19:52:15 +00:00
|
|
|
let(:object_json) do
|
|
|
|
{
|
2018-01-08 04:00:23 +00:00
|
|
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
2017-08-08 19:52:15 +00:00
|
|
|
type: 'Note',
|
|
|
|
content: 'Lorem ipsum',
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2019-02-17 02:38:25 +00:00
|
|
|
it 'does not create anything' do
|
|
|
|
expect(sender.statuses.count).to eq 0
|
2017-09-25 16:33:11 +00:00
|
|
|
end
|
|
|
|
end
|
2017-08-08 19:52:15 +00:00
|
|
|
end
|
|
|
|
end
|