feat: dashboard API refactor
This commit is contained in:
parent
7d691e4f78
commit
9a6a897f3a
|
|
@ -1,12 +1,12 @@
|
||||||
import graphene
|
import graphene
|
||||||
|
|
||||||
from vbv_lernwelt.course.models import Course, CourseSessionUser
|
from vbv_lernwelt.course.models import Course, CourseSessionUser
|
||||||
from vbv_lernwelt.dashboard.graphql.types import CourseDashboardType
|
from vbv_lernwelt.dashboard.graphql.types.attendance import CourseDashboardType
|
||||||
|
|
||||||
|
|
||||||
class DashboardQuery(graphene.ObjectType):
|
class DashboardQuery(graphene.ObjectType):
|
||||||
course_dashboard = graphene.List(
|
course_dashboard = graphene.List(
|
||||||
CourseDashboardType, course_id=graphene.String(required=False)
|
CourseDashboardType, course_id=graphene.ID(required=False)
|
||||||
)
|
)
|
||||||
|
|
||||||
def resolve_course_dashboard(root, info, course_id: str | None = None):
|
def resolve_course_dashboard(root, info, course_id: str | None = None):
|
||||||
|
|
|
||||||
|
|
@ -10,26 +10,15 @@ from vbv_lernwelt.course_session.services.attendance import AttendanceUserStatus
|
||||||
from vbv_lernwelt.notify.email.email_services import format_swiss_datetime
|
from vbv_lernwelt.notify.email.email_services import format_swiss_datetime
|
||||||
|
|
||||||
|
|
||||||
class CircleDashboardType(graphene.ObjectType):
|
|
||||||
circle_id = graphene.String()
|
|
||||||
circle_title = graphene.String()
|
|
||||||
|
|
||||||
|
|
||||||
class CourseSessionDashboardType(graphene.ObjectType):
|
|
||||||
session_id = graphene.String()
|
|
||||||
session_title = graphene.String()
|
|
||||||
session_generation = graphene.String()
|
|
||||||
|
|
||||||
|
|
||||||
class AttendanceSummary(graphene.ObjectType):
|
class AttendanceSummary(graphene.ObjectType):
|
||||||
days_completed = graphene.Int()
|
days_completed = graphene.Int()
|
||||||
participants_present = graphene.Int()
|
participants_present = graphene.Int()
|
||||||
|
|
||||||
|
|
||||||
class Record(graphene.ObjectType):
|
class Record(graphene.ObjectType):
|
||||||
course_session_id = graphene.String()
|
course_session_id = graphene.ID()
|
||||||
generation = graphene.String()
|
generation = graphene.String()
|
||||||
circle_id = graphene.String()
|
circle_id = graphene.ID()
|
||||||
due_date = graphene.String()
|
due_date = graphene.String()
|
||||||
participants_present = graphene.Int()
|
participants_present = graphene.Int()
|
||||||
participants_total = graphene.Int()
|
participants_total = graphene.Int()
|
||||||
|
|
@ -60,7 +49,6 @@ def calculate_avg_participation(records: List[Record]) -> float:
|
||||||
class CourseDashboardType(graphene.ObjectType):
|
class CourseDashboardType(graphene.ObjectType):
|
||||||
course_id = graphene.String()
|
course_id = graphene.String()
|
||||||
course_title = graphene.String()
|
course_title = graphene.String()
|
||||||
# course_sessions = graphene.List(CourseSessionDashboardType)
|
|
||||||
attendance_day_presences = graphene.Field(AttendanceDayPresences)
|
attendance_day_presences = graphene.Field(AttendanceDayPresences)
|
||||||
|
|
||||||
def resolve_attendance_day_presences(root, info):
|
def resolve_attendance_day_presences(root, info):
|
||||||
|
|
@ -69,6 +57,7 @@ class CourseDashboardType(graphene.ObjectType):
|
||||||
course_session__coursesessionuser__user=user,
|
course_session__coursesessionuser__user=user,
|
||||||
course_session__coursesessionuser__role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
course_session__coursesessionuser__role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
||||||
due_date__end__lt=datetime.datetime.now(),
|
due_date__end__lt=datetime.datetime.now(),
|
||||||
|
course_session__course_id=root.course_id,
|
||||||
).order_by("-due_date__end")
|
).order_by("-due_date__end")
|
||||||
|
|
||||||
_filter = {}
|
_filter = {}
|
||||||
|
|
@ -0,0 +1,7 @@
|
||||||
|
import graphene
|
||||||
|
|
||||||
|
|
||||||
|
class CourseSessionDashboardType(graphene.ObjectType):
|
||||||
|
session_id = graphene.ID()
|
||||||
|
session_title = graphene.String()
|
||||||
|
session_generation = graphene.String()
|
||||||
|
|
@ -0,0 +1,125 @@
|
||||||
|
from datetime import timedelta
|
||||||
|
|
||||||
|
from django.utils import timezone
|
||||||
|
from graphene_django.utils import GraphQLTestCase
|
||||||
|
|
||||||
|
from vbv_lernwelt.course.models import CourseSessionUser
|
||||||
|
from vbv_lernwelt.course_session.services.attendance import AttendanceUserStatus
|
||||||
|
from vbv_lernwelt.dashboard.tests.graphql.utils import (
|
||||||
|
add_course_session_user,
|
||||||
|
create_attendance_course,
|
||||||
|
create_circle,
|
||||||
|
create_course,
|
||||||
|
create_course_session,
|
||||||
|
create_user,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class DashboardTestCase(GraphQLTestCase):
|
||||||
|
GRAPHQL_URL = "/server/graphql/"
|
||||||
|
|
||||||
|
def test_attendance_day_presences(self):
|
||||||
|
# GIVEN
|
||||||
|
course, course_page = create_course("Test Course")
|
||||||
|
course_session = create_course_session(course=course, title="Test Bern 2022 a")
|
||||||
|
|
||||||
|
supervisor = create_user("supervisor")
|
||||||
|
|
||||||
|
add_course_session_user(
|
||||||
|
course_session=course_session,
|
||||||
|
user=supervisor,
|
||||||
|
role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
||||||
|
)
|
||||||
|
|
||||||
|
circle, _ = create_circle(title="Test Circle", course_page=course_page)
|
||||||
|
|
||||||
|
m1 = create_user("member_1")
|
||||||
|
add_course_session_user(
|
||||||
|
course_session=course_session,
|
||||||
|
user=m1,
|
||||||
|
role=CourseSessionUser.Role.MEMBER,
|
||||||
|
)
|
||||||
|
|
||||||
|
m2 = create_user("member_2")
|
||||||
|
add_course_session_user(
|
||||||
|
course_session=course_session,
|
||||||
|
user=m2,
|
||||||
|
role=CourseSessionUser.Role.MEMBER,
|
||||||
|
)
|
||||||
|
|
||||||
|
m3 = create_user("member_3")
|
||||||
|
add_course_session_user(
|
||||||
|
course_session=course_session,
|
||||||
|
user=m3,
|
||||||
|
role=CourseSessionUser.Role.MEMBER,
|
||||||
|
)
|
||||||
|
|
||||||
|
e1 = create_user("expert_1")
|
||||||
|
add_course_session_user(
|
||||||
|
course_session=course_session,
|
||||||
|
user=e1,
|
||||||
|
role=CourseSessionUser.Role.EXPERT,
|
||||||
|
)
|
||||||
|
|
||||||
|
attendance_user_list = [
|
||||||
|
{"user_id": str(m1.id), "status": AttendanceUserStatus.PRESENT.value},
|
||||||
|
{"user_id": str(m2.id), "status": AttendanceUserStatus.ABSENT.value},
|
||||||
|
]
|
||||||
|
|
||||||
|
due_date_end = timezone.now() - timedelta(hours=2)
|
||||||
|
attendance_course = create_attendance_course(
|
||||||
|
course_session=course_session,
|
||||||
|
circle=circle,
|
||||||
|
attendance_user_list=attendance_user_list,
|
||||||
|
due_date_end=due_date_end,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.client.force_login(supervisor)
|
||||||
|
|
||||||
|
query = f"""
|
||||||
|
query($course_id: ID) {{
|
||||||
|
course_dashboard(course_id: $course_id) {{
|
||||||
|
attendance_day_presences{{
|
||||||
|
summary{{
|
||||||
|
days_completed
|
||||||
|
participants_present
|
||||||
|
}}
|
||||||
|
records{{
|
||||||
|
course_session_id
|
||||||
|
generation
|
||||||
|
circle_id
|
||||||
|
due_date
|
||||||
|
participants_present
|
||||||
|
participants_total
|
||||||
|
cockpit_url
|
||||||
|
}}
|
||||||
|
}}
|
||||||
|
}}
|
||||||
|
}}
|
||||||
|
"""
|
||||||
|
|
||||||
|
# WHEN
|
||||||
|
response = self.query(query, variables={"course_id": str(course.id)})
|
||||||
|
|
||||||
|
self.assertResponseNoErrors(response)
|
||||||
|
|
||||||
|
data = response.json()["data"]
|
||||||
|
|
||||||
|
attendance_day_presences = data["course_dashboard"][0][
|
||||||
|
"attendance_day_presences"
|
||||||
|
]
|
||||||
|
|
||||||
|
record = attendance_day_presences["records"][0]
|
||||||
|
|
||||||
|
self.assertEqual(record["course_session_id"], str(course_session.id))
|
||||||
|
self.assertEqual(record["generation"], "2023")
|
||||||
|
self.assertEqual(record["participants_present"], 1)
|
||||||
|
self.assertEqual(record["participants_total"], 3)
|
||||||
|
self.assertEqual(
|
||||||
|
record["cockpit_url"],
|
||||||
|
f"/course/test-lehrgang/cockpit/attendance?id={attendance_course.learning_content.id}&courseSessionId={course_session.id}",
|
||||||
|
)
|
||||||
|
|
||||||
|
summary = attendance_day_presences["summary"]
|
||||||
|
self.assertEqual(summary["days_completed"], 1)
|
||||||
|
self.assertEqual(summary["participants_present"], 34)
|
||||||
|
|
@ -0,0 +1,100 @@
|
||||||
|
from graphene_django.utils import GraphQLTestCase
|
||||||
|
|
||||||
|
from vbv_lernwelt.course.models import CourseSessionUser
|
||||||
|
from vbv_lernwelt.dashboard.tests.graphql.utils import (
|
||||||
|
add_course_session_user,
|
||||||
|
create_course,
|
||||||
|
create_course_session,
|
||||||
|
create_user,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class DashboardTestCase(GraphQLTestCase):
|
||||||
|
GRAPHQL_URL = "/server/graphql/"
|
||||||
|
|
||||||
|
def test_course_dashboard(self):
|
||||||
|
# GIVEN
|
||||||
|
supervisor = create_user("supervisor")
|
||||||
|
course, _ = create_course("Test Course")
|
||||||
|
course_session = create_course_session(course=course, title="Test Bern 2022 a")
|
||||||
|
add_course_session_user(
|
||||||
|
course_session=course_session,
|
||||||
|
user=supervisor,
|
||||||
|
role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
||||||
|
)
|
||||||
|
|
||||||
|
some_course, _ = create_course("Other Course")
|
||||||
|
some_course_session = create_course_session(
|
||||||
|
course=some_course, title="Here is go study"
|
||||||
|
)
|
||||||
|
add_course_session_user(
|
||||||
|
course_session=some_course_session,
|
||||||
|
user=supervisor,
|
||||||
|
role=CourseSessionUser.Role.MEMBER,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.client.force_login(supervisor)
|
||||||
|
|
||||||
|
query = f"""
|
||||||
|
query {{
|
||||||
|
course_dashboard {{
|
||||||
|
course_id
|
||||||
|
course_title
|
||||||
|
}}
|
||||||
|
}}
|
||||||
|
"""
|
||||||
|
|
||||||
|
# WHEN
|
||||||
|
response = self.query(query)
|
||||||
|
|
||||||
|
# THEN
|
||||||
|
self.assertResponseNoErrors(response)
|
||||||
|
|
||||||
|
course_dashboard = response.json()["data"]["course_dashboard"]
|
||||||
|
|
||||||
|
self.assertEqual(len(course_dashboard), 1)
|
||||||
|
self.assertEqual(course_dashboard[0]["course_id"], str(course.id))
|
||||||
|
self.assertEqual(course_dashboard[0]["course_title"], str(course.title))
|
||||||
|
|
||||||
|
def test_course_dashboard_id(self):
|
||||||
|
# GIVEN
|
||||||
|
supervisor = create_user("supervisor")
|
||||||
|
course_1, _ = create_course("Test Course 1")
|
||||||
|
course_2, _ = create_course("Test Course 2")
|
||||||
|
course_session_1 = create_course_session(
|
||||||
|
course=course_1, title="Test Course 1 Session"
|
||||||
|
)
|
||||||
|
course_session_2 = create_course_session(
|
||||||
|
course=course_2, title="Test Course 2 Session"
|
||||||
|
)
|
||||||
|
add_course_session_user(
|
||||||
|
course_session=course_session_1,
|
||||||
|
user=supervisor,
|
||||||
|
role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
||||||
|
)
|
||||||
|
add_course_session_user(
|
||||||
|
course_session=course_session_2,
|
||||||
|
user=supervisor,
|
||||||
|
role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.client.force_login(supervisor)
|
||||||
|
|
||||||
|
query = f"""query($course_id: ID) {{
|
||||||
|
course_dashboard(course_id: $course_id) {{
|
||||||
|
course_id
|
||||||
|
}}
|
||||||
|
}}
|
||||||
|
"""
|
||||||
|
variables = {"course_id": str(course_2.id)}
|
||||||
|
|
||||||
|
# WHEN
|
||||||
|
response = self.query(query, variables=variables)
|
||||||
|
|
||||||
|
# THEN
|
||||||
|
self.assertResponseNoErrors(response)
|
||||||
|
|
||||||
|
course_dashboard = response.json()["data"]["course_dashboard"]
|
||||||
|
|
||||||
|
self.assertEqual(len(course_dashboard), 1)
|
||||||
|
self.assertEqual(course_dashboard[0]["course_id"], str(course_2.id))
|
||||||
|
|
@ -1,253 +0,0 @@
|
||||||
from datetime import timedelta
|
|
||||||
|
|
||||||
from django.utils import timezone
|
|
||||||
from graphene_django.utils import GraphQLTestCase
|
|
||||||
|
|
||||||
from vbv_lernwelt.course.models import CourseSessionUser
|
|
||||||
from vbv_lernwelt.course_session.services.attendance import AttendanceUserStatus
|
|
||||||
from vbv_lernwelt.dashboard.tests.utils import (
|
|
||||||
add_course_session_user,
|
|
||||||
create_attendance_course,
|
|
||||||
create_circle,
|
|
||||||
create_course,
|
|
||||||
create_course_session,
|
|
||||||
create_user,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class DashboardTestCase(GraphQLTestCase):
|
|
||||||
GRAPHQL_URL = "/server/graphql/"
|
|
||||||
|
|
||||||
# def test_course_dashboard(self):
|
|
||||||
# # GIVEN
|
|
||||||
# supervisor = create_user("supervisor")
|
|
||||||
# course = create_course("Test Course")
|
|
||||||
# course_session = create_course_session(
|
|
||||||
# course=course, title="Test Bern 2022 a"
|
|
||||||
# )
|
|
||||||
# add_course_session_user(
|
|
||||||
# course_session=course_session,
|
|
||||||
# user=supervisor,
|
|
||||||
# role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
|
||||||
# )
|
|
||||||
#
|
|
||||||
# some_course = create_course("Other Course")
|
|
||||||
# some_course_session = create_course_session(
|
|
||||||
# course=some_course, title="Here is go study"
|
|
||||||
# )
|
|
||||||
# add_course_session_user(
|
|
||||||
# course_session=some_course_session,
|
|
||||||
# user=supervisor,
|
|
||||||
# role=CourseSessionUser.Role.MEMBER,
|
|
||||||
# )
|
|
||||||
#
|
|
||||||
# self.client.force_login(supervisor)
|
|
||||||
#
|
|
||||||
# query = f"""
|
|
||||||
# query {{
|
|
||||||
# course_dashboard {{
|
|
||||||
# course_id
|
|
||||||
# course_title
|
|
||||||
# }}
|
|
||||||
# }}
|
|
||||||
# """
|
|
||||||
#
|
|
||||||
# # WHEN
|
|
||||||
# response = self.query(query)
|
|
||||||
#
|
|
||||||
# # THEN
|
|
||||||
# self.assertResponseNoErrors(response)
|
|
||||||
#
|
|
||||||
# course_dashboard = response.json()["data"]["course_dashboard"]
|
|
||||||
#
|
|
||||||
# self.assertEqual(len(course_dashboard), 1)
|
|
||||||
# self.assertEqual(course_dashboard[0]["course_id"], str(course.id))
|
|
||||||
# self.assertEqual(course_dashboard[0]["course_title"], str(course.title))
|
|
||||||
#
|
|
||||||
# def test_course_dashboard_id(self):
|
|
||||||
# # GIVEN
|
|
||||||
# supervisor = create_user("supervisor")
|
|
||||||
# course_1 = create_course("Test Course 1")
|
|
||||||
# course_2 = create_course("Test Course 2")
|
|
||||||
# course_session_1 = create_course_session(
|
|
||||||
# course=course_1, title="Test Course 1 Session"
|
|
||||||
# )
|
|
||||||
# course_session_2 = create_course_session(
|
|
||||||
# course=course_2, title="Test Course 2 Session"
|
|
||||||
# )
|
|
||||||
# add_course_session_user(
|
|
||||||
# course_session=course_session_1,
|
|
||||||
# user=supervisor,
|
|
||||||
# role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
|
||||||
# )
|
|
||||||
# add_course_session_user(
|
|
||||||
# course_session=course_session_2,
|
|
||||||
# user=supervisor,
|
|
||||||
# role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
|
||||||
# )
|
|
||||||
#
|
|
||||||
# self.client.force_login(supervisor)
|
|
||||||
#
|
|
||||||
# query = f"""query($course_id: String) {{
|
|
||||||
# course_dashboard(course_id: $course_id) {{
|
|
||||||
# course_id
|
|
||||||
# }}
|
|
||||||
# }}
|
|
||||||
# """
|
|
||||||
# variables = {"course_id": str(course_2.id)}
|
|
||||||
#
|
|
||||||
# # WHEN
|
|
||||||
# response = self.query(query, variables=variables)
|
|
||||||
#
|
|
||||||
# # THEN
|
|
||||||
# self.assertResponseNoErrors(response)
|
|
||||||
#
|
|
||||||
# course_dashboard = response.json()["data"]["course_dashboard"]
|
|
||||||
#
|
|
||||||
# self.assertEqual(len(course_dashboard), 1)
|
|
||||||
# self.assertEqual(course_dashboard[0]["course_id"], str(course_2.id))
|
|
||||||
#
|
|
||||||
# def test_course_dashboard_sessions(self):
|
|
||||||
# # GIVEN
|
|
||||||
# supervisor = create_user("supervisor")
|
|
||||||
# course = create_course("Test Course")
|
|
||||||
# course_session = create_course_session(
|
|
||||||
# course=course, title="Test Bern 2022 a"
|
|
||||||
# )
|
|
||||||
# add_course_session_user(
|
|
||||||
# course_session=course_session,
|
|
||||||
# user=supervisor,
|
|
||||||
# role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
|
||||||
# )
|
|
||||||
#
|
|
||||||
# self.client.force_login(supervisor)
|
|
||||||
#
|
|
||||||
# query = f"""
|
|
||||||
# query {{
|
|
||||||
# course_dashboard {{
|
|
||||||
# course_sessions{{
|
|
||||||
# session_id
|
|
||||||
# session_title
|
|
||||||
# session_generation
|
|
||||||
# }}
|
|
||||||
# }}
|
|
||||||
# }}
|
|
||||||
# """
|
|
||||||
#
|
|
||||||
# # WHEN
|
|
||||||
# response = self.query(query)
|
|
||||||
#
|
|
||||||
# # THEN
|
|
||||||
# self.assertResponseNoErrors(response)
|
|
||||||
#
|
|
||||||
# course_dashboard = response.json()["data"]["course_dashboard"][0]
|
|
||||||
# session = course_dashboard["course_sessions"][0]
|
|
||||||
# self.assertEqual(session["session_id"], str(course_session.id))
|
|
||||||
# self.assertEqual(session["session_title"], str(course_session.title))
|
|
||||||
# self.assertEqual(session["session_generation"], str(course_session.generation))
|
|
||||||
|
|
||||||
def test_attendance_day_presences(self):
|
|
||||||
# GIVEN
|
|
||||||
course, course_page = create_course("Test Course")
|
|
||||||
course_session = create_course_session(course=course, title="Test Bern 2022 a")
|
|
||||||
|
|
||||||
supervisor = create_user("supervisor")
|
|
||||||
|
|
||||||
add_course_session_user(
|
|
||||||
course_session=course_session,
|
|
||||||
user=supervisor,
|
|
||||||
role=CourseSessionUser.Role.SESSION_SUPERVISOR,
|
|
||||||
)
|
|
||||||
|
|
||||||
circle, _ = create_circle(title="Test Circle", course_page=course_page)
|
|
||||||
|
|
||||||
m1 = create_user("member_1")
|
|
||||||
add_course_session_user(
|
|
||||||
course_session=course_session,
|
|
||||||
user=m1,
|
|
||||||
role=CourseSessionUser.Role.MEMBER,
|
|
||||||
)
|
|
||||||
|
|
||||||
m2 = create_user("member_2")
|
|
||||||
add_course_session_user(
|
|
||||||
course_session=course_session,
|
|
||||||
user=m2,
|
|
||||||
role=CourseSessionUser.Role.MEMBER,
|
|
||||||
)
|
|
||||||
|
|
||||||
m3 = create_user("member_3")
|
|
||||||
add_course_session_user(
|
|
||||||
course_session=course_session,
|
|
||||||
user=m3,
|
|
||||||
role=CourseSessionUser.Role.MEMBER,
|
|
||||||
)
|
|
||||||
|
|
||||||
e1 = create_user("expert_1")
|
|
||||||
add_course_session_user(
|
|
||||||
course_session=course_session,
|
|
||||||
user=e1,
|
|
||||||
role=CourseSessionUser.Role.EXPERT,
|
|
||||||
)
|
|
||||||
|
|
||||||
attendance_user_list = [
|
|
||||||
{"user_id": str(m1.id), "status": AttendanceUserStatus.PRESENT.value},
|
|
||||||
{"user_id": str(m2.id), "status": AttendanceUserStatus.ABSENT.value},
|
|
||||||
]
|
|
||||||
|
|
||||||
due_date_end = timezone.now() - timedelta(hours=2)
|
|
||||||
attendance_course = create_attendance_course(
|
|
||||||
course_session=course_session,
|
|
||||||
circle=circle,
|
|
||||||
attendance_user_list=attendance_user_list,
|
|
||||||
due_date_end=due_date_end,
|
|
||||||
)
|
|
||||||
|
|
||||||
self.client.force_login(supervisor)
|
|
||||||
|
|
||||||
query = f"""
|
|
||||||
query {{
|
|
||||||
course_dashboard {{
|
|
||||||
attendance_day_presences{{
|
|
||||||
summary{{
|
|
||||||
days_completed
|
|
||||||
participants_present
|
|
||||||
}}
|
|
||||||
records{{
|
|
||||||
course_session_id
|
|
||||||
generation
|
|
||||||
circle_id
|
|
||||||
due_date
|
|
||||||
participants_present
|
|
||||||
participants_total
|
|
||||||
cockpit_url
|
|
||||||
}}
|
|
||||||
}}
|
|
||||||
}}
|
|
||||||
}}
|
|
||||||
"""
|
|
||||||
|
|
||||||
# WHEN
|
|
||||||
response = self.query(query)
|
|
||||||
|
|
||||||
self.assertResponseNoErrors(response)
|
|
||||||
|
|
||||||
data = response.json()["data"]
|
|
||||||
|
|
||||||
attendance_day_presences = data["course_dashboard"][0][
|
|
||||||
"attendance_day_presences"
|
|
||||||
]
|
|
||||||
|
|
||||||
record = attendance_day_presences["records"][0]
|
|
||||||
|
|
||||||
self.assertEqual(record["course_session_id"], str(course_session.id))
|
|
||||||
self.assertEqual(record["generation"], "2023")
|
|
||||||
self.assertEqual(record["participants_present"], 1)
|
|
||||||
self.assertEqual(record["participants_total"], 3)
|
|
||||||
self.assertEqual(
|
|
||||||
record["cockpit_url"],
|
|
||||||
f"/course/test-lehrgang/cockpit/attendance?id={attendance_course.learning_content.id}&courseSessionId={course_session.id}",
|
|
||||||
)
|
|
||||||
|
|
||||||
summary = attendance_day_presences["summary"]
|
|
||||||
self.assertEqual(summary["days_completed"], 1)
|
|
||||||
self.assertEqual(summary["participants_present"], 34)
|
|
||||||
Loading…
Reference in New Issue