Update to sync also BookEditionsRegistry.
continuous-integration/drone/push Build is passing
Details
continuous-integration/drone/push Build is passing
Details
parent
62be4c9165
commit
cbec8fceb4
@ -0,0 +1,31 @@
|
|||||||
|
defmodule DecentralisedBookIndex.Sync.BookEditionsRegistrySync do
|
||||||
|
alias DecentralisedBookIndex.Metadata
|
||||||
|
alias DecentralisedBookIndex.Metadata.BookEditionsRegistry
|
||||||
|
|
||||||
|
def create_update(attrs, server_id) do
|
||||||
|
case Metadata.get_book_editions_registry_by_id(attrs.id) do
|
||||||
|
{:ok, editions_registry} ->
|
||||||
|
attrs =
|
||||||
|
attrs
|
||||||
|
|> Map.delete(:id)
|
||||||
|
|> Map.put(:dbi_server_id, server_id)
|
||||||
|
|
||||||
|
editions_registry
|
||||||
|
|> Ash.Changeset.for_update(:sync, attrs)
|
||||||
|
|> Ash.update!()
|
||||||
|
|
||||||
|
:ok
|
||||||
|
|
||||||
|
{:error, %Ash.Error.Query.NotFound{}} ->
|
||||||
|
attrs =
|
||||||
|
attrs
|
||||||
|
|> Map.put(:dbi_server_id, server_id)
|
||||||
|
|
||||||
|
BookEditionsRegistry
|
||||||
|
|> Ash.Changeset.for_create(:sync_create, attrs)
|
||||||
|
|> Ash.create!()
|
||||||
|
|
||||||
|
:ok
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
@ -0,0 +1,37 @@
|
|||||||
|
defmodule DecentralisedBookIndex.Sync.DataTransformers.BookEditionsRegistrySyncTest do
|
||||||
|
use DecentralisedBookIndex.DataCase, async: true
|
||||||
|
|
||||||
|
alias DecentralisedBookIndex.Sync.BookEditionsRegistrySync
|
||||||
|
alias DecentralisedBookIndex.Metadata
|
||||||
|
|
||||||
|
alias DecentralisedBookIndex.TestEndpoints
|
||||||
|
@test_server_endpoint TestEndpoints.test_api_endpoint()
|
||||||
|
|
||||||
|
describe "sync book edition registry transformations" do
|
||||||
|
test "a new registry will be created" do
|
||||||
|
server = generate(dbi_server(url: @test_server_endpoint))
|
||||||
|
|
||||||
|
attrs = %{
|
||||||
|
id: "889a323e-d104-4b5d-b276-dad5a9b1da9d",
|
||||||
|
}
|
||||||
|
|
||||||
|
assert :ok = BookEditionsRegistrySync.create_update(attrs, server.id)
|
||||||
|
assert {:ok, saved_alias} = Metadata.get_book_editions_registry_by_id(attrs.id)
|
||||||
|
assert server.id == saved_alias.dbi_server_id
|
||||||
|
end
|
||||||
|
|
||||||
|
test "the same registry" do
|
||||||
|
server = generate(dbi_server(url: @test_server_endpoint))
|
||||||
|
|
||||||
|
{:ok, same_alias} = Metadata.create_book_editions_registry()
|
||||||
|
|
||||||
|
attrs = %{
|
||||||
|
id: same_alias.id,
|
||||||
|
}
|
||||||
|
|
||||||
|
assert :ok = BookEditionsRegistrySync.create_update(attrs, server.id)
|
||||||
|
assert {:ok, saved_alias} = Metadata.get_book_editions_registry_by_id(attrs.id)
|
||||||
|
assert server.id == saved_alias.dbi_server_id
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in new issue