After 'mix phx.gen.live Items Item items name:string description:string info:string amount:integer factor:float type:string'
This commit is contained in:
101
test/generic_rest_server/items_test.exs
Normal file
101
test/generic_rest_server/items_test.exs
Normal file
@ -0,0 +1,101 @@
|
||||
defmodule GenericRestServer.ItemsTest do
|
||||
use GenericRestServer.DataCase
|
||||
|
||||
alias GenericRestServer.Items
|
||||
|
||||
describe "items" do
|
||||
alias GenericRestServer.Items.Item
|
||||
|
||||
import GenericRestServer.AccountsFixtures, only: [user_scope_fixture: 0]
|
||||
import GenericRestServer.ItemsFixtures
|
||||
|
||||
@invalid_attrs %{info: nil, name: nil, type: nil, description: nil, amount: nil, factor: nil}
|
||||
|
||||
test "list_items/1 returns all scoped items" do
|
||||
scope = user_scope_fixture()
|
||||
other_scope = user_scope_fixture()
|
||||
item = item_fixture(scope)
|
||||
other_item = item_fixture(other_scope)
|
||||
assert Items.list_items(scope) == [item]
|
||||
assert Items.list_items(other_scope) == [other_item]
|
||||
end
|
||||
|
||||
test "get_item!/2 returns the item with given id" do
|
||||
scope = user_scope_fixture()
|
||||
item = item_fixture(scope)
|
||||
other_scope = user_scope_fixture()
|
||||
assert Items.get_item!(scope, item.id) == item
|
||||
assert_raise Ecto.NoResultsError, fn -> Items.get_item!(other_scope, item.id) end
|
||||
end
|
||||
|
||||
test "create_item/2 with valid data creates a item" do
|
||||
valid_attrs = %{info: "some info", name: "some name", type: "some type", description: "some description", amount: 42, factor: 120.5}
|
||||
scope = user_scope_fixture()
|
||||
|
||||
assert {:ok, %Item{} = item} = Items.create_item(scope, valid_attrs)
|
||||
assert item.info == "some info"
|
||||
assert item.name == "some name"
|
||||
assert item.type == "some type"
|
||||
assert item.description == "some description"
|
||||
assert item.amount == 42
|
||||
assert item.factor == 120.5
|
||||
assert item.user_id == scope.user.id
|
||||
end
|
||||
|
||||
test "create_item/2 with invalid data returns error changeset" do
|
||||
scope = user_scope_fixture()
|
||||
assert {:error, %Ecto.Changeset{}} = Items.create_item(scope, @invalid_attrs)
|
||||
end
|
||||
|
||||
test "update_item/3 with valid data updates the item" do
|
||||
scope = user_scope_fixture()
|
||||
item = item_fixture(scope)
|
||||
update_attrs = %{info: "some updated info", name: "some updated name", type: "some updated type", description: "some updated description", amount: 43, factor: 456.7}
|
||||
|
||||
assert {:ok, %Item{} = item} = Items.update_item(scope, item, update_attrs)
|
||||
assert item.info == "some updated info"
|
||||
assert item.name == "some updated name"
|
||||
assert item.type == "some updated type"
|
||||
assert item.description == "some updated description"
|
||||
assert item.amount == 43
|
||||
assert item.factor == 456.7
|
||||
end
|
||||
|
||||
test "update_item/3 with invalid scope raises" do
|
||||
scope = user_scope_fixture()
|
||||
other_scope = user_scope_fixture()
|
||||
item = item_fixture(scope)
|
||||
|
||||
assert_raise MatchError, fn ->
|
||||
Items.update_item(other_scope, item, %{})
|
||||
end
|
||||
end
|
||||
|
||||
test "update_item/3 with invalid data returns error changeset" do
|
||||
scope = user_scope_fixture()
|
||||
item = item_fixture(scope)
|
||||
assert {:error, %Ecto.Changeset{}} = Items.update_item(scope, item, @invalid_attrs)
|
||||
assert item == Items.get_item!(scope, item.id)
|
||||
end
|
||||
|
||||
test "delete_item/2 deletes the item" do
|
||||
scope = user_scope_fixture()
|
||||
item = item_fixture(scope)
|
||||
assert {:ok, %Item{}} = Items.delete_item(scope, item)
|
||||
assert_raise Ecto.NoResultsError, fn -> Items.get_item!(scope, item.id) end
|
||||
end
|
||||
|
||||
test "delete_item/2 with invalid scope raises" do
|
||||
scope = user_scope_fixture()
|
||||
other_scope = user_scope_fixture()
|
||||
item = item_fixture(scope)
|
||||
assert_raise MatchError, fn -> Items.delete_item(other_scope, item) end
|
||||
end
|
||||
|
||||
test "change_item/2 returns a item changeset" do
|
||||
scope = user_scope_fixture()
|
||||
item = item_fixture(scope)
|
||||
assert %Ecto.Changeset{} = Items.change_item(scope, item)
|
||||
end
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user