feat: first entities in database
This commit is contained in:
40
test/bds/projects_test.exs
Normal file
40
test/bds/projects_test.exs
Normal file
@@ -0,0 +1,40 @@
|
||||
defmodule BDS.ProjectsTest do
|
||||
use ExUnit.Case, async: false
|
||||
|
||||
setup do
|
||||
:ok = Ecto.Adapters.SQL.Sandbox.checkout(BDS.Repo)
|
||||
end
|
||||
|
||||
test "create_project slugifies names, keeps new projects inactive, and deduplicates slugs" do
|
||||
assert {:ok, first} = BDS.Projects.create_project(%{name: "Föö Bär Blog", data_path: "/tmp/blog"})
|
||||
|
||||
assert first.name == "Föö Bär Blog"
|
||||
assert first.slug == "foo-bar-blog"
|
||||
assert first.data_path == "/tmp/blog"
|
||||
assert first.is_active == false
|
||||
assert is_integer(first.created_at)
|
||||
assert is_integer(first.updated_at)
|
||||
|
||||
assert {:ok, second} = BDS.Projects.create_project(%{name: "Föö Bär Blog"})
|
||||
assert second.slug == "foo-bar-blog-2"
|
||||
assert second.is_active == false
|
||||
end
|
||||
|
||||
test "set_active_project clears the previous active project and activates the target" do
|
||||
assert {:ok, first} = BDS.Projects.create_project(%{name: "First"})
|
||||
assert {:ok, second} = BDS.Projects.create_project(%{name: "Second"})
|
||||
|
||||
assert {:ok, active_first} = BDS.Projects.set_active_project(first.id)
|
||||
assert active_first.is_active == true
|
||||
|
||||
assert {:ok, active_second} = BDS.Projects.set_active_project(second.id)
|
||||
assert active_second.is_active == true
|
||||
|
||||
refetched_first = BDS.Projects.get_project!(first.id)
|
||||
refetched_second = BDS.Projects.get_project!(second.id)
|
||||
|
||||
assert refetched_first.is_active == false
|
||||
assert refetched_second.is_active == true
|
||||
assert Enum.count(BDS.Projects.list_projects(), & &1.is_active) == 1
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user