aboutsummaryrefslogtreecommitdiffstats
path: root/ctrack
diff options
context:
space:
mode:
authorMatthew Lemon <lemon@matthewlemon.com>2020-10-20 15:15:46 +0100
committerMatthew Lemon <lemon@matthewlemon.com>2020-10-20 15:15:46 +0100
commit98f6ce0fa2ce5692f578a98922f50aa79fd46bdd (patch)
tree0ca0a402c515c9ebbc741a06acd28729b6a86b9a /ctrack
parente4c95417112ffe8ba684b4f1d7bd957f87b2f2ed (diff)
func can do deputy_lead_inspectors
Diffstat (limited to 'ctrack')
-rw-r--r--ctrack/core/tests/test_views.py27
-rw-r--r--ctrack/organisations/views.py7
2 files changed, 20 insertions, 14 deletions
diff --git a/ctrack/core/tests/test_views.py b/ctrack/core/tests/test_views.py
index 53dc1da..9f7d292 100644
--- a/ctrack/core/tests/test_views.py
+++ b/ctrack/core/tests/test_views.py
@@ -15,18 +15,18 @@ def test_group_lead_inspector_by_submode(
submode2 = Submode.objects.create(
descriptor="Metro Rail", mode=Mode.objects.create(descriptor="Rail"))
- org1 = OrganisationFactory(submode=submode1, lead_inspector=inspector1)
- org2 = OrganisationFactory(submode=submode1, lead_inspector=inspector1)
- org3 = OrganisationFactory(submode=submode1, lead_inspector=inspector1)
- org4 = OrganisationFactory(submode=submode1, lead_inspector=inspector1)
+ OrganisationFactory(submode=submode1, lead_inspector=inspector1, deputy_lead_inspector=inspector2)
+ OrganisationFactory(submode=submode1, lead_inspector=inspector1, deputy_lead_inspector=inspector2)
+ OrganisationFactory(submode=submode1, lead_inspector=inspector1, deputy_lead_inspector=inspector2)
+ OrganisationFactory(submode=submode1, lead_inspector=inspector1, deputy_lead_inspector=inspector2)
- org5 = OrganisationFactory(submode=submode2, lead_inspector=inspector2)
- org6 = OrganisationFactory(submode=submode2, lead_inspector=inspector2)
- org7 = OrganisationFactory(submode=submode2, lead_inspector=inspector2)
- org8 = OrganisationFactory(submode=submode2, lead_inspector=inspector2)
+ OrganisationFactory(submode=submode2, lead_inspector=inspector2, deputy_lead_inspector=inspector1)
+ OrganisationFactory(submode=submode2, lead_inspector=inspector2, deputy_lead_inspector=inspector1)
+ OrganisationFactory(submode=submode2, lead_inspector=inspector2, deputy_lead_inspector=inspector1)
+ OrganisationFactory(submode=submode2, lead_inspector=inspector2, deputy_lead_inspector=inspector1)
# We have two lead inspectors for submode1!
- org8 = OrganisationFactory(submode=submode1, lead_inspector=inspector2)
+ org8 = OrganisationFactory(submode=submode1, lead_inspector=inspector2, deputy_lead_inspector=inspector1)
orgs = Organisation.objects.filter(submode=submode)
leads = [org.lead_inspector for org in orgs]
@@ -36,6 +36,9 @@ def test_group_lead_inspector_by_submode(
for lead in leads[4:]:
assert lead.first_name == "Ogilvie"
- inspector_dict = inspectors_for_each_mode(lead_type="lead_inspector")
- assert inspector_dict["Light Rail"] == [inspector1, inspector2]
- assert inspector_dict["Metro Rail"] == [inspector2]
+ lead_inspectors = inspectors_for_each_mode(lead_type="lead_inspector")
+ deputy_lead_inspectors = inspectors_for_each_mode(lead_type="deputy_lead_inspector")
+ assert lead_inspectors["Light Rail"] == {inspector1, inspector2}
+ assert lead_inspectors["Metro Rail"] == {inspector2}
+ assert deputy_lead_inspectors["Light Rail"] == {inspector2, inspector1}
+ assert deputy_lead_inspectors["Metro Rail"] == {inspector1}
diff --git a/ctrack/organisations/views.py b/ctrack/organisations/views.py
index 45a86bb..82347e6 100644
--- a/ctrack/organisations/views.py
+++ b/ctrack/organisations/views.py
@@ -145,7 +145,10 @@ class IncidentReportCreateView(FormView):
return HttpResponseRedirect(reverse("core:home"))
-def inspectors_for_each_mode(lead_type="lead_inspector") -> Dict[str, List[str]]:
+def inspectors_for_each_mode(lead_type="lead_inspector") -> Dict[str, Set[str]]:
+ """
+ We want to be able to group lead inspectors by submode.
+ """
if lead_type not in ["lead_inspector", "deputy_lead_inspector"]:
raise ValueError("Can only query for lead_inspector and deputy_lead_inspector attributes.")
submodes = Submode.objects.all()
@@ -155,6 +158,6 @@ def inspectors_for_each_mode(lead_type="lead_inspector") -> Dict[str, List[str]]
orgs = sm.organisation_set.all()
for org in orgs:
insp.add(getattr(org, lead_type))
- out[sm.descriptor] = list(insp)
+ out[sm.descriptor] = insp
del insp
return out