From a6e39851c1309c36ba38d0a0b75c6758d6374ff4 Mon Sep 17 00:00:00 2001 From: Peter Dudfield <34686298+peterdudfield@users.noreply.github.com> Date: Fri, 26 Apr 2024 10:11:15 +0100 Subject: [PATCH] add read and tests #130 (#131) * add read and tests #130 * fix * fix --- pvsite_datamodel/__init__.py | 1 + pvsite_datamodel/read/__init__.py | 9 ++++- pvsite_datamodel/read/user.py | 56 +++++++++++++++++++++++++++++-- tests/test_read.py | 45 +++++++++++++++++++++++++ 4 files changed, 107 insertions(+), 4 deletions(-) diff --git a/pvsite_datamodel/__init__.py b/pvsite_datamodel/__init__.py index 14a35db..fb1e710 100644 --- a/pvsite_datamodel/__init__.py +++ b/pvsite_datamodel/__init__.py @@ -2,6 +2,7 @@ from .connection import DatabaseConnection from .sqlmodels import ( + APIRequestSQL, ForecastSQL, ForecastValueSQL, GenerationSQL, diff --git a/pvsite_datamodel/read/__init__.py b/pvsite_datamodel/read/__init__.py index d564479..83ff30a 100644 --- a/pvsite_datamodel/read/__init__.py +++ b/pvsite_datamodel/read/__init__.py @@ -13,4 +13,11 @@ get_sites_from_user, ) from .status import get_latest_status -from .user import get_all_site_groups, get_all_users, get_site_group_by_name, get_user_by_email +from .user import ( + get_all_last_api_request, + get_all_site_groups, + get_all_users, + get_api_requests_for_one_user, + get_site_group_by_name, + get_user_by_email, +) diff --git a/pvsite_datamodel/read/user.py b/pvsite_datamodel/read/user.py index 45488b6..b3e10cc 100644 --- a/pvsite_datamodel/read/user.py +++ b/pvsite_datamodel/read/user.py @@ -1,10 +1,11 @@ """ Functions for reading user data from the database. """ import logging -from typing import List +from datetime import datetime +from typing import List, Optional -from sqlalchemy.orm import Session +from sqlalchemy.orm import Session, contains_eager -from pvsite_datamodel.sqlmodels import SiteGroupSQL, UserSQL +from pvsite_datamodel.sqlmodels import APIRequestSQL, SiteGroupSQL, UserSQL logger = logging.getLogger(__name__) @@ -90,3 +91,52 @@ def get_all_site_groups(session: Session) -> List[SiteGroupSQL]: site_groups = query.all() return site_groups + + +def get_all_last_api_request(session: Session) -> List[APIRequestSQL]: + """ + Get all last api requests for all users. + + :param session: database session + :return: + """ + + last_requests_sql: [APIRequestSQL] = ( + session.query(APIRequestSQL) + .distinct(APIRequestSQL.user_uuid) + .join(UserSQL) + .options(contains_eager(APIRequestSQL.user)) + .populate_existing() + .order_by(APIRequestSQL.user_uuid, APIRequestSQL.created_utc.desc()) + .all() + ) + + return last_requests_sql + + +def get_api_requests_for_one_user( + session: Session, + email: str, + start_datetime: Optional[datetime] = None, + end_datetime: Optional[datetime] = None, +) -> List[APIRequestSQL]: + """ + Get all api requests for one user. + + :param session: database session + :param email: user email + :param start_datetime: only get api requests after start datetime + :param end_datetime: only get api requests before end datetime + """ + + query = session.query(APIRequestSQL).join(UserSQL).filter(UserSQL.email == email) + + if start_datetime is not None: + query = query.filter(APIRequestSQL.created_utc >= start_datetime) + + if end_datetime is not None: + query = query.filter(APIRequestSQL.created_utc <= end_datetime) + + api_requests: [APIRequestSQL] = query.order_by(APIRequestSQL.created_utc.desc()).all() + + return api_requests diff --git a/tests/test_read.py b/tests/test_read.py index ba7d02a..5a31fc7 100644 --- a/tests/test_read.py +++ b/tests/test_read.py @@ -8,6 +8,7 @@ from sqlalchemy.orm import Query from pvsite_datamodel import ( + APIRequestSQL, ForecastSQL, ForecastValueSQL, SiteGroupSQL, @@ -17,9 +18,11 @@ ) from pvsite_datamodel.pydantic_models import LatitudeLongitudeLimits from pvsite_datamodel.read import ( + get_all_last_api_request, get_all_site_groups, get_all_sites, get_all_users, + get_api_requests_for_one_user, get_latest_forecast_values_by_site, get_latest_status, get_pv_generation_by_sites, @@ -559,3 +562,45 @@ def test_get_site_list_min(db_session, user_with_sites): lat_lon = LatitudeLongitudeLimits(latitude_min=50, longitude_min=2) sites = get_sites_from_user(session=db_session, user=user_with_sites, lat_lon_limits=lat_lon) assert len(sites) > 0 + + +def test_get_all_last_api_request(db_session): + user = get_user_by_email(session=db_session, email="test@test.com") + db_session.add(APIRequestSQL(user_uuid=user.user_uuid, url="test")) + db_session.add(APIRequestSQL(user_uuid=user.user_uuid, url="test2")) + + last_requests_sql = get_all_last_api_request(session=db_session) + assert len(last_requests_sql) == 1 + assert last_requests_sql[0].url == "test2" + assert last_requests_sql[0].user_uuid == user.user_uuid + + +def test_get_api_requests_for_one_user(db_session): + user = get_user_by_email(session=db_session, email="test@test.com") + db_session.add(APIRequestSQL(user_uuid=user.user_uuid, url="test")) + + requests_sql = get_api_requests_for_one_user(session=db_session, email=user.email) + assert len(requests_sql) == 1 + assert requests_sql[0].url == "test" + + +def test_get_api_requests_for_one_user_start_datetime(db_session): + user = get_user_by_email(session=db_session, email="test@test.com") + db_session.add(APIRequestSQL(user_uuid=user.user_uuid, url="test")) + + requests_sql = get_api_requests_for_one_user( + session=db_session, + email=user.email, + start_datetime=dt.datetime.now() + dt.timedelta(hours=1), + ) + assert len(requests_sql) == 0 + + +def test_get_api_requests_for_one_user_end_datetime(db_session): + user = get_user_by_email(session=db_session, email="test@test.com") + db_session.add(APIRequestSQL(user_uuid=user.user_uuid, url="test")) + + requests_sql = get_api_requests_for_one_user( + session=db_session, email=user.email, end_datetime=dt.datetime.now() - dt.timedelta(hours=1) + ) + assert len(requests_sql) == 0