Stage 3.4
This commit is contained in:
@@ -51,17 +51,18 @@ test_create_calendar() ->
|
||||
UserId = create_test_user(),
|
||||
Title = <<"Test Calendar">>,
|
||||
Description = <<"Test Description">>,
|
||||
Confirmation = auto,
|
||||
|
||||
{ok, Calendar} = logic_calendar:create_calendar(UserId, Title, Description),
|
||||
{ok, Calendar} = logic_calendar:create_calendar(UserId, Title, Description, Confirmation),
|
||||
?assertEqual(UserId, Calendar#calendar.owner_id),
|
||||
?assertEqual(Title, Calendar#calendar.title),
|
||||
?assertEqual(personal, Calendar#calendar.type).
|
||||
?assertEqual(personal, Calendar#calendar.type),
|
||||
?assertEqual(Confirmation, Calendar#calendar.confirmation).
|
||||
|
||||
test_get_calendar() ->
|
||||
UserId = create_test_user(),
|
||||
{ok, Calendar} = logic_calendar:create_calendar(UserId, <<"Test">>, <<"">>),
|
||||
{ok, Calendar} = logic_calendar:create_calendar(UserId, <<"Test">>, <<"">>, manual),
|
||||
|
||||
% Владелец имеет доступ
|
||||
case logic_calendar:get_calendar(UserId, Calendar#calendar.id) of
|
||||
{ok, Found} ->
|
||||
?assertEqual(Calendar#calendar.id, Found#calendar.id);
|
||||
@@ -69,77 +70,55 @@ test_get_calendar() ->
|
||||
?assert(false, {unexpected_result, Other})
|
||||
end,
|
||||
|
||||
% Другой пользователь не имеет доступа к personal календарю
|
||||
OtherUserId = create_test_user(),
|
||||
?assertMatch({error, access_denied},
|
||||
logic_calendar:get_calendar(OtherUserId, Calendar#calendar.id)),
|
||||
|
||||
% Делаем календарь коммерческим
|
||||
{ok, Commercial} = logic_calendar:update_calendar(UserId, Calendar#calendar.id, [{type, commercial}]),
|
||||
|
||||
% Теперь другой пользователь имеет доступ
|
||||
{ok, _} = logic_calendar:get_calendar(OtherUserId, Commercial#calendar.id).
|
||||
logic_calendar:get_calendar(OtherUserId, Calendar#calendar.id)).
|
||||
|
||||
test_list_calendars() ->
|
||||
UserId = create_test_user(),
|
||||
{ok, _} = logic_calendar:create_calendar(UserId, <<"Calendar 1">>, <<"">>),
|
||||
{ok, _} = logic_calendar:create_calendar(UserId, <<"Calendar 2">>, <<"">>),
|
||||
{ok, _} = logic_calendar:create_calendar(UserId, <<"Calendar 1">>, <<"">>, manual),
|
||||
{ok, _} = logic_calendar:create_calendar(UserId, <<"Calendar 2">>, <<"">>, auto),
|
||||
|
||||
{ok, Calendars} = logic_calendar:list_calendars(UserId),
|
||||
?assertEqual(2, length(Calendars)).
|
||||
|
||||
test_update_calendar() ->
|
||||
UserId = create_test_user(),
|
||||
{ok, Calendar} = logic_calendar:create_calendar(UserId, <<"Original">>, <<"">>),
|
||||
{ok, Calendar} = logic_calendar:create_calendar(UserId, <<"Original">>, <<"">>, manual),
|
||||
|
||||
Updates = [{title, <<"Updated">>}, {type, commercial}],
|
||||
Updates = [{title, <<"Updated">>}, {type, commercial}, {confirmation, auto}],
|
||||
{ok, Updated} = logic_calendar:update_calendar(UserId, Calendar#calendar.id, Updates),
|
||||
?assertEqual(<<"Updated">>, Updated#calendar.title),
|
||||
?assertEqual(commercial, Updated#calendar.type),
|
||||
?assertEqual(auto, Updated#calendar.confirmation),
|
||||
|
||||
% Другой пользователь не может обновить
|
||||
OtherUserId = create_test_user(),
|
||||
?assertMatch({error, access_denied},
|
||||
logic_calendar:update_calendar(OtherUserId, Calendar#calendar.id, Updates)).
|
||||
|
||||
test_delete_calendar() ->
|
||||
UserId = create_test_user(),
|
||||
{ok, Calendar} = logic_calendar:create_calendar(UserId, <<"Test">>, <<"">>),
|
||||
{ok, Calendar} = logic_calendar:create_calendar(UserId, <<"Test">>, <<"">>, manual),
|
||||
|
||||
{ok, Deleted} = logic_calendar:delete_calendar(UserId, Calendar#calendar.id),
|
||||
?assertEqual(deleted, Deleted#calendar.status),
|
||||
|
||||
% После удаления доступ запрещён
|
||||
?assertMatch({error, access_denied}, logic_calendar:get_calendar(UserId, Calendar#calendar.id)).
|
||||
|
||||
test_access_control() ->
|
||||
OwnerId = create_test_user(),
|
||||
OtherId = create_test_user(),
|
||||
|
||||
% Создаём personal календарь
|
||||
{ok, PersonalCalendar} = logic_calendar:create_calendar(OwnerId, <<"Personal">>, <<"">>),
|
||||
{ok, PersonalCalendar} = logic_calendar:create_calendar(OwnerId, <<"Personal">>, <<"">>, manual),
|
||||
|
||||
% Владелец может редактировать
|
||||
?assert(logic_calendar:can_edit(OwnerId, PersonalCalendar)),
|
||||
|
||||
% Другой пользователь не может редактировать
|
||||
?assertNot(logic_calendar:can_edit(OtherId, PersonalCalendar)),
|
||||
|
||||
% Другой пользователь не может просматривать personal календарь
|
||||
?assertNot(logic_calendar:can_access(OtherId, PersonalCalendar)),
|
||||
|
||||
% Делаем календарь коммерческим
|
||||
{ok, CommercialCalendar} = logic_calendar:update_calendar(OwnerId, PersonalCalendar#calendar.id, [{type, commercial}]),
|
||||
|
||||
% Теперь другой пользователь может просматривать
|
||||
?assert(logic_calendar:can_access(OtherId, CommercialCalendar)),
|
||||
|
||||
% Но всё ещё не может редактировать
|
||||
?assertNot(logic_calendar:can_edit(OtherId, CommercialCalendar)),
|
||||
|
||||
% Замораживаем календарь
|
||||
{ok, Frozen} = core_calendar:update(CommercialCalendar#calendar.id, [{status, frozen}]),
|
||||
|
||||
% После заморозки доступ запрещён всем (кроме владельца для редактирования?)
|
||||
?assertNot(logic_calendar:can_access(OtherId, Frozen)),
|
||||
?assertNot(logic_calendar:can_access(OwnerId, Frozen)).
|
||||
Reference in New Issue
Block a user