fix visibility issues with multiple users
This commit is contained in:
@ -25,10 +25,6 @@ defmodule Memex.ContextsTest do
|
||||
%{slug: "chickens", content: "bananas stuff", tags: ["life", "decisions"]}
|
||||
|> context_fixture(user)
|
||||
|
||||
_shouldnt_return =
|
||||
%{slug: "dog", content: "banana treat stuff", visibility: :private}
|
||||
|> context_fixture(user_fixture())
|
||||
|
||||
# slug
|
||||
assert Contexts.list_contexts("dog", user) == [context_a]
|
||||
assert Contexts.list_contexts("dogs", user) == [context_a]
|
||||
@ -72,15 +68,6 @@ defmodule Memex.ContextsTest do
|
||||
}
|
||||
|> context_fixture(user)
|
||||
|
||||
_shouldnt_return =
|
||||
%{
|
||||
slug: "dog",
|
||||
content: "treats bananas stuff",
|
||||
tags: ["home", "life", "decisions"],
|
||||
visibility: :private
|
||||
}
|
||||
|> context_fixture(user)
|
||||
|
||||
# slug
|
||||
assert Contexts.list_public_contexts("dog") == [context_a]
|
||||
assert Contexts.list_public_contexts("dogs") == [context_a]
|
||||
@ -110,21 +97,6 @@ defmodule Memex.ContextsTest do
|
||||
assert Contexts.get_context!(context.id, user) == context
|
||||
end
|
||||
|
||||
test "get_context!/1 only returns unlisted or public contexts for other users", %{user: user} do
|
||||
another_user = user_fixture()
|
||||
context = context_fixture(%{visibility: :public}, another_user)
|
||||
assert Contexts.get_context!(context.id, user) == context
|
||||
|
||||
context = context_fixture(%{visibility: :unlisted}, another_user)
|
||||
assert Contexts.get_context!(context.id, user) == context
|
||||
|
||||
context = context_fixture(%{visibility: :private}, another_user)
|
||||
|
||||
assert_raise Ecto.NoResultsError, fn ->
|
||||
Contexts.get_context!(context.id, user)
|
||||
end
|
||||
end
|
||||
|
||||
test "get_context_by_slug/1 returns the context with given id", %{user: user} do
|
||||
context = context_fixture(%{slug: "a", visibility: :public}, user)
|
||||
assert Contexts.get_context_by_slug("a", user) == context
|
||||
@ -136,20 +108,6 @@ defmodule Memex.ContextsTest do
|
||||
assert Contexts.get_context_by_slug("c", user) == context
|
||||
end
|
||||
|
||||
test "get_context_by_slug/1 only returns unlisted or public contexts for other users", %{
|
||||
user: user
|
||||
} do
|
||||
another_user = user_fixture()
|
||||
context = context_fixture(%{slug: "a", visibility: :public}, another_user)
|
||||
assert Contexts.get_context_by_slug("a", user) == context
|
||||
|
||||
context = context_fixture(%{slug: "b", visibility: :unlisted}, another_user)
|
||||
assert Contexts.get_context_by_slug("b", user) == context
|
||||
|
||||
context_fixture(%{slug: "c", visibility: :private}, another_user)
|
||||
assert Contexts.get_context_by_slug("c", user) |> is_nil()
|
||||
end
|
||||
|
||||
test "create_context/1 with valid data creates a context", %{user: user} do
|
||||
valid_attrs = %{
|
||||
content: "some content",
|
||||
|
@ -14,7 +14,6 @@ defmodule Memex.NotesTest do
|
||||
note_a = note_fixture(%{slug: "a", visibility: :public}, user)
|
||||
note_b = note_fixture(%{slug: "b", visibility: :unlisted}, user)
|
||||
note_c = note_fixture(%{slug: "c", visibility: :private}, user)
|
||||
_shouldnt_return = note_fixture(%{visibility: :private}, user_fixture())
|
||||
|
||||
assert Notes.list_notes(user) == [note_a, note_b, note_c]
|
||||
end
|
||||
@ -27,10 +26,6 @@ defmodule Memex.NotesTest do
|
||||
%{slug: "chickens", content: "bananas stuff", tags: ["life", "decisions"]}
|
||||
|> note_fixture(user)
|
||||
|
||||
_shouldnt_return =
|
||||
%{slug: "dog", content: "banana treat stuff", visibility: :private}
|
||||
|> note_fixture(user_fixture())
|
||||
|
||||
# slug
|
||||
assert Notes.list_notes("dog", user) == [note_a]
|
||||
assert Notes.list_notes("dogs", user) == [note_a]
|
||||
@ -74,15 +69,6 @@ defmodule Memex.NotesTest do
|
||||
}
|
||||
|> note_fixture(user)
|
||||
|
||||
_shouldnt_return =
|
||||
%{
|
||||
slug: "dog",
|
||||
content: "treats bananas stuff",
|
||||
tags: ["home", "life", "decisions"],
|
||||
visibility: :private
|
||||
}
|
||||
|> note_fixture(user)
|
||||
|
||||
# slug
|
||||
assert Notes.list_public_notes("dog") == [note_a]
|
||||
assert Notes.list_public_notes("dogs") == [note_a]
|
||||
@ -112,21 +98,6 @@ defmodule Memex.NotesTest do
|
||||
assert Notes.get_note!(note.id, user) == note
|
||||
end
|
||||
|
||||
test "get_note!/1 only returns unlisted or public notes for other users", %{user: user} do
|
||||
another_user = user_fixture()
|
||||
note = note_fixture(%{visibility: :public}, another_user)
|
||||
assert Notes.get_note!(note.id, user) == note
|
||||
|
||||
note = note_fixture(%{visibility: :unlisted}, another_user)
|
||||
assert Notes.get_note!(note.id, user) == note
|
||||
|
||||
note = note_fixture(%{visibility: :private}, another_user)
|
||||
|
||||
assert_raise Ecto.NoResultsError, fn ->
|
||||
Notes.get_note!(note.id, user)
|
||||
end
|
||||
end
|
||||
|
||||
test "get_note_by_slug/1 returns the note with given id", %{user: user} do
|
||||
note = note_fixture(%{slug: "a", visibility: :public}, user)
|
||||
assert Notes.get_note_by_slug("a", user) == note
|
||||
@ -138,20 +109,6 @@ defmodule Memex.NotesTest do
|
||||
assert Notes.get_note_by_slug("c", user) == note
|
||||
end
|
||||
|
||||
test "get_note_by_slug/1 only returns unlisted or public notes for other users", %{
|
||||
user: user
|
||||
} do
|
||||
another_user = user_fixture()
|
||||
note = note_fixture(%{slug: "a", visibility: :public}, another_user)
|
||||
assert Notes.get_note_by_slug("a", user) == note
|
||||
|
||||
note = note_fixture(%{slug: "b", visibility: :unlisted}, another_user)
|
||||
assert Notes.get_note_by_slug("b", user) == note
|
||||
|
||||
note_fixture(%{slug: "c", visibility: :private}, another_user)
|
||||
assert Notes.get_note_by_slug("c", user) |> is_nil()
|
||||
end
|
||||
|
||||
test "create_note/1 with valid data creates a note", %{user: user} do
|
||||
valid_attrs = %{
|
||||
content: "some content",
|
||||
|
@ -25,10 +25,6 @@ defmodule Memex.PipelinesTest do
|
||||
%{slug: "chickens", description: "bananas stuff", tags: ["life", "decisions"]}
|
||||
|> pipeline_fixture(user)
|
||||
|
||||
_shouldnt_return =
|
||||
%{slug: "dog", description: "banana treat stuff", visibility: :private}
|
||||
|> pipeline_fixture(user_fixture())
|
||||
|
||||
# slug
|
||||
assert Pipelines.list_pipelines("dog", user) == [pipeline_a]
|
||||
assert Pipelines.list_pipelines("dogs", user) == [pipeline_a]
|
||||
@ -72,15 +68,6 @@ defmodule Memex.PipelinesTest do
|
||||
}
|
||||
|> pipeline_fixture(user)
|
||||
|
||||
_shouldnt_return =
|
||||
%{
|
||||
slug: "dog",
|
||||
description: "treats bananas stuff",
|
||||
tags: ["home", "life", "decisions"],
|
||||
visibility: :private
|
||||
}
|
||||
|> pipeline_fixture(user)
|
||||
|
||||
# slug
|
||||
assert Pipelines.list_public_pipelines("dog") == [pipeline_a]
|
||||
assert Pipelines.list_public_pipelines("dogs") == [pipeline_a]
|
||||
@ -110,23 +97,6 @@ defmodule Memex.PipelinesTest do
|
||||
assert Pipelines.get_pipeline!(pipeline.id, user) == pipeline
|
||||
end
|
||||
|
||||
test "get_pipeline!/1 only returns unlisted or public pipelines for other users", %{
|
||||
user: user
|
||||
} do
|
||||
another_user = user_fixture()
|
||||
pipeline = pipeline_fixture(%{visibility: :public}, another_user)
|
||||
assert Pipelines.get_pipeline!(pipeline.id, user) == pipeline
|
||||
|
||||
pipeline = pipeline_fixture(%{visibility: :unlisted}, another_user)
|
||||
assert Pipelines.get_pipeline!(pipeline.id, user) == pipeline
|
||||
|
||||
pipeline = pipeline_fixture(%{visibility: :private}, another_user)
|
||||
|
||||
assert_raise Ecto.NoResultsError, fn ->
|
||||
Pipelines.get_pipeline!(pipeline.id, user)
|
||||
end
|
||||
end
|
||||
|
||||
test "get_pipeline_by_slug/1 returns the pipeline with given id", %{user: user} do
|
||||
pipeline = pipeline_fixture(%{slug: "a", visibility: :public}, user)
|
||||
assert Pipelines.get_pipeline_by_slug("a", user) == pipeline
|
||||
@ -138,20 +108,6 @@ defmodule Memex.PipelinesTest do
|
||||
assert Pipelines.get_pipeline_by_slug("c", user) == pipeline
|
||||
end
|
||||
|
||||
test "get_pipeline_by_slug/1 only returns unlisted or public pipelines for other users", %{
|
||||
user: user
|
||||
} do
|
||||
another_user = user_fixture()
|
||||
pipeline = pipeline_fixture(%{slug: "a", visibility: :public}, another_user)
|
||||
assert Pipelines.get_pipeline_by_slug("a", user) == pipeline
|
||||
|
||||
pipeline = pipeline_fixture(%{slug: "b", visibility: :unlisted}, another_user)
|
||||
assert Pipelines.get_pipeline_by_slug("b", user) == pipeline
|
||||
|
||||
pipeline_fixture(%{slug: "c", visibility: :private}, another_user)
|
||||
assert Pipelines.get_pipeline_by_slug("c", user) |> is_nil()
|
||||
end
|
||||
|
||||
test "create_pipeline/1 with valid data creates a pipeline", %{user: user} do
|
||||
valid_attrs = %{
|
||||
description: "some description",
|
||||
|
@ -25,16 +25,6 @@ defmodule Memex.StepsTest do
|
||||
assert Steps.get_step!(step.id, user) == step
|
||||
end
|
||||
|
||||
test "get_step!/2 only returns unlisted or public steps for other users", %{user: user} do
|
||||
another_user = user_fixture()
|
||||
another_pipeline = pipeline_fixture(another_user)
|
||||
step = step_fixture(0, another_pipeline, another_user)
|
||||
|
||||
assert_raise Ecto.NoResultsError, fn ->
|
||||
Steps.get_step!(step.id, user)
|
||||
end
|
||||
end
|
||||
|
||||
test "create_step/4 with valid data creates a step", %{pipeline: pipeline, user: user} do
|
||||
valid_attrs = %{
|
||||
content: "some content",
|
||||
|
Reference in New Issue
Block a user