pleroma/test/web/twitter_api/twitter_api_test.exs

416 lines
12 KiB
Elixir
Raw Normal View History

2018-12-23 14:11:29 -06:00
# Pleroma: A lightweight social networking server
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
2018-12-23 14:11:29 -06:00
# SPDX-License-Identifier: AGPL-3.0-only
2017-03-21 11:53:20 -05:00
defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do
use Pleroma.DataCase
2019-02-10 15:57:38 -06:00
alias Pleroma.Repo
alias Pleroma.Tests.ObanHelpers
alias Pleroma.User
2019-02-10 15:57:38 -06:00
alias Pleroma.UserInviteToken
alias Pleroma.Web.MastodonAPI.AccountView
alias Pleroma.Web.TwitterAPI.TwitterAPI
2017-04-13 09:19:07 -05:00
setup_all do
Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)
:ok
end
2017-04-16 03:25:27 -05:00
test "it registers a new user and returns the user." do
data = %{
:username => "lain",
2020-04-03 13:45:08 -05:00
:email => "lain@wired.jp",
:fullname => "lain iwakura",
:password => "bear",
:confirm => "bear"
2017-04-16 03:25:27 -05:00
}
{:ok, user} = TwitterAPI.register_user(data)
2019-04-22 02:20:43 -05:00
fetched_user = User.get_cached_by_nickname("lain")
2018-03-30 08:01:53 -05:00
2019-09-30 07:10:54 -05:00
assert AccountView.render("show.json", %{user: user}) ==
AccountView.render("show.json", %{user: fetched_user})
2017-04-16 03:25:27 -05:00
end
test "it registers a new user with empty string in bio and returns the user." do
data = %{
:username => "lain",
2020-04-03 13:45:08 -05:00
:email => "lain@wired.jp",
:fullname => "lain iwakura",
:bio => "",
:password => "bear",
:confirm => "bear"
2017-04-16 03:25:27 -05:00
}
{:ok, user} = TwitterAPI.register_user(data)
2019-04-22 02:20:43 -05:00
fetched_user = User.get_cached_by_nickname("lain")
2018-03-30 08:01:53 -05:00
2019-09-30 07:10:54 -05:00
assert AccountView.render("show.json", %{user: user}) ==
AccountView.render("show.json", %{user: fetched_user})
2017-04-16 03:25:27 -05:00
end
test "it sends confirmation email if :account_activation_required is specified in instance config" do
setting = Pleroma.Config.get([:instance, :account_activation_required])
unless setting do
Pleroma.Config.put([:instance, :account_activation_required], true)
on_exit(fn -> Pleroma.Config.put([:instance, :account_activation_required], setting) end)
end
data = %{
:username => "lain",
2020-04-03 13:45:08 -05:00
:email => "lain@wired.jp",
:fullname => "lain iwakura",
:bio => "",
:password => "bear",
:confirm => "bear"
}
{:ok, user} = TwitterAPI.register_user(data)
ObanHelpers.perform_all()
assert user.confirmation_pending
2019-04-13 02:55:42 -05:00
email = Pleroma.Emails.UserEmail.account_confirmation_email(user)
notify_email = Pleroma.Config.get([:instance, :notify_email])
instance_name = Pleroma.Config.get([:instance, :name])
Swoosh.TestAssertions.assert_email_sent(
from: {instance_name, notify_email},
to: {user.name, user.email},
html_body: email.html_body
)
end
2018-12-02 13:03:53 -06:00
test "it registers a new user and parses mentions in the bio" do
data1 = %{
:username => "john",
2020-04-03 13:45:08 -05:00
:email => "john@gmail.com",
:fullname => "John Doe",
:bio => "test",
:password => "bear",
:confirm => "bear"
2018-12-02 13:03:53 -06:00
}
{:ok, user1} = TwitterAPI.register_user(data1)
data2 = %{
:username => "lain",
2020-04-03 13:45:08 -05:00
:email => "lain@wired.jp",
:fullname => "lain iwakura",
:bio => "@john test",
:password => "bear",
:confirm => "bear"
2018-12-02 13:03:53 -06:00
}
{:ok, user2} = TwitterAPI.register_user(data2)
2018-12-02 13:08:53 -06:00
expected_text =
~s(<span class="h-card"><a class="u-url mention" data-user="#{user1.id}" href="#{
user1.ap_id
}" rel="ugc">@<span>john</span></a></span> test)
2018-12-02 13:03:53 -06:00
assert user2.bio == expected_text
end
describe "register with one time token" do
setup do: clear_config([:instance, :registrations_open], false)
2018-06-12 06:52:54 -05:00
test "returns user on success" do
2019-04-06 08:24:22 -05:00
{:ok, invite} = UserInviteToken.create_invite()
2018-06-12 06:52:54 -05:00
data = %{
:username => "vinny",
2020-04-03 13:45:08 -05:00
:email => "pasta@pizza.vs",
:fullname => "Vinny Vinesauce",
:bio => "streamer",
:password => "hiptofbees",
:confirm => "hiptofbees",
:token => invite.token
}
2018-06-12 07:01:40 -05:00
{:ok, user} = TwitterAPI.register_user(data)
2019-04-22 02:20:43 -05:00
fetched_user = User.get_cached_by_nickname("vinny")
2019-04-06 08:24:22 -05:00
invite = Repo.get_by(UserInviteToken, token: invite.token)
2019-04-06 08:24:22 -05:00
assert invite.used == true
2019-09-30 07:10:54 -05:00
assert AccountView.render("show.json", %{user: user}) ==
AccountView.render("show.json", %{user: fetched_user})
end
test "returns error on invalid token" do
data = %{
:username => "GrimReaper",
2020-04-03 13:45:08 -05:00
:email => "death@reapers.afterlife",
:fullname => "Reaper Grim",
:bio => "Your time has come",
:password => "scythe",
:confirm => "scythe",
:token => "DudeLetMeInImAFairy"
}
{:error, msg} = TwitterAPI.register_user(data)
assert msg == "Invalid token"
2019-04-22 02:20:43 -05:00
refute User.get_cached_by_nickname("GrimReaper")
end
test "returns error on expired token" do
2019-04-06 08:24:22 -05:00
{:ok, invite} = UserInviteToken.create_invite()
UserInviteToken.update_invite!(invite, used: true)
data = %{
:username => "GrimReaper",
2020-04-03 13:45:08 -05:00
:email => "death@reapers.afterlife",
:fullname => "Reaper Grim",
:bio => "Your time has come",
:password => "scythe",
:confirm => "scythe",
:token => invite.token
}
{:error, msg} = TwitterAPI.register_user(data)
assert msg == "Expired token"
2019-04-22 02:20:43 -05:00
refute User.get_cached_by_nickname("GrimReaper")
end
2018-06-12 06:52:54 -05:00
end
describe "registers with date limited token" do
setup do: clear_config([:instance, :registrations_open], false)
setup do
data = %{
:username => "vinny",
2020-04-03 13:45:08 -05:00
:email => "pasta@pizza.vs",
:fullname => "Vinny Vinesauce",
:bio => "streamer",
:password => "hiptofbees",
:confirm => "hiptofbees"
}
2019-04-06 08:24:22 -05:00
check_fn = fn invite ->
2020-04-03 13:45:08 -05:00
data = Map.put(data, :token, invite.token)
{:ok, user} = TwitterAPI.register_user(data)
2019-04-22 02:20:43 -05:00
fetched_user = User.get_cached_by_nickname("vinny")
2019-09-30 07:10:54 -05:00
assert AccountView.render("show.json", %{user: user}) ==
AccountView.render("show.json", %{user: fetched_user})
end
{:ok, data: data, check_fn: check_fn}
end
test "returns user on success", %{check_fn: check_fn} do
{:ok, invite} = UserInviteToken.create_invite(%{expires_at: Date.utc_today()})
2019-04-06 08:24:22 -05:00
check_fn.(invite)
2018-06-12 06:52:54 -05:00
2019-04-06 08:24:22 -05:00
invite = Repo.get_by(UserInviteToken, token: invite.token)
2019-04-06 08:24:22 -05:00
refute invite.used
end
test "returns user on token which expired tomorrow", %{check_fn: check_fn} do
{:ok, invite} = UserInviteToken.create_invite(%{expires_at: Date.add(Date.utc_today(), 1)})
2019-04-06 08:24:22 -05:00
check_fn.(invite)
2019-04-06 08:24:22 -05:00
invite = Repo.get_by(UserInviteToken, token: invite.token)
2019-04-06 08:24:22 -05:00
refute invite.used
end
2018-06-12 06:52:54 -05:00
test "returns an error on overdue date", %{data: data} do
{:ok, invite} = UserInviteToken.create_invite(%{expires_at: Date.add(Date.utc_today(), -1)})
2018-06-12 06:52:54 -05:00
2019-04-06 08:24:22 -05:00
data = Map.put(data, "token", invite.token)
2018-06-12 06:52:54 -05:00
{:error, msg} = TwitterAPI.register_user(data)
assert msg == "Expired token"
2019-04-22 02:20:43 -05:00
refute User.get_cached_by_nickname("vinny")
2019-04-06 08:24:22 -05:00
invite = Repo.get_by(UserInviteToken, token: invite.token)
2019-04-08 08:08:16 -05:00
refute invite.used
end
2018-06-12 06:52:54 -05:00
end
describe "registers with reusable token" do
setup do: clear_config([:instance, :registrations_open], false)
test "returns user on success, after him registration fails" do
2019-04-06 08:24:22 -05:00
{:ok, invite} = UserInviteToken.create_invite(%{max_use: 100})
2019-04-06 08:24:22 -05:00
UserInviteToken.update_invite!(invite, uses: 99)
data = %{
:username => "vinny",
2020-04-03 13:45:08 -05:00
:email => "pasta@pizza.vs",
:fullname => "Vinny Vinesauce",
:bio => "streamer",
:password => "hiptofbees",
:confirm => "hiptofbees",
:token => invite.token
}
{:ok, user} = TwitterAPI.register_user(data)
2019-04-22 02:20:43 -05:00
fetched_user = User.get_cached_by_nickname("vinny")
2019-04-06 08:24:22 -05:00
invite = Repo.get_by(UserInviteToken, token: invite.token)
2019-04-06 08:24:22 -05:00
assert invite.used == true
2019-09-30 07:10:54 -05:00
assert AccountView.render("show.json", %{user: user}) ==
AccountView.render("show.json", %{user: fetched_user})
2018-06-12 06:52:54 -05:00
data = %{
:username => "GrimReaper",
2020-04-03 13:45:08 -05:00
:email => "death@reapers.afterlife",
:fullname => "Reaper Grim",
:bio => "Your time has come",
:password => "scythe",
:confirm => "scythe",
:token => invite.token
}
2018-06-12 06:52:54 -05:00
{:error, msg} = TwitterAPI.register_user(data)
2018-06-12 06:52:54 -05:00
assert msg == "Expired token"
2019-04-22 02:20:43 -05:00
refute User.get_cached_by_nickname("GrimReaper")
end
end
describe "registers with reusable date limited token" do
setup do: clear_config([:instance, :registrations_open], false)
test "returns user on success" do
{:ok, invite} = UserInviteToken.create_invite(%{expires_at: Date.utc_today(), max_use: 100})
data = %{
:username => "vinny",
2020-04-03 13:45:08 -05:00
:email => "pasta@pizza.vs",
:fullname => "Vinny Vinesauce",
:bio => "streamer",
:password => "hiptofbees",
:confirm => "hiptofbees",
:token => invite.token
}
{:ok, user} = TwitterAPI.register_user(data)
2019-04-22 02:20:43 -05:00
fetched_user = User.get_cached_by_nickname("vinny")
2019-04-06 08:24:22 -05:00
invite = Repo.get_by(UserInviteToken, token: invite.token)
2019-04-06 08:24:22 -05:00
refute invite.used
2019-09-30 07:10:54 -05:00
assert AccountView.render("show.json", %{user: user}) ==
AccountView.render("show.json", %{user: fetched_user})
end
test "error after max uses" do
{:ok, invite} = UserInviteToken.create_invite(%{expires_at: Date.utc_today(), max_use: 100})
2019-04-06 08:24:22 -05:00
UserInviteToken.update_invite!(invite, uses: 99)
data = %{
:username => "vinny",
2020-04-03 13:45:08 -05:00
:email => "pasta@pizza.vs",
:fullname => "Vinny Vinesauce",
:bio => "streamer",
:password => "hiptofbees",
:confirm => "hiptofbees",
:token => invite.token
}
{:ok, user} = TwitterAPI.register_user(data)
2019-04-22 02:20:43 -05:00
fetched_user = User.get_cached_by_nickname("vinny")
2019-04-06 08:24:22 -05:00
invite = Repo.get_by(UserInviteToken, token: invite.token)
assert invite.used == true
2019-09-30 07:10:54 -05:00
assert AccountView.render("show.json", %{user: user}) ==
AccountView.render("show.json", %{user: fetched_user})
data = %{
:username => "GrimReaper",
2020-04-03 13:45:08 -05:00
:email => "death@reapers.afterlife",
:fullname => "Reaper Grim",
:bio => "Your time has come",
:password => "scythe",
:confirm => "scythe",
:token => invite.token
}
{:error, msg} = TwitterAPI.register_user(data)
assert msg == "Expired token"
2019-04-22 02:20:43 -05:00
refute User.get_cached_by_nickname("GrimReaper")
end
test "returns error on overdue date" do
2019-04-06 08:24:22 -05:00
{:ok, invite} =
UserInviteToken.create_invite(%{expires_at: Date.add(Date.utc_today(), -1), max_use: 100})
data = %{
:username => "GrimReaper",
2020-04-03 13:45:08 -05:00
:email => "death@reapers.afterlife",
:fullname => "Reaper Grim",
:bio => "Your time has come",
:password => "scythe",
:confirm => "scythe",
:token => invite.token
}
2018-06-12 06:52:54 -05:00
{:error, msg} = TwitterAPI.register_user(data)
assert msg == "Expired token"
2019-04-22 02:20:43 -05:00
refute User.get_cached_by_nickname("GrimReaper")
end
test "returns error on with overdue date and after max" do
2019-04-06 08:24:22 -05:00
{:ok, invite} =
UserInviteToken.create_invite(%{expires_at: Date.add(Date.utc_today(), -1), max_use: 100})
2019-04-06 08:24:22 -05:00
UserInviteToken.update_invite!(invite, uses: 100)
data = %{
:username => "GrimReaper",
2020-04-03 13:45:08 -05:00
:email => "death@reapers.afterlife",
:fullname => "Reaper Grim",
:bio => "Your time has come",
:password => "scythe",
:confirm => "scythe",
:token => invite.token
}
{:error, msg} = TwitterAPI.register_user(data)
assert msg == "Expired token"
2019-04-22 02:20:43 -05:00
refute User.get_cached_by_nickname("GrimReaper")
end
2018-06-12 06:52:54 -05:00
end
2017-04-16 03:25:27 -05:00
test "it returns the error on registration problems" do
data = %{
:username => "lain",
2020-04-03 13:45:08 -05:00
:email => "lain@wired.jp",
:fullname => "lain iwakura",
:bio => "close the world."
2017-04-16 03:25:27 -05:00
}
{:error, error} = TwitterAPI.register_user(data)
2017-04-16 03:25:27 -05:00
assert is_binary(error)
2019-04-22 02:20:43 -05:00
refute User.get_cached_by_nickname("lain")
2017-04-16 03:25:27 -05:00
end
setup do
Supervisor.terminate_child(Pleroma.Supervisor, Cachex)
Supervisor.restart_child(Pleroma.Supervisor, Cachex)
:ok
end
2017-03-21 11:53:20 -05:00
end