Fix Oban jobs for imports
This commit is contained in:
parent
08a444f6c3
commit
649e51b581
3 changed files with 7 additions and 6 deletions
1
changelog.d/user-imports.fix
Normal file
1
changelog.d/user-imports.fix
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Imports of blocks, mutes, and following would retry until Oban runs out of attempts due to incorrect return value being considered an error.
|
|
@ -18,7 +18,7 @@ def perform(:mutes_import, %User{} = user, [_ | _] = identifiers) do
|
||||||
fn identifier ->
|
fn identifier ->
|
||||||
with {:ok, %User{} = muted_user} <- User.get_or_fetch(identifier),
|
with {:ok, %User{} = muted_user} <- User.get_or_fetch(identifier),
|
||||||
{:ok, _} <- User.mute(user, muted_user) do
|
{:ok, _} <- User.mute(user, muted_user) do
|
||||||
muted_user
|
{:ok, muted_user}
|
||||||
else
|
else
|
||||||
error -> handle_error(:mutes_import, identifier, error)
|
error -> handle_error(:mutes_import, identifier, error)
|
||||||
end
|
end
|
||||||
|
@ -32,7 +32,7 @@ def perform(:blocks_import, %User{} = blocker, [_ | _] = identifiers) do
|
||||||
fn identifier ->
|
fn identifier ->
|
||||||
with {:ok, %User{} = blocked} <- User.get_or_fetch(identifier),
|
with {:ok, %User{} = blocked} <- User.get_or_fetch(identifier),
|
||||||
{:ok, _block} <- CommonAPI.block(blocked, blocker) do
|
{:ok, _block} <- CommonAPI.block(blocked, blocker) do
|
||||||
blocked
|
{:ok, blocked}
|
||||||
else
|
else
|
||||||
error -> handle_error(:blocks_import, identifier, error)
|
error -> handle_error(:blocks_import, identifier, error)
|
||||||
end
|
end
|
||||||
|
@ -47,7 +47,7 @@ def perform(:follow_import, %User{} = follower, [_ | _] = identifiers) do
|
||||||
with {:ok, %User{} = followed} <- User.get_or_fetch(identifier),
|
with {:ok, %User{} = followed} <- User.get_or_fetch(identifier),
|
||||||
{:ok, follower, followed} <- User.maybe_direct_follow(follower, followed),
|
{:ok, follower, followed} <- User.maybe_direct_follow(follower, followed),
|
||||||
{:ok, _, _, _} <- CommonAPI.follow(followed, follower) do
|
{:ok, _, _, _} <- CommonAPI.follow(followed, follower) do
|
||||||
followed
|
{:ok, followed}
|
||||||
else
|
else
|
||||||
error -> handle_error(:follow_import, identifier, error)
|
error -> handle_error(:follow_import, identifier, error)
|
||||||
end
|
end
|
||||||
|
|
|
@ -29,7 +29,7 @@ test "it imports user followings from list" do
|
||||||
|
|
||||||
assert {:ok, result} = ObanHelpers.perform(job)
|
assert {:ok, result} = ObanHelpers.perform(job)
|
||||||
assert is_list(result)
|
assert is_list(result)
|
||||||
assert result == [refresh_record(user2), refresh_record(user3)]
|
assert result == [{:ok, refresh_record(user2)}, {:ok, refresh_record(user3)}]
|
||||||
assert User.following?(user1, user2)
|
assert User.following?(user1, user2)
|
||||||
assert User.following?(user1, user3)
|
assert User.following?(user1, user3)
|
||||||
end
|
end
|
||||||
|
@ -48,7 +48,7 @@ test "it imports user blocks from list" do
|
||||||
|
|
||||||
assert {:ok, result} = ObanHelpers.perform(job)
|
assert {:ok, result} = ObanHelpers.perform(job)
|
||||||
assert is_list(result)
|
assert is_list(result)
|
||||||
assert result == [user2, user3]
|
assert result == [{:ok, user2}, {:ok, user3}]
|
||||||
assert User.blocks?(user1, user2)
|
assert User.blocks?(user1, user2)
|
||||||
assert User.blocks?(user1, user3)
|
assert User.blocks?(user1, user3)
|
||||||
end
|
end
|
||||||
|
@ -67,7 +67,7 @@ test "it imports user mutes from list" do
|
||||||
|
|
||||||
assert {:ok, result} = ObanHelpers.perform(job)
|
assert {:ok, result} = ObanHelpers.perform(job)
|
||||||
assert is_list(result)
|
assert is_list(result)
|
||||||
assert result == [user2, user3]
|
assert result == [{:ok, user2}, {:ok, user3}]
|
||||||
assert User.mutes?(user1, user2)
|
assert User.mutes?(user1, user2)
|
||||||
assert User.mutes?(user1, user3)
|
assert User.mutes?(user1, user3)
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue