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