diff options
| author | Mark Felder <feld@feld.me> | 2024-07-29 13:54:26 -0400 | 
|---|---|---|
| committer | Mark Felder <feld@feld.me> | 2024-07-29 14:00:46 -0400 | 
| commit | 05d4989795b79683933aa602cd427c57ded10e2f (patch) | |
| tree | 485c0dd363a294790229671b3ca20eb688b96de2 /test | |
| parent | b48fd89a41ad766b79a7a2336737196216cede22 (diff) | |
| download | pleroma-05d4989795b79683933aa602cd427c57ded10e2f.tar.gz pleroma-05d4989795b79683933aa602cd427c57ded10e2f.zip | |
Insert replacement jobs in the new format if any remain undelivered
The old jobs remain and will fail gracefully
Diffstat (limited to 'test')
| -rw-r--r-- | test/pleroma/repo/migrations/publisher_migration_change_test.exs | 43 | 
1 files changed, 43 insertions, 0 deletions
| diff --git a/test/pleroma/repo/migrations/publisher_migration_change_test.exs b/test/pleroma/repo/migrations/publisher_migration_change_test.exs new file mode 100644 index 000000000..9c035e604 --- /dev/null +++ b/test/pleroma/repo/migrations/publisher_migration_change_test.exs @@ -0,0 +1,43 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Repo.Migrations.PublisherMigrationChangeTest do +  use Oban.Testing, repo: Pleroma.Repo +  use Pleroma.DataCase +  import Pleroma.Factory +  import Pleroma.Tests.Helpers + +  alias Pleroma.Activity +  alias Pleroma.Workers.PublisherWorker + +  setup_all do: require_migration("20240729163838_publisher_job_change") + +  describe "up/0" do +    test "migrates publisher jobs to new format", %{migration: migration} do +      user = insert(:user) + +      %Activity{id: activity_id, data: %{"id" => ap_id}} = +        insert(:note_activity, user: user) + +      {:ok, %{id: job_id}} = +        PublisherWorker.new(%{ +          "actor_id" => user.id, +          "json" => "{}", +          "id" => ap_id, +          "inbox" => "https://example.com/inbox", +          "unreachable_since" => nil +        }) +        |> Oban.insert() + +      assert [%{id: ^job_id, args: %{"id" => ^ap_id}}] = all_enqueued(worker: PublisherWorker) + +      assert migration.up() == :ok + +      assert_enqueued( +        worker: PublisherWorker, +        args: %{"id" => ap_id, "activity_id" => activity_id} +      ) +    end +  end +end | 
