mirror of
https://github.com/ash-project/ash_sqlite.git
synced 2024-09-20 05:13:19 +12:00
37 lines
1 KiB
Elixir
37 lines
1 KiB
Elixir
|
defmodule AshSqlite.Test.UniqueIdentityTest do
|
||
|
use AshSqlite.RepoCase, async: false
|
||
|
alias AshSqlite.Test.{Api, Post}
|
||
|
|
||
|
require Ash.Query
|
||
|
|
||
|
test "unique constraint errors are properly caught" do
|
||
|
post =
|
||
|
Post
|
||
|
|> Ash.Changeset.new(%{title: "title"})
|
||
|
|> Api.create!()
|
||
|
|
||
|
assert_raise Ash.Error.Invalid,
|
||
|
~r/Invalid value provided for id: has already been taken/,
|
||
|
fn ->
|
||
|
Post
|
||
|
|> Ash.Changeset.new(%{id: post.id})
|
||
|
|> Api.create!()
|
||
|
end
|
||
|
end
|
||
|
|
||
|
test "a unique constraint can be used to upsert when the resource has a base filter" do
|
||
|
post =
|
||
|
Post
|
||
|
|> Ash.Changeset.new(%{title: "title", uniq_one: "fred", uniq_two: "astair", price: 10})
|
||
|
|> Api.create!()
|
||
|
|
||
|
new_post =
|
||
|
Post
|
||
|
|> Ash.Changeset.new(%{title: "title2", uniq_one: "fred", uniq_two: "astair"})
|
||
|
|> Api.create!(upsert?: true, upsert_identity: :uniq_one_and_two)
|
||
|
|
||
|
assert new_post.id == post.id
|
||
|
assert new_post.price == 10
|
||
|
end
|
||
|
end
|