Fix /v1/admin/stats всегда пустые данные
Добавлено поле с датой последнего логина пользователям и админам #20
This commit is contained in:
@@ -34,10 +34,34 @@ test() ->
|
||||
end,
|
||||
|
||||
%% TEST 3: Admin stats (superadmin)
|
||||
ct:pal(" TEST 3: Admin stats (superadmin)... "),
|
||||
{ok, {{_, 200, _}, _, StatsResp1}} = httpc:request(get, {AdminURL ++ "/v1/admin/stats", [{"Authorization", "Bearer " ++ binary_to_list(AdminToken)}]}, [], []),
|
||||
ct:pal(" TEST 3: Admin stats for role... "),
|
||||
SuperadminToken = api_test_runner:login_custom_admin(?FALLBACK_ADMIN_SUPER_EMAIL, ?FALLBACK_ADMIN_SUPER_PASSWORD),
|
||||
ModeratorToken = api_test_runner:login_custom_admin(?FALLBACK_ADMIN_MODER_EMAIL, ?FALLBACK_ADMIN_MODER_PASSWORD),
|
||||
SupportToken = api_test_runner:login_custom_admin(?FALLBACK_ADMIN_SUPPORT_EMAIL, ?FALLBACK_ADMIN_SUPPORT_PASSWORD),
|
||||
|
||||
ct:pal(" Admin stats (superadmin)... "),
|
||||
{ok, {{_, 200, _}, _, StatsResp1}} = httpc:request(get, {AdminURL ++ "/v1/admin/stats", [{"Authorization", "Bearer " ++ binary_to_list(SuperadminToken)}]}, [], []),
|
||||
Stats1 = jsx:decode(list_to_binary(StatsResp1), [return_maps]),
|
||||
ct:pal(" OK (keys: ~p)~n", [maps:keys(Stats1)]),
|
||||
ct:pal(" OK (Stats 1: ~p)~n", [Stats1]),
|
||||
map_size(Stats1) > 0,
|
||||
|
||||
ct:pal(" Admin stats (admin)... "),
|
||||
{ok, {{_, 200, _}, _, StatsResp2}} = httpc:request(get, {AdminURL ++ "/v1/admin/stats", [{"Authorization", "Bearer " ++ binary_to_list(AdminToken)}]}, [], []),
|
||||
Stats2 = jsx:decode(list_to_binary(StatsResp2), [return_maps]),
|
||||
ct:pal(" OK (Stats 1: ~p)~n", [Stats2]),
|
||||
map_size(Stats2) > 0,
|
||||
|
||||
ct:pal(" Admin stats (moderator)... "),
|
||||
{ok, {{_, 200, _}, _, StatsResp3}} = httpc:request(get, {AdminURL ++ "/v1/admin/stats", [{"Authorization", "Bearer " ++ binary_to_list(ModeratorToken)}]}, [], []),
|
||||
Stats3 = jsx:decode(list_to_binary(StatsResp3), [return_maps]),
|
||||
ct:pal(" OK (Stats 1: ~p)~n", [Stats3]),
|
||||
map_size(Stats3) > 0,
|
||||
|
||||
ct:pal(" Admin stats (support)... "),
|
||||
{ok, {{_, 200, _}, _, StatsResp4}} = httpc:request(get, {AdminURL ++ "/v1/admin/stats", [{"Authorization", "Bearer " ++ binary_to_list(SupportToken)}]}, [], []),
|
||||
Stats4 = jsx:decode(list_to_binary(StatsResp4), [return_maps]),
|
||||
ct:pal(" OK (Stats 1: ~p)~n", [Stats4]),
|
||||
map_size(Stats4) > 0,
|
||||
|
||||
%% TEST 4: List users
|
||||
ct:pal(" TEST 4: List users... "),
|
||||
|
||||
@@ -3,7 +3,7 @@
|
||||
-export([http_post/2, http_post/3, http_get/1, http_get/2, http_put/3, http_delete/2]).
|
||||
-export([extract_json/2, extract_json/3, assert_status/2]).
|
||||
-export([unique_email/1, register_and_login/2, create_calendar/2, create_event/3]).
|
||||
-export([get_admin_token/0, get_admin_id/0, get_user_token/0, get_user_id/0, get_admin_url/0, get_base_url/0, get_admin_ws_url/0, get_base_ws_url/0]).
|
||||
-export([get_admin_token/0, get_admin_id/0, get_user_token/0, get_user_id/0, get_admin_url/0, get_base_url/0, get_admin_ws_url/0, get_base_ws_url/0, login_admin/2, login_custom_admin/2]).
|
||||
-export([wait_for_server/0]).
|
||||
-export([format_datetime/1]).
|
||||
|
||||
@@ -243,6 +243,14 @@ register_and_login(Email, Password) ->
|
||||
maps:get(<<"token">>, Map)
|
||||
end.
|
||||
|
||||
login_custom_admin(Email, Password) ->
|
||||
%% LoginBody = #{email => Email, password => Password},
|
||||
LoginBody = jsx:encode(#{<<"email">> => Email, <<"password">> => Password}),
|
||||
{ok, {{_, _, _}, _, LoginResp}} = httpc:request(post,
|
||||
{?ADMIN_URL ++ "/v1/admin/login", [], "application/json", LoginBody}, ssl_opts(), []),
|
||||
Map = jsx:decode(list_to_binary(LoginResp), [return_maps]),
|
||||
maps:get(<<"token">>, Map).
|
||||
|
||||
create_calendar(Token, Params) ->
|
||||
Response = http_post("/v1/calendars", Params, Token),
|
||||
ct:pal(" create_calendar Response: ~p~n", [Response]),
|
||||
|
||||
Reference in New Issue
Block a user