From 06999b5052e9d260a3ffeb4a557fddc77d22d93b Mon Sep 17 00:00:00 2001 From: Ewen Corre Date: Fri, 29 Nov 2024 13:55:22 +0100 Subject: [PATCH 1/5] job_seekers_views: delete session before leaving the block At this point, when leaving CheckNir views for CheckJobSeekerInformations, we are leaving the job_seeker_views block. Deleting the job_seeker_session when leaving avoids getting too many unused sessions. --- itou/www/job_seekers_views/views.py | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/itou/www/job_seekers_views/views.py b/itou/www/job_seekers_views/views.py index e7a04b2e40..58d0fb85db 100644 --- a/itou/www/job_seekers_views/views.py +++ b/itou/www/job_seekers_views/views.py @@ -289,6 +289,9 @@ def dispatch(self, request, *args, **kwargs): def get(self, request, *args, **kwargs): # The NIR already exists, go to next step if self.job_seeker.jobseeker_profile.nir: + # TODO(ewen): check_job_seeker_info doesn't use the session yet, + # so we delete the session here. + self.job_seeker_session.delete() return HttpResponseRedirect( reverse( "job_seekers_views:check_job_seeker_info", @@ -303,6 +306,9 @@ def post(self, request, *args, **kwargs): self.job_seeker.jobseeker_profile.nir = self.form.cleaned_data["nir"] self.job_seeker.jobseeker_profile.lack_of_nir_reason = "" self.job_seeker.jobseeker_profile.save(update_fields=("nir", "lack_of_nir_reason")) + # TODO(ewen): check_job_seeker_info doesn't use the session yet, + # so we delete the session here. + self.job_seeker_session.delete() return self.redirect_to_check_infos(self.job_seeker.public_id) else: next_url = reverse( From c0910f7735a9423a80bb32259139ab4bf7d75176 Mon Sep 17 00:00:00 2001 From: Ewen Corre Date: Fri, 13 Dec 2024 08:28:19 +0100 Subject: [PATCH 2/5] job_seekers_views: disconnect jobseeker update views from apply The UpdateJobSeeker* views do not inherit from `apply` views anymore. The URL is changed to use the `session_uuid` parameter. The same set of URLs is used for applying and for hiring. For those Update views, the session is initialized by a new `start` view. --- .../apply/submit/application/base.html | 2 +- .../check_job_seeker_info_for_hire.html | 3 +- itou/www/job_seekers_views/urls.py | 37 +- itou/www/job_seekers_views/views.py | 116 +- .../www/apply/__snapshots__/test_submit.ambr | 7708 +++++++++++++---- tests/www/apply/test_submit.py | 353 +- .../test_create_or_update.py | 144 +- 7 files changed, 6349 insertions(+), 2014 deletions(-) diff --git a/itou/templates/apply/submit/application/base.html b/itou/templates/apply/submit/application/base.html index 87f403af3b..9da30caaea 100644 --- a/itou/templates/apply/submit/application/base.html +++ b/itou/templates/apply/submit/application/base.html @@ -38,7 +38,7 @@

{% include 'apply/includes/_submit_title.html' %}

Dernière actualisation du profil : {{ job_seeker.last_checked_at|date }} à {{ job_seeker.last_checked_at|time }} {% if can_view_personal_information and not request.user.is_job_seeker %} - Vérifier le profil + Vérifier le profil {% endif %} {% if new_check_needed %}{% endif %}

diff --git a/itou/templates/job_seekers_views/check_job_seeker_info_for_hire.html b/itou/templates/job_seekers_views/check_job_seeker_info_for_hire.html index f3408b62d8..4b283d55df 100644 --- a/itou/templates/job_seekers_views/check_job_seeker_info_for_hire.html +++ b/itou/templates/job_seekers_views/check_job_seeker_info_for_hire.html @@ -14,7 +14,8 @@

Informations personnelles - Mettre à jour + Mettre à jour

{% include "apply/includes/profile_infos.html" %} diff --git a/itou/www/job_seekers_views/urls.py b/itou/www/job_seekers_views/urls.py index 2f51cb0a68..4c37869d32 100644 --- a/itou/www/job_seekers_views/urls.py +++ b/itou/www/job_seekers_views/urls.py @@ -72,30 +72,6 @@ name="create_job_seeker_step_end_for_hire", kwargs={"hire_process": True}, ), - path( - "/hire/update//1", - views.UpdateJobSeekerStep1View.as_view(), - name="update_job_seeker_step_1_for_hire", - kwargs={"hire_process": True}, - ), - path( - "/hire/update//2", - views.UpdateJobSeekerStep2View.as_view(), - name="update_job_seeker_step_2_for_hire", - kwargs={"hire_process": True}, - ), - path( - "/hire/update//3", - views.UpdateJobSeekerStep3View.as_view(), - name="update_job_seeker_step_3_for_hire", - kwargs={"hire_process": True}, - ), - path( - "/hire/update//end", - views.UpdateJobSeekerStepEndView.as_view(), - name="update_job_seeker_step_end_for_hire", - kwargs={"hire_process": True}, - ), path( "/hire//check-infos", views.CheckJobSeekerInformationsForHire.as_view(), @@ -110,22 +86,27 @@ ), # Job seeker check/updates path( - "/update//1", + "update/start", + views.UpdateJobSeekerStartView.as_view(), + name="update_job_seeker_start", + ), + path( + "update//1", views.UpdateJobSeekerStep1View.as_view(), name="update_job_seeker_step_1", ), path( - "/update//2", + "update//2", views.UpdateJobSeekerStep2View.as_view(), name="update_job_seeker_step_2", ), path( - "/update//3", + "update//3", views.UpdateJobSeekerStep3View.as_view(), name="update_job_seeker_step_3", ), path( - "/update//end", + "update//end", views.UpdateJobSeekerStepEndView.as_view(), name="update_job_seeker_step_end", ), diff --git a/itou/www/job_seekers_views/views.py b/itou/www/job_seekers_views/views.py index 58d0fb85db..630740d0f1 100644 --- a/itou/www/job_seekers_views/views.py +++ b/itou/www/job_seekers_views/views.py @@ -12,7 +12,7 @@ from django.urls import reverse from django.utils import timezone from django.utils.html import format_html -from django.views.generic import DetailView, ListView, TemplateView +from django.views.generic import DetailView, ListView, TemplateView, View from itou.companies import enums as companies_enums from itou.companies.enums import CompanyKind @@ -26,9 +26,9 @@ from itou.utils.apis.exceptions import AddressLookupError from itou.utils.emails import redact_email_address from itou.utils.pagination import ItouPaginator -from itou.utils.session import SessionNamespace, SessionNamespaceRequiredMixin +from itou.utils.session import SessionNamespace from itou.utils.urls import get_safe_url -from itou.www.apply.views.submit_views import ApplicationBaseView, ApplyStepBaseView +from itou.www.apply.views.submit_views import ApplicationBaseView from .forms import ( CheckJobSeekerInfoForm, @@ -755,7 +755,45 @@ def get_context_data(self, **kwargs): return super().get_context_data(**kwargs) | {"profile": self.profile, "progress": "80"} -class UpdateJobSeekerBaseView(SessionNamespaceRequiredMixin, ApplyStepBaseView): +class UpdateJobSeekerStartView(View): + def setup(self, request, *args, **kwargs): + super().setup(request, *args, **kwargs) + + try: + job_seeker = get_object_or_404( + User.objects.filter(kind=UserKind.JOB_SEEKER), public_id=request.GET.get("job_seeker") + ) + except ValidationError: + raise Http404("Aucun candidat n'a été trouvé") + + try: + company = get_object_or_404(Company.objects.with_has_active_members(), pk=request.GET.get("company")) + except ValueError: + raise Http404("Aucune entreprise n'a été trouvée") + + from_url = get_safe_url(request, "from_url", fallback_url=reverse("dashboard:index")) + + if request.user.is_job_seeker or not request.user.can_view_personal_information(job_seeker): + raise PermissionDenied("Votre utilisateur n'est pas autorisé à vérifier les informations de ce candidat") + + self.job_seeker_session = SessionNamespace.create_uuid_namespace( + request.session, + data={ + "config": {"from_url": from_url}, + "job_seeker_pk": job_seeker.pk, + "apply": {"company_pk": company.pk}, + }, + ) + + def get(self, request, *args, **kwargs): + return HttpResponseRedirect( + reverse( + "job_seekers_views:update_job_seeker_step_1", kwargs={"session_uuid": self.job_seeker_session.name} + ) + ) + + +class UpdateJobSeekerBaseView(JobSeekerBaseView): def __init__(self): super().__init__() self.job_seeker_session = None @@ -764,27 +802,23 @@ def get_job_seeker_queryset(self): return User.objects.filter(kind=UserKind.JOB_SEEKER) def setup(self, request, *args, **kwargs): - self.job_seeker = get_object_or_404(self.get_job_seeker_queryset(), public_id=kwargs["job_seeker_public_id"]) - self.job_seeker_session = SessionNamespace(request.session, f"job_seeker-{self.job_seeker.public_id}") + super().setup(request, *args, **kwargs) + self.job_seeker = get_object_or_404( + self.get_job_seeker_queryset(), pk=self.job_seeker_session.get("job_seeker_pk") + ) if request.user.is_job_seeker or not request.user.can_view_personal_information(self.job_seeker): # Since the link leading to this process isn't visible to those users, this should never happen raise PermissionDenied("Votre utilisateur n'est pas autorisé à vérifier les informations de ce candidat") - super().setup(request, *args, **kwargs) def get_context_data(self, **kwargs): return super().get_context_data(**kwargs) | { "update_job_seeker": True, "job_seeker": self.job_seeker, "step_3_url": reverse( - "job_seekers_views:update_job_seeker_step_3_for_hire" - if self.hire_process - else "job_seekers_views:update_job_seeker_step_3", - kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, - ), - "reset_url": reverse( - "apply:application_jobs", - kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + "job_seekers_views:update_job_seeker_step_3", + kwargs={"session_uuid": self.job_seeker_session.name}, ), + "reset_url": self.get_reset_url(), "readonly_form": False, } @@ -792,28 +826,26 @@ def _disable_form(self): for field in self.form: field.field.disabled = True + def get_reset_url(self): + return self.job_seeker_session.get("config").get("from_url") + def get_back_url(self): - view_name = self.previous_hire_url if self.hire_process else self.previous_apply_url return reverse( - view_name, - kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + self.previous_url, + kwargs={"session_uuid": self.job_seeker_session.name}, ) def get_next_url(self): - view_name = self.next_hire_url if self.hire_process else self.next_apply_url return reverse( - view_name, - kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + self.next_url, + kwargs={"session_uuid": self.job_seeker_session.name}, ) class UpdateJobSeekerStep1View(UpdateJobSeekerBaseView): template_name = "job_seekers_views/create_or_update_job_seeker/step_1.html" - previous_apply_url = "apply:application_jobs" - previous_hire_url = "job_seekers_views:check_job_seeker_info_for_hire" - next_apply_url = "job_seekers_views:update_job_seeker_step_2" - next_hire_url = "job_seekers_views:update_job_seeker_step_2_for_hire" + next_url = "job_seekers_views:update_job_seeker_step_2" def __init__(self): super().__init__() @@ -824,8 +856,8 @@ def get_job_seeker_queryset(self): def setup(self, request, *args, **kwargs): super().setup(request, *args, **kwargs) - if not self.job_seeker_session.exists(): - self.job_seeker_session.init({"user": {}}) + if not self.job_seeker_session.get("user"): + self.job_seeker_session.set("user", {}) session_nir = self.job_seeker_session.get("profile", {}).get("nir") session_lack_of_nir_reason = self.job_seeker_session.get("profile", {}).get("lack_of_nir_reason") @@ -861,6 +893,9 @@ def post(self, request, *args, **kwargs): return self.render_to_response(self.get_context_data(**kwargs)) + def get_back_url(self): + return self.get_reset_url() + def get_context_data(self, **kwargs): return super().get_context_data(**kwargs) | { "confirmation_needed": False, @@ -873,12 +908,9 @@ def get_context_data(self, **kwargs): class UpdateJobSeekerStep2View(UpdateJobSeekerBaseView): template_name = "job_seekers_views/create_or_update_job_seeker/step_2.html" - required_session_namespaces = ["job_seeker_session"] + UpdateJobSeekerBaseView.required_session_namespaces - previous_apply_url = "job_seekers_views:update_job_seeker_step_1" - previous_hire_url = "job_seekers_views:update_job_seeker_step_1_for_hire" - next_apply_url = "job_seekers_views:update_job_seeker_step_3" - next_hire_url = "job_seekers_views:update_job_seeker_step_3_for_hire" + previous_url = "job_seekers_views:update_job_seeker_step_1" + next_url = "job_seekers_views:update_job_seeker_step_3" def __init__(self): super().__init__() @@ -913,12 +945,9 @@ def get_context_data(self, **kwargs): class UpdateJobSeekerStep3View(UpdateJobSeekerBaseView): template_name = "job_seekers_views/create_or_update_job_seeker/step_3.html" - required_session_namespaces = ["job_seeker_session"] + UpdateJobSeekerBaseView.required_session_namespaces - previous_apply_url = "job_seekers_views:update_job_seeker_step_2" - previous_hire_url = "job_seekers_views:update_job_seeker_step_2_for_hire" - next_apply_url = "job_seekers_views:update_job_seeker_step_end" - next_hire_url = "job_seekers_views:update_job_seeker_step_end_for_hire" + previous_url = "job_seekers_views:update_job_seeker_step_2" + next_url = "job_seekers_views:update_job_seeker_step_end" def __init__(self): super().__init__() @@ -952,12 +981,8 @@ def get_context_data(self, **kwargs): class UpdateJobSeekerStepEndView(UpdateJobSeekerBaseView): template_name = "job_seekers_views/create_or_update_job_seeker/step_end.html" - required_session_namespaces = ["job_seeker_session"] + UpdateJobSeekerBaseView.required_session_namespaces - previous_apply_url = "job_seekers_views:update_job_seeker_step_3" - previous_hire_url = "job_seekers_views:update_job_seeker_step_3_for_hire" - next_apply_url = "apply:application_jobs" - next_hire_url = "job_seekers_views:check_job_seeker_info_for_hire" + previous_url = "job_seekers_views:update_job_seeker_step_3" def __init__(self): super().__init__() @@ -1031,14 +1056,17 @@ def post(self, request, *args, **kwargs): messages.error(request, " ".join(e.messages)) url = reverse( "job_seekers_views:update_job_seeker_step_1", - kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + kwargs={"session_uuid": self.job_seeker_session.name}, ) else: self.profile.save() - self.job_seeker_session.delete() url = self.get_next_url() + self.job_seeker_session.delete() return HttpResponseRedirect(url) + def get_next_url(self): + return self.job_seeker_session.get("config").get("from_url") + def get_context_data(self, **kwargs): return super().get_context_data(**kwargs) | {"profile": self.profile, "progress": "80"} diff --git a/tests/www/apply/__snapshots__/test_submit.ambr b/tests/www/apply/__snapshots__/test_submit.ambr index 96987aeb0a..d739cf49b6 100644 --- a/tests/www/apply/__snapshots__/test_submit.ambr +++ b/tests/www/apply/__snapshots__/test_submit.ambr @@ -939,9 +939,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 1] +# name: TestUpdateJobSeeker.test_as_authorized_prescriber_with_proxied_job_seeker[queries - start] dict({ - 'num_queries': 12, + 'num_queries': 11, 'queries': list([ dict({ 'origin': list([ @@ -1059,8 +1059,7 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -1094,45 +1093,8 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login", - "users_jobseekerprofile"."user_id", - "users_jobseekerprofile"."birthdate", - "users_jobseekerprofile"."birth_place_id", - "users_jobseekerprofile"."birth_country_id", - "users_jobseekerprofile"."nir", - "users_jobseekerprofile"."lack_of_nir_reason", - "users_jobseekerprofile"."pole_emploi_id", - "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", - "users_jobseekerprofile"."asp_uid", - "users_jobseekerprofile"."education_level", - "users_jobseekerprofile"."resourceless", - "users_jobseekerprofile"."rqth_employee", - "users_jobseekerprofile"."oeth_employee", - "users_jobseekerprofile"."pole_emploi_since", - "users_jobseekerprofile"."unemployed_since", - "users_jobseekerprofile"."has_rsa_allocation", - "users_jobseekerprofile"."rsa_allocation_since", - "users_jobseekerprofile"."ass_allocation_since", - "users_jobseekerprofile"."aah_allocation_since", - "users_jobseekerprofile"."are_allocation_since", - "users_jobseekerprofile"."activity_bonus_since", - "users_jobseekerprofile"."cape_freelance", - "users_jobseekerprofile"."cesa_freelance", - "users_jobseekerprofile"."actor_met_for_business_creation", - "users_jobseekerprofile"."mean_monthly_income_before_process", - "users_jobseekerprofile"."eiti_contributions", - "users_jobseekerprofile"."hexa_lane_number", - "users_jobseekerprofile"."hexa_std_extension", - "users_jobseekerprofile"."hexa_non_std_extension", - "users_jobseekerprofile"."hexa_lane_type", - "users_jobseekerprofile"."hexa_lane_name", - "users_jobseekerprofile"."hexa_additional_address", - "users_jobseekerprofile"."hexa_post_code", - "users_jobseekerprofile"."hexa_commune_id", - "users_jobseekerprofile"."pe_obfuscated_nir", - "users_jobseekerprofile"."pe_last_certification_attempt_at" + "users_user"."first_login" FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s AND "users_user"."public_id" = %s) LIMIT 21 @@ -1140,30 +1102,7 @@ }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep1View.setup[utils/session.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -1215,29 +1154,28 @@ }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', }), dict({ 'origin': list([ - 'CustomFieldRenderer.render[utils/custom_renderer.py]', - 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'BlockNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT "asp_country"."id", - "asp_country"."code", - "asp_country"."name", - "asp_country"."group", - "asp_country"."department" - FROM "asp_country" - ORDER BY "asp_country"."name" ASC - ''', + 'sql': 'RELEASE SAVEPOINT ""', }), dict({ 'origin': list([ @@ -1268,9 +1206,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 2] +# name: TestUpdateJobSeeker.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 1] dict({ - 'num_queries': 8, + 'num_queries': 13, 'queries': list([ dict({ 'origin': list([ @@ -1286,6 +1224,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -1388,74 +1340,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep2View.setup[utils/session.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -1507,34 +1394,8 @@ }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - ]), - }) -# --- -# name: TestUpdateJobSeeker.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 3] - dict({ - 'num_queries': 8, - 'queries': list([ - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -1568,15 +1429,202 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login" + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" FROM "users_user" - WHERE "users_user"."id" = %s + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) LIMIT 21 ''', }), dict({ 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 2] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' SELECT "prescribers_prescribermembership"."id", @@ -1634,8 +1682,62 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -1669,47 +1771,10 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login", - "users_jobseekerprofile"."user_id", - "users_jobseekerprofile"."birthdate", - "users_jobseekerprofile"."birth_place_id", - "users_jobseekerprofile"."birth_country_id", - "users_jobseekerprofile"."nir", - "users_jobseekerprofile"."lack_of_nir_reason", - "users_jobseekerprofile"."pole_emploi_id", - "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", - "users_jobseekerprofile"."asp_uid", - "users_jobseekerprofile"."education_level", - "users_jobseekerprofile"."resourceless", - "users_jobseekerprofile"."rqth_employee", - "users_jobseekerprofile"."oeth_employee", - "users_jobseekerprofile"."pole_emploi_since", - "users_jobseekerprofile"."unemployed_since", - "users_jobseekerprofile"."has_rsa_allocation", - "users_jobseekerprofile"."rsa_allocation_since", - "users_jobseekerprofile"."ass_allocation_since", - "users_jobseekerprofile"."aah_allocation_since", - "users_jobseekerprofile"."are_allocation_since", - "users_jobseekerprofile"."activity_bonus_since", - "users_jobseekerprofile"."cape_freelance", - "users_jobseekerprofile"."cesa_freelance", - "users_jobseekerprofile"."actor_met_for_business_creation", - "users_jobseekerprofile"."mean_monthly_income_before_process", - "users_jobseekerprofile"."eiti_contributions", - "users_jobseekerprofile"."hexa_lane_number", - "users_jobseekerprofile"."hexa_std_extension", - "users_jobseekerprofile"."hexa_non_std_extension", - "users_jobseekerprofile"."hexa_lane_type", - "users_jobseekerprofile"."hexa_lane_name", - "users_jobseekerprofile"."hexa_additional_address", - "users_jobseekerprofile"."hexa_post_code", - "users_jobseekerprofile"."hexa_commune_id", - "users_jobseekerprofile"."pe_obfuscated_nir", - "users_jobseekerprofile"."pe_last_certification_attempt_at" + "users_user"."first_login" FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) + AND "users_user"."id" = %s) LIMIT 21 ''', }), @@ -1718,8 +1783,8 @@ 'User.is_prescriber_with_authorized_org[users/models.py]', 'User.can_edit_personal_information[users/models.py]', 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" @@ -1735,10 +1800,150 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep3View.setup[utils/session.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 3] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -1788,6 +1993,107 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', @@ -1797,9 +2103,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 1] +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - start] dict({ - 'num_queries': 13, + 'num_queries': 11, 'queries': list([ dict({ 'origin': list([ @@ -1969,8 +2275,7 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -2004,45 +2309,8 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login", - "users_jobseekerprofile"."user_id", - "users_jobseekerprofile"."birthdate", - "users_jobseekerprofile"."birth_place_id", - "users_jobseekerprofile"."birth_country_id", - "users_jobseekerprofile"."nir", - "users_jobseekerprofile"."lack_of_nir_reason", - "users_jobseekerprofile"."pole_emploi_id", - "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", - "users_jobseekerprofile"."asp_uid", - "users_jobseekerprofile"."education_level", - "users_jobseekerprofile"."resourceless", - "users_jobseekerprofile"."rqth_employee", - "users_jobseekerprofile"."oeth_employee", - "users_jobseekerprofile"."pole_emploi_since", - "users_jobseekerprofile"."unemployed_since", - "users_jobseekerprofile"."has_rsa_allocation", - "users_jobseekerprofile"."rsa_allocation_since", - "users_jobseekerprofile"."ass_allocation_since", - "users_jobseekerprofile"."aah_allocation_since", - "users_jobseekerprofile"."are_allocation_since", - "users_jobseekerprofile"."activity_bonus_since", - "users_jobseekerprofile"."cape_freelance", - "users_jobseekerprofile"."cesa_freelance", - "users_jobseekerprofile"."actor_met_for_business_creation", - "users_jobseekerprofile"."mean_monthly_income_before_process", - "users_jobseekerprofile"."eiti_contributions", - "users_jobseekerprofile"."hexa_lane_number", - "users_jobseekerprofile"."hexa_std_extension", - "users_jobseekerprofile"."hexa_non_std_extension", - "users_jobseekerprofile"."hexa_lane_type", - "users_jobseekerprofile"."hexa_lane_name", - "users_jobseekerprofile"."hexa_additional_address", - "users_jobseekerprofile"."hexa_post_code", - "users_jobseekerprofile"."hexa_commune_id", - "users_jobseekerprofile"."pe_obfuscated_nir", - "users_jobseekerprofile"."pe_last_certification_attempt_at" + "users_user"."first_login" FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s AND "users_user"."public_id" = %s) LIMIT 21 @@ -2050,10 +2318,7 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep1View.setup[utils/session.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -2109,54 +2374,6 @@ ]), 'sql': 'RELEASE SAVEPOINT ""', }), - dict({ - 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 - ''', - }), - dict({ - 'origin': list([ - 'CustomFieldRenderer.render[utils/custom_renderer.py]', - 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'BlockNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - ]), - 'sql': ''' - SELECT "asp_country"."id", - "asp_country"."code", - "asp_country"."name", - "asp_country"."group", - "asp_country"."department" - FROM "asp_country" - ORDER BY "asp_country"."name" ASC - ''', - }), dict({ 'origin': list([ 'Atomic.__enter__[/django/db/transaction.py]', @@ -2186,9 +2403,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 2] +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 1] dict({ - 'num_queries': 9, + 'num_queries': 14, 'queries': list([ dict({ 'origin': list([ @@ -2204,6 +2421,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -2358,54 +2589,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep2View.setup[utils/session.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -2457,62 +2643,8 @@ }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 - ''', - }), - ]), - }) -# --- -# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 3] - dict({ - 'num_queries': 9, - 'queries': list([ - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -2546,22 +2678,217 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login" + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" FROM "users_user" - WHERE "users_user"."id" = %s + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) LIMIT 21 ''', }), dict({ 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 2] + dict({ + 'num_queries': 10, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", "companies_companymembership"."created_at", "companies_companymembership"."updated_at", "companies_companymembership"."company_id", @@ -2664,91 +2991,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login", - "users_jobseekerprofile"."user_id", - "users_jobseekerprofile"."birthdate", - "users_jobseekerprofile"."birth_place_id", - "users_jobseekerprofile"."birth_country_id", - "users_jobseekerprofile"."nir", - "users_jobseekerprofile"."lack_of_nir_reason", - "users_jobseekerprofile"."pole_emploi_id", - "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", - "users_jobseekerprofile"."asp_uid", - "users_jobseekerprofile"."education_level", - "users_jobseekerprofile"."resourceless", - "users_jobseekerprofile"."rqth_employee", - "users_jobseekerprofile"."oeth_employee", - "users_jobseekerprofile"."pole_emploi_since", - "users_jobseekerprofile"."unemployed_since", - "users_jobseekerprofile"."has_rsa_allocation", - "users_jobseekerprofile"."rsa_allocation_since", - "users_jobseekerprofile"."ass_allocation_since", - "users_jobseekerprofile"."aah_allocation_since", - "users_jobseekerprofile"."are_allocation_since", - "users_jobseekerprofile"."activity_bonus_since", - "users_jobseekerprofile"."cape_freelance", - "users_jobseekerprofile"."cesa_freelance", - "users_jobseekerprofile"."actor_met_for_business_creation", - "users_jobseekerprofile"."mean_monthly_income_before_process", - "users_jobseekerprofile"."eiti_contributions", - "users_jobseekerprofile"."hexa_lane_number", - "users_jobseekerprofile"."hexa_std_extension", - "users_jobseekerprofile"."hexa_non_std_extension", - "users_jobseekerprofile"."hexa_lane_type", - "users_jobseekerprofile"."hexa_lane_name", - "users_jobseekerprofile"."hexa_additional_address", - "users_jobseekerprofile"."hexa_post_code", - "users_jobseekerprofile"."hexa_commune_id", - "users_jobseekerprofile"."pe_obfuscated_nir", - "users_jobseekerprofile"."pe_last_certification_attempt_at" - FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep3View.setup[utils/session.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -2800,12 +3045,56 @@ }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - dict({ - 'origin': list([ + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ 'Company.has_admin[common_apps/organizations/models.py]', 'Company.convention_can_be_accessed_by[companies/models.py]', 'nav[utils/templatetags/nav.py]', @@ -2813,7 +3102,7 @@ 'IncludeNode[layout/base.html]', 'IfNode[layout/base.html]', 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', ]), 'sql': ''' SELECT %s AS "a" @@ -2835,9 +3124,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 1] +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 3] dict({ - 'num_queries': 12, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -2855,43 +3144,15 @@ }), dict({ 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', ]), 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE "users_user"."id" = %s + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) LIMIT 21 ''', }), @@ -2899,65 +3160,6 @@ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), - 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - ]), 'sql': ''' SELECT "users_user"."id", "users_user"."password", @@ -2990,76 +3192,36 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login", - "users_jobseekerprofile"."user_id", - "users_jobseekerprofile"."birthdate", - "users_jobseekerprofile"."birth_place_id", - "users_jobseekerprofile"."birth_country_id", - "users_jobseekerprofile"."nir", - "users_jobseekerprofile"."lack_of_nir_reason", - "users_jobseekerprofile"."pole_emploi_id", - "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", - "users_jobseekerprofile"."asp_uid", - "users_jobseekerprofile"."education_level", - "users_jobseekerprofile"."resourceless", - "users_jobseekerprofile"."rqth_employee", - "users_jobseekerprofile"."oeth_employee", - "users_jobseekerprofile"."pole_emploi_since", - "users_jobseekerprofile"."unemployed_since", - "users_jobseekerprofile"."has_rsa_allocation", - "users_jobseekerprofile"."rsa_allocation_since", - "users_jobseekerprofile"."ass_allocation_since", - "users_jobseekerprofile"."aah_allocation_since", - "users_jobseekerprofile"."are_allocation_since", - "users_jobseekerprofile"."activity_bonus_since", - "users_jobseekerprofile"."cape_freelance", - "users_jobseekerprofile"."cesa_freelance", - "users_jobseekerprofile"."actor_met_for_business_creation", - "users_jobseekerprofile"."mean_monthly_income_before_process", - "users_jobseekerprofile"."eiti_contributions", - "users_jobseekerprofile"."hexa_lane_number", - "users_jobseekerprofile"."hexa_std_extension", - "users_jobseekerprofile"."hexa_non_std_extension", - "users_jobseekerprofile"."hexa_lane_type", - "users_jobseekerprofile"."hexa_lane_name", - "users_jobseekerprofile"."hexa_additional_address", - "users_jobseekerprofile"."hexa_post_code", - "users_jobseekerprofile"."hexa_commune_id", - "users_jobseekerprofile"."pe_obfuscated_nir", - "users_jobseekerprofile"."pe_last_certification_attempt_at" + "users_user"."first_login" FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) + WHERE "users_user"."id" = %s LIMIT 21 ''', }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC ''', }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep1View.setup[utils/session.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -3099,74 +3261,228 @@ "companies_company"."rdv_solidarites_id", EXISTS (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', }), dict({ 'origin': list([ - 'CustomFieldRenderer.render[utils/custom_renderer.py]', - 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'BlockNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'Atomic.__enter__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT "asp_country"."id", - "asp_country"."code", - "asp_country"."name", - "asp_country"."group", - "asp_country"."department" - FROM "asp_country" - ORDER BY "asp_country"."name" ASC - ''', + 'sql': 'SAVEPOINT ""', }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), - 'sql': 'SAVEPOINT ""', + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', }), dict({ 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 ''', }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': 'RELEASE SAVEPOINT ""', }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), ]), }) # --- -# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 2] +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - start] dict({ - 'num_queries': 8, + 'num_queries': 11, 'queries': list([ dict({ 'origin': list([ @@ -3284,8 +3600,7 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -3328,30 +3643,7 @@ }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep2View.setup[utils/session.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -3401,24 +3693,83 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', ]), 'sql': 'RELEASE SAVEPOINT ""', }), - ]), - }) -# --- -# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 3] - dict({ - 'num_queries': 8, - 'queries': list([ dict({ 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), - 'sql': ''' + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 1] + dict({ + 'num_queries': 13, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" @@ -3530,8 +3881,62 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -3605,7 +4010,7 @@ FROM "users_user" LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) + AND "users_user"."id" = %s) LIMIT 21 ''', }), @@ -3614,8 +4019,8 @@ 'User.is_prescriber_with_authorized_org[users/models.py]', 'User.can_edit_personal_information[users/models.py]', 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" @@ -3631,71 +4036,62 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep3View.setup[utils/session.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', ]), 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" - FROM "companies_company" - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s ''', }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': 'RELEASE SAVEPOINT ""', }), ]), }) # --- -# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 1] +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 2] dict({ - 'num_queries': 13, + 'num_queries': 9, 'queries': list([ dict({ 'origin': list([ @@ -3711,6 +4107,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -3758,46 +4168,3844 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 3] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - start] + dict({ + 'num_queries': 11, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 1] + dict({ + 'num_queries': 14, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 2] + dict({ + 'num_queries': 10, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 3] + dict({ + 'num_queries': 10, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + ]), + }) +# --- +# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - start] + dict({ + 'num_queries': 11, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 1] + dict({ + 'num_queries': 13, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 2] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 3] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - start] + dict({ + 'num_queries': 11, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 1] + dict({ + 'num_queries': 14, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 2] + dict({ + 'num_queries': 10, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", "companies_company"."kind", "companies_company"."brand", "companies_company"."phone", @@ -3865,91 +8073,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login", - "users_jobseekerprofile"."user_id", - "users_jobseekerprofile"."birthdate", - "users_jobseekerprofile"."birth_place_id", - "users_jobseekerprofile"."birth_country_id", - "users_jobseekerprofile"."nir", - "users_jobseekerprofile"."lack_of_nir_reason", - "users_jobseekerprofile"."pole_emploi_id", - "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", - "users_jobseekerprofile"."asp_uid", - "users_jobseekerprofile"."education_level", - "users_jobseekerprofile"."resourceless", - "users_jobseekerprofile"."rqth_employee", - "users_jobseekerprofile"."oeth_employee", - "users_jobseekerprofile"."pole_emploi_since", - "users_jobseekerprofile"."unemployed_since", - "users_jobseekerprofile"."has_rsa_allocation", - "users_jobseekerprofile"."rsa_allocation_since", - "users_jobseekerprofile"."ass_allocation_since", - "users_jobseekerprofile"."aah_allocation_since", - "users_jobseekerprofile"."are_allocation_since", - "users_jobseekerprofile"."activity_bonus_since", - "users_jobseekerprofile"."cape_freelance", - "users_jobseekerprofile"."cesa_freelance", - "users_jobseekerprofile"."actor_met_for_business_creation", - "users_jobseekerprofile"."mean_monthly_income_before_process", - "users_jobseekerprofile"."eiti_contributions", - "users_jobseekerprofile"."hexa_lane_number", - "users_jobseekerprofile"."hexa_std_extension", - "users_jobseekerprofile"."hexa_non_std_extension", - "users_jobseekerprofile"."hexa_lane_type", - "users_jobseekerprofile"."hexa_lane_name", - "users_jobseekerprofile"."hexa_additional_address", - "users_jobseekerprofile"."hexa_post_code", - "users_jobseekerprofile"."hexa_commune_id", - "users_jobseekerprofile"."pe_obfuscated_nir", - "users_jobseekerprofile"."pe_last_certification_attempt_at" - FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep1View.setup[utils/session.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -3999,6 +8125,50 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', @@ -4014,7 +8184,7 @@ 'IncludeNode[layout/base.html]', 'IfNode[layout/base.html]', 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', ]), 'sql': ''' SELECT %s AS "a" @@ -4033,59 +8203,27 @@ LIMIT 1 ''', }), + ]), + }) +# --- +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 3] + dict({ + 'num_queries': 10, + 'queries': list([ dict({ 'origin': list([ - 'CustomFieldRenderer.render[utils/custom_renderer.py]', - 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'BlockNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - ]), - 'sql': ''' - SELECT "asp_country"."id", - "asp_country"."code", - "asp_country"."name", - "asp_country"."group", - "asp_country"."department" - FROM "asp_country" - ORDER BY "asp_country"."name" ASC - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', ]), 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - ]), - }) -# --- -# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 2] - dict({ - 'num_queries': 9, - 'queries': list([ dict({ 'origin': list([ 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', @@ -4248,60 +8386,15 @@ }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'Atomic.__enter__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', + 'sql': 'SAVEPOINT ""', }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep2View.setup[utils/session.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -4351,6 +8444,87 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', @@ -4366,7 +8540,7 @@ 'IncludeNode[layout/base.html]', 'IfNode[layout/base.html]', 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', ]), 'sql': ''' SELECT %s AS "a" @@ -4388,9 +8562,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 3] +# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - start] dict({ - 'num_queries': 9, + 'num_queries': 11, 'queries': list([ dict({ 'origin': list([ @@ -4453,103 +8627,51 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" - FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ @@ -4560,8 +8682,7 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -4595,45 +8716,8 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login", - "users_jobseekerprofile"."user_id", - "users_jobseekerprofile"."birthdate", - "users_jobseekerprofile"."birth_place_id", - "users_jobseekerprofile"."birth_country_id", - "users_jobseekerprofile"."nir", - "users_jobseekerprofile"."lack_of_nir_reason", - "users_jobseekerprofile"."pole_emploi_id", - "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", - "users_jobseekerprofile"."asp_uid", - "users_jobseekerprofile"."education_level", - "users_jobseekerprofile"."resourceless", - "users_jobseekerprofile"."rqth_employee", - "users_jobseekerprofile"."oeth_employee", - "users_jobseekerprofile"."pole_emploi_since", - "users_jobseekerprofile"."unemployed_since", - "users_jobseekerprofile"."has_rsa_allocation", - "users_jobseekerprofile"."rsa_allocation_since", - "users_jobseekerprofile"."ass_allocation_since", - "users_jobseekerprofile"."aah_allocation_since", - "users_jobseekerprofile"."are_allocation_since", - "users_jobseekerprofile"."activity_bonus_since", - "users_jobseekerprofile"."cape_freelance", - "users_jobseekerprofile"."cesa_freelance", - "users_jobseekerprofile"."actor_met_for_business_creation", - "users_jobseekerprofile"."mean_monthly_income_before_process", - "users_jobseekerprofile"."eiti_contributions", - "users_jobseekerprofile"."hexa_lane_number", - "users_jobseekerprofile"."hexa_std_extension", - "users_jobseekerprofile"."hexa_non_std_extension", - "users_jobseekerprofile"."hexa_lane_type", - "users_jobseekerprofile"."hexa_lane_name", - "users_jobseekerprofile"."hexa_additional_address", - "users_jobseekerprofile"."hexa_post_code", - "users_jobseekerprofile"."hexa_commune_id", - "users_jobseekerprofile"."pe_obfuscated_nir", - "users_jobseekerprofile"."pe_last_certification_attempt_at" + "users_user"."first_login" FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s AND "users_user"."public_id" = %s) LIMIT 21 @@ -4641,10 +8725,7 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep3View.setup[utils/session.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -4694,6 +8775,25 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', @@ -4702,38 +8802,36 @@ }), dict({ 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s ''', }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 1] +# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 1] dict({ - 'num_queries': 14, + 'num_queries': 13, 'queries': list([ dict({ 'origin': list([ @@ -4749,6 +8847,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -4796,25 +8908,64 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -4854,53 +9005,16 @@ "companies_company"."rdv_solidarites_id", EXISTS (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + AND "companies_company"."id" = %s) + LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), dict({ 'origin': list([ 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', @@ -4978,82 +9092,27 @@ FROM "users_user" LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) + AND "users_user"."id" = %s) LIMIT 21 ''', }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep1View.setup[utils/session.py]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" - FROM "companies_company" - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep1View.dispatch[www/apply/views/submit_views.py]', - ]), 'sql': ''' SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active")) - AND "users_user"."id" = %s) + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") LIMIT 1 ''', }), @@ -5063,34 +9122,6 @@ ]), 'sql': 'RELEASE SAVEPOINT ""', }), - dict({ - 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 - ''', - }), dict({ 'origin': list([ 'CustomFieldRenderer.render[utils/custom_renderer.py]', @@ -5140,9 +9171,9 @@ ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 2] +# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 2] dict({ - 'num_queries': 10, + 'num_queries': 9, 'queries': list([ dict({ 'origin': list([ @@ -5158,6 +9189,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -5205,25 +9250,64 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -5263,57 +9347,124 @@ "companies_company"."rdv_solidarites_id", EXISTS (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 ''', }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), - 'sql': 'SAVEPOINT ""', + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 3] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -5349,17 +9500,73 @@ "users_user"."address_filled_at", "users_user"."first_login" FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) + WHERE "users_user"."id" = %s LIMIT 21 ''', }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep2View.setup[utils/session.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -5411,64 +9618,117 @@ }), dict({ 'origin': list([ - 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep2View.dispatch[www/apply/views/submit_views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' - SELECT %s AS "a" + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active")) + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s AND "users_user"."id" = %s) - LIMIT 1 + LIMIT 21 ''', }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") LIMIT 1 ''', }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 3] +# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - start] dict({ - 'num_queries': 10, + 'num_queries': 11, 'queries': list([ dict({ 'origin': list([ @@ -5638,8 +9898,7 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -5673,45 +9932,8 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login", - "users_jobseekerprofile"."user_id", - "users_jobseekerprofile"."birthdate", - "users_jobseekerprofile"."birth_place_id", - "users_jobseekerprofile"."birth_country_id", - "users_jobseekerprofile"."nir", - "users_jobseekerprofile"."lack_of_nir_reason", - "users_jobseekerprofile"."pole_emploi_id", - "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", - "users_jobseekerprofile"."asp_uid", - "users_jobseekerprofile"."education_level", - "users_jobseekerprofile"."resourceless", - "users_jobseekerprofile"."rqth_employee", - "users_jobseekerprofile"."oeth_employee", - "users_jobseekerprofile"."pole_emploi_since", - "users_jobseekerprofile"."unemployed_since", - "users_jobseekerprofile"."has_rsa_allocation", - "users_jobseekerprofile"."rsa_allocation_since", - "users_jobseekerprofile"."ass_allocation_since", - "users_jobseekerprofile"."aah_allocation_since", - "users_jobseekerprofile"."are_allocation_since", - "users_jobseekerprofile"."activity_bonus_since", - "users_jobseekerprofile"."cape_freelance", - "users_jobseekerprofile"."cesa_freelance", - "users_jobseekerprofile"."actor_met_for_business_creation", - "users_jobseekerprofile"."mean_monthly_income_before_process", - "users_jobseekerprofile"."eiti_contributions", - "users_jobseekerprofile"."hexa_lane_number", - "users_jobseekerprofile"."hexa_std_extension", - "users_jobseekerprofile"."hexa_non_std_extension", - "users_jobseekerprofile"."hexa_lane_type", - "users_jobseekerprofile"."hexa_lane_name", - "users_jobseekerprofile"."hexa_additional_address", - "users_jobseekerprofile"."hexa_post_code", - "users_jobseekerprofile"."hexa_commune_id", - "users_jobseekerprofile"."pe_obfuscated_nir", - "users_jobseekerprofile"."pe_last_certification_attempt_at" + "users_user"."first_login" FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s AND "users_user"."public_id" = %s) LIMIT 21 @@ -5719,10 +9941,7 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep3View.setup[utils/session.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -5774,58 +9993,36 @@ }), dict({ 'origin': list([ - 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep3View.dispatch[www/apply/views/submit_views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 - ''', + 'sql': 'RELEASE SAVEPOINT ""', }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + 'sql': 'SAVEPOINT ""', }), dict({ 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s ''', }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), ]), }) # --- @@ -5847,6 +10044,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -5999,6 +10210,60 @@ ]), 'sql': 'SAVEPOINT ""', }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', @@ -6070,89 +10335,14 @@ "users_jobseekerprofile"."hexa_lane_name", "users_jobseekerprofile"."hexa_additional_address", "users_jobseekerprofile"."hexa_post_code", - "users_jobseekerprofile"."hexa_commune_id", - "users_jobseekerprofile"."pe_obfuscated_nir", - "users_jobseekerprofile"."pe_last_certification_attempt_at" - FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep1View.setup[utils/session.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" - FROM "companies_company" - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep1View.dispatch[www/apply/views/submit_views.py]', - ]), - 'sql': ''' - SELECT %s AS "a" + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active")) + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s AND "users_user"."id" = %s) - LIMIT 1 + LIMIT 21 ''', }), dict({ @@ -6256,6 +10446,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -6412,51 +10616,6 @@ 'origin': list([ 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep2View.setup[utils/session.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' @@ -6509,22 +10668,46 @@ }), dict({ 'origin': list([ - 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep2View.dispatch[www/apply/views/submit_views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' - SELECT %s AS "a" + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active")) + WHERE ("users_user"."kind" = %s AND "users_user"."id" = %s) - LIMIT 1 + LIMIT 21 ''', }), dict({ @@ -6582,6 +10765,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -6734,6 +10931,60 @@ ]), 'sql': 'SAVEPOINT ""', }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', @@ -6811,83 +11062,8 @@ FROM "users_user" LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', - 'UpdateJobSeekerStep3View.setup[utils/session.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" - FROM "companies_company" - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep3View.dispatch[www/apply/views/submit_views.py]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active")) AND "users_user"."id" = %s) - LIMIT 1 + LIMIT 21 ''', }), dict({ diff --git a/tests/www/apply/test_submit.py b/tests/www/apply/test_submit.py index fb3f8fecab..7601428482 100644 --- a/tests/www/apply/test_submit.py +++ b/tests/www/apply/test_submit.py @@ -261,15 +261,13 @@ def test_404_when_trying_to_update_a_prescriber(self, client): company = CompanyFactory(with_jobs=True, with_membership=True) prescriber = PrescriberFactory() client.force_login(company.members.first()) - for viewname in ( - "job_seekers_views:update_job_seeker_step_1_for_hire", - "job_seekers_views:update_job_seeker_step_2_for_hire", - "job_seekers_views:update_job_seeker_step_3_for_hire", - "job_seekers_views:update_job_seeker_step_end_for_hire", - ): - url = reverse(viewname, kwargs={"company_pk": company.pk, "job_seeker_public_id": prescriber.public_id}) - response = client.get(url) - assert response.status_code == 404 + params = { + "job_seeker": prescriber.public_id, + "company": company.pk, + } + url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + response = client.get(url) + assert response.status_code == 404 def test_404_when_trying_to_hire_a_prescriber(self, client): company = CompanyFactory(with_jobs=True, with_membership=True) @@ -3415,11 +3413,12 @@ def _check_last_checked_at(self, client, user, sees_warning, sees_verify_link): response = client.get(url) assert response.status_code == 200 - # Check the presence of the verify link - update_url = reverse( - "job_seekers_views:update_job_seeker_step_1", - kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, - ) + params = { + "job_seeker": self.job_seeker.public_id, + "company": self.company.pk, + "from_url": url, + } + update_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) link_check = assertContains if sees_verify_link else assertNotContains link_check(response, f'Vérifier le profil', html=True) # Check last_checked_at is shown @@ -3464,26 +3463,19 @@ def setup_method(self, settings, mocker): jobseeker_profile__birthdate=datetime.date(1978, 12, 20), title="M", ) - self.step_1_url = reverse( - self.STEP_1_VIEW_NAME, - kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, - ) - self.step_2_url = reverse( - self.STEP_2_VIEW_NAME, - kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, - ) - self.step_3_url = reverse( - self.STEP_3_VIEW_NAME, - kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, - ) - self.step_end_url = reverse( - self.STEP_END_VIEW_NAME, + from_url = reverse( + self.FINAL_REDIRECT_VIEW_NAME, kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, ) + self.config = { + "apply": {"company_pk": self.company.pk}, + "config": {"from_url": from_url}, + "job_seeker_pk": self.job_seeker.pk, + } + [self.city] = create_test_cities(["67"], num_per_department=1) self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT = "Informations modifiables par le candidat uniquement" - self.job_seeker_session_key = f"job_seeker-{self.job_seeker.public_id}" settings.API_BAN_BASE_URL = "http://ban-api" mocker.patch( @@ -3491,28 +3483,46 @@ def setup_method(self, settings, mocker): side_effect=mock_get_first_geocoding_data, ) + params = { + "job_seeker": self.job_seeker.public_id, + "company": self.company.pk, + "from_url": from_url, + } + self.start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + + def get_job_seeker_session_key(self, client): + [job_seeker_session_key] = [ + k for k in client.session.keys() if k not in KNOWN_SESSION_KEYS and not k.startswith("job_application") + ] or [None] + return job_seeker_session_key + + def get_step_url(self, step, client): + viewname = f"job_seekers_views:update_job_seeker_step_{step}" + return reverse(viewname, kwargs={"session_uuid": self.get_job_seeker_session_key(client)}) + def _check_nothing_permitted(self, client, user): client.force_login(user) - for url in [ - self.step_1_url, - self.step_2_url, - self.step_3_url, - self.step_end_url, - ]: - response = client.get(url) - assert response.status_code == 403 + + response = client.get(self.start_url) + assert response.status_code == 403 def _check_that_last_step_doesnt_crash_with_direct_access(self, client, user): client.force_login(user) - client.get(self.step_1_url) # Setup job_seeker_session - client.get(self.step_end_url) # Use partial job_seeker_session + client.get(self.start_url) # Setup job_seeker_session + client.get(self.get_step_url("end", client)) # Use partial job_seeker_session def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=None): client.force_login(user) + # START + with assertSnapshotQueries(snapshot(name="queries - start")): + response = client.get(self.start_url) + assert client.session[self.get_job_seeker_session_key(client)] == self.config + assertRedirects(response, self.get_step_url("1", client)) + # STEP 1 with assertSnapshotQueries(snapshot(name="queries - step 1")): - response = client.get(self.step_1_url) + response = client.get(self.get_step_url("1", client)) assertContains(response, self.job_seeker.first_name) assertNotContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) @@ -3529,8 +3539,7 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No "lack_of_nir": False, "lack_of_nir_reason": "", } - response = client.post(self.step_1_url, data=post_data) - assert response.status_code == 200 + response = client.post(self.get_step_url("1", client), data=post_data) assertContains(response, JobSeekerProfile.ERROR_JOBSEEKER_INCONSISTENT_NIR_TITLE % "") post_data = { @@ -3541,8 +3550,7 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No "lack_of_nir": False, "lack_of_nir_reason": "", } - response = client.post(self.step_1_url, data=post_data) - assert response.status_code == 200 + response = client.post(self.get_step_url("1", client), data=post_data) assertContains(response, JobSeekerProfile.ERROR_JOBSEEKER_INCONSISTENT_NIR_BIRTHDATE % "") # Resume to valid data and proceed with "normal" flow. @@ -3561,8 +3569,8 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No } if extra_post_data_1 is not None: post_data.update(extra_post_data_1) - response = client.post(self.step_1_url, data=post_data) - assertRedirects(response, self.step_2_url, fetch_redirect_response=False) + response = client.post(self.get_step_url("1", client), data=post_data) + assertRedirects(response, self.get_step_url("2", client), fetch_redirect_response=False) # Data is stored in the session but user is untouched # (nir value is retrieved from the job_seeker and stored in the session) @@ -3580,19 +3588,19 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No "nir": nir or self.job_seeker.jobseeker_profile.nir, "lack_of_nir_reason": lack_of_nir_reason, }, - } - assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + } | self.config + assert client.session[self.get_job_seeker_session_key(client)] == expected_job_seeker_session self.job_seeker.refresh_from_db() assert self.job_seeker.first_name != NEW_FIRST_NAME # If you go back to step 1, new data is shown - response = client.get(self.step_1_url) + response = client.get(self.get_step_url("1", client)) assertContains(response, PROCESS_TITLE, html=True) assertContains(response, NEW_FIRST_NAME) # STEP 2 with assertSnapshotQueries(snapshot(name="queries - step 2")): - response = client.get(self.step_2_url) + response = client.get(self.get_step_url("2", client)) assertContains(response, PROCESS_TITLE, html=True) assertContains(response, self.job_seeker.phone) assertNotContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) @@ -3612,30 +3620,30 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No "fill_mode": "ban_api", } - response = client.post(self.step_2_url, data=post_data) - assertRedirects(response, self.step_3_url, fetch_redirect_response=False) + response = client.post(self.get_step_url("2", client), data=post_data) + assertRedirects(response, self.get_step_url("3", client), fetch_redirect_response=False) # Data is stored in the session but user is untouched expected_job_seeker_session["user"] |= post_data | {"address_line_2": "", "address_for_autocomplete": None} - assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + assert client.session[self.get_job_seeker_session_key(client)] == expected_job_seeker_session self.job_seeker.refresh_from_db() assert self.job_seeker.address_line_1 != NEW_ADDRESS_LINE # If you go back to step 2, new data is shown - response = client.get(self.step_2_url) + response = client.get(self.get_step_url("2", client)) assertContains(response, NEW_ADDRESS_LINE) # STEP 3 with assertSnapshotQueries(snapshot(name="queries - step 3")): - response = client.get(self.step_3_url) + response = client.get(self.get_step_url("3", client)) assertContains(response, PROCESS_TITLE, html=True) assertContains(response, "Niveau de formation") post_data = { "education_level": EducationLevel.BAC_LEVEL.value, } - response = client.post(self.step_3_url, data=post_data) - assertRedirects(response, self.step_end_url, fetch_redirect_response=False) + response = client.post(self.get_step_url("3", client), data=post_data) + assertRedirects(response, self.get_step_url("end", client), fetch_redirect_response=False) # Data is stored in the session but user & profiles are untouched expected_job_seeker_session["profile"] |= post_data | { @@ -3657,15 +3665,15 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No "aah_allocation": False, "aah_allocation_since": "", } - assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + assert client.session[self.get_job_seeker_session_key(client)] == expected_job_seeker_session self.job_seeker.refresh_from_db() # If you go back to step 3, new data is shown - response = client.get(self.step_3_url) + response = client.get(self.get_step_url("3", client)) assertContains(response, '', html=True) # Step END - response = client.get(self.step_end_url) + response = client.get(self.get_step_url("end", client)) assertContains(response, PROCESS_TITLE, html=True) assertContains(response, NEW_FIRST_NAME.title()) # User.get_full_name() changes the firstname display assertContains(response, NEW_ADDRESS_LINE) @@ -3674,7 +3682,7 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No previous_last_checked_at = self.job_seeker.last_checked_at - response = client.post(self.step_end_url) + response = client.post(self.get_step_url("end", client)) assertRedirects( response, reverse( @@ -3683,7 +3691,7 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No ), fetch_redirect_response=False, ) - assert client.session.get(self.job_seeker_session_key) is None + assert client.session.get(self.get_job_seeker_session_key(client)) is None self.job_seeker.refresh_from_db() assert self.job_seeker.has_jobseeker_profile is True @@ -3697,38 +3705,42 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No def _check_only_administrative_allowed(self, client, user): client.force_login(user) + # START + response = client.get(self.start_url) + expected_job_seeker_session = self.config + assert client.session[self.get_job_seeker_session_key(client)] == expected_job_seeker_session + assertRedirects(response, self.get_step_url("1", client)) + # STEP 1 - response = client.get(self.step_1_url) + response = client.get(self.get_step_url("1", client)) assertContains(response, self.job_seeker.first_name) assertContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) - response = client.post(self.step_1_url) - assertRedirects(response, self.step_2_url, fetch_redirect_response=False) - - # Session is created - expected_job_seeker_session = {"user": {}} - assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + response = client.post(self.get_step_url("1", client)) + assertRedirects(response, self.get_step_url("2", client), fetch_redirect_response=False) + expected_job_seeker_session |= {"user": {}} + assert client.session[self.get_job_seeker_session_key(client)] == expected_job_seeker_session # STEP 2 - response = client.get(self.step_2_url) + response = client.get(self.get_step_url("2", client)) assertContains(response, self.job_seeker.phone) assertContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) - response = client.post(self.step_2_url) - assertRedirects(response, self.step_3_url, fetch_redirect_response=False) + response = client.post(self.get_step_url("2", client)) + assertRedirects(response, self.get_step_url("3", client), fetch_redirect_response=False) # Data is stored in the session but user is untouched - assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + assert client.session[self.get_job_seeker_session_key(client)] == expected_job_seeker_session # STEP 3 - response = client.get(self.step_3_url) + response = client.get(self.get_step_url("3", client)) assertContains(response, "Niveau de formation") post_data = { "education_level": EducationLevel.BAC_LEVEL.value, } - response = client.post(self.step_3_url, data=post_data) - assertRedirects(response, self.step_end_url, fetch_redirect_response=False) + response = client.post(self.get_step_url("3", client), data=post_data) + assertRedirects(response, self.get_step_url("end", client), fetch_redirect_response=False) # Data is stored in the session but user & profiles are untouched expected_job_seeker_session["profile"] = post_data | { @@ -3750,20 +3762,20 @@ def _check_only_administrative_allowed(self, client, user): "aah_allocation": False, "aah_allocation_since": "", } - assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + assert client.session[self.get_job_seeker_session_key(client)] == expected_job_seeker_session self.job_seeker.refresh_from_db() # If you go back to step 3, new data is shown - response = client.get(self.step_3_url) + response = client.get(self.get_step_url("3", client)) assertContains(response, '', html=True) # Step END - response = client.get(self.step_end_url) + response = client.get(self.get_step_url("end", client)) assertContains(response, "Formation de niveau BAC") previous_last_checked_at = self.job_seeker.last_checked_at - response = client.post(self.step_end_url) + response = client.post(self.get_step_url("end", client)) assertRedirects( response, reverse( @@ -3772,7 +3784,7 @@ def _check_only_administrative_allowed(self, client, user): ), fetch_redirect_response=False, ) - assert client.session.get(self.job_seeker_session_key) is None + assert client.session.get(self.get_job_seeker_session_key(client)) is None self.job_seeker.refresh_from_db() assert self.job_seeker.has_jobseeker_profile is True @@ -3781,27 +3793,12 @@ def _check_only_administrative_allowed(self, client, user): class TestUpdateJobSeeker(UpdateJobSeekerTestMixin): - STEP_1_VIEW_NAME = "job_seekers_views:update_job_seeker_step_1" - STEP_2_VIEW_NAME = "job_seekers_views:update_job_seeker_step_2" - STEP_3_VIEW_NAME = "job_seekers_views:update_job_seeker_step_3" - STEP_END_VIEW_NAME = "job_seekers_views:update_job_seeker_step_end" + TUNNEL = "apply" FINAL_REDIRECT_VIEW_NAME = "apply:application_jobs" - def test_anonymous_step_1(self, client): - response = client.get(self.step_1_url) - assertRedirects(response, reverse("account_login") + f"?next={self.step_1_url}") - - def test_anonymous_step_2(self, client): - response = client.get(self.step_2_url) - assertRedirects(response, reverse("account_login") + f"?next={self.step_2_url}") - - def test_anonymous_step_3(self, client): - response = client.get(self.step_3_url) - assertRedirects(response, reverse("account_login") + f"?next={self.step_3_url}") - - def test_anonymous_step_end(self, client): - response = client.get(self.step_end_url) - assertRedirects(response, reverse("account_login") + f"?next={self.step_end_url}") + def test_anonymous_start(self, client): + response = client.get(self.start_url) + assertRedirects(response, add_url_params(reverse("account_login"), {"next": self.start_url})) def test_as_job_seeker(self, client): self._check_nothing_permitted(client, self.job_seeker) @@ -3889,15 +3886,18 @@ def test_as_company_with_non_proxied_job_seeker(self, client): self.job_seeker.save(update_fields=["last_login"]) self._check_only_administrative_allowed(client, self.company.members.first()) - def test_without_job_seeker_session(self, client): + def test_with_invalid_job_seeker_session(self, client): client.force_login(self.company.members.first()) + invalid_session_name = uuid.uuid4() + kwargs = {"session_uuid": invalid_session_name} for url in [ - self.step_2_url, - self.step_3_url, - self.step_end_url, + reverse("job_seekers_views:update_job_seeker_step_1", kwargs=kwargs), + reverse("job_seekers_views:update_job_seeker_step_2", kwargs=kwargs), + reverse("job_seekers_views:update_job_seeker_step_3", kwargs=kwargs), + reverse("job_seekers_views:update_job_seeker_step_end", kwargs=kwargs), ]: response = client.get(url) - assert response.status_code == 403 + assert response.status_code == 404 def test_with_job_seeker_without_nir(self, client, snapshot): # Make sure the job seeker does not manage its own account (and has no nir) @@ -3936,27 +3936,12 @@ def test_as_company_that_last_step_doesnt_crash_with_direct_access(self, client) class TestUpdateJobSeekerForHire(UpdateJobSeekerTestMixin): - STEP_1_VIEW_NAME = "job_seekers_views:update_job_seeker_step_1_for_hire" - STEP_2_VIEW_NAME = "job_seekers_views:update_job_seeker_step_2_for_hire" - STEP_3_VIEW_NAME = "job_seekers_views:update_job_seeker_step_3_for_hire" - STEP_END_VIEW_NAME = "job_seekers_views:update_job_seeker_step_end_for_hire" + TUNNEL = "hire" FINAL_REDIRECT_VIEW_NAME = "job_seekers_views:check_job_seeker_info_for_hire" - def test_anonymous_step_1(self, client): - response = client.get(self.step_1_url) - assertRedirects(response, reverse("account_login") + f"?next={self.step_1_url}") - - def test_anonymous_step_2(self, client): - response = client.get(self.step_2_url) - assertRedirects(response, reverse("account_login") + f"?next={self.step_2_url}") - - def test_anonymous_step_3(self, client): - response = client.get(self.step_3_url) - assertRedirects(response, reverse("account_login") + f"?next={self.step_3_url}") - - def test_anonymous_step_end(self, client): - response = client.get(self.step_end_url) - assertRedirects(response, reverse("account_login") + f"?next={self.step_end_url}") + def test_anonymous_start(self, client): + response = client.get(self.start_url) + assertRedirects(response, add_url_params(reverse("account_login"), {"next": self.start_url})) def test_as_job_seeker(self, client): self._check_nothing_permitted(client, self.job_seeker) @@ -3965,12 +3950,24 @@ def test_as_unauthorized_prescriber(self, client): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() self._check_nothing_permitted(client, prescriber) - def test_as_unauthorized_prescriber_that_created_proxied_job_seeker(self, client): + def test_as_unauthorized_prescriber_that_created_proxied_job_seeker(self, client, snapshot): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() self.job_seeker.created_by = prescriber self.job_seeker.last_login = None self.job_seeker.save(update_fields=["created_by", "last_login"]) - self._check_nothing_permitted(client, prescriber) + + geispolsheim = create_city_geispolsheim() + birthdate = self.job_seeker.jobseeker_profile.birthdate + + self._check_everything_allowed( + client, + snapshot, + prescriber, + extra_post_data_1={ + "birth_place": Commune.objects.by_insee_code_and_period(geispolsheim.code_insee, birthdate).id, + "birth_country": Country.france_id, + }, + ) def test_as_unauthorized_prescriber_that_created_the_non_proxied_job_seeker(self, client): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() @@ -3980,20 +3977,32 @@ def test_as_unauthorized_prescriber_that_created_the_non_proxied_job_seeker(self self.job_seeker.save(update_fields=["created_by", "last_login"]) self._check_nothing_permitted(client, prescriber) - def test_as_authorized_prescriber_with_proxied_job_seeker(self, client): + def test_as_authorized_prescriber_with_proxied_job_seeker(self, client, snapshot): # Make sure the job seeker does not manage its own account self.job_seeker.created_by = PrescriberFactory() self.job_seeker.last_login = None self.job_seeker.save(update_fields=["created_by", "last_login"]) authorized_prescriber = PrescriberOrganizationWithMembershipFactory(authorized=True).members.first() - self._check_nothing_permitted(client, authorized_prescriber) + + geispolsheim = create_city_geispolsheim() + birthdate = self.job_seeker.jobseeker_profile.birthdate + + self._check_everything_allowed( + client, + snapshot, + authorized_prescriber, + extra_post_data_1={ + "birth_place": Commune.objects.by_insee_code_and_period(geispolsheim.code_insee, birthdate).id, + "birth_country": Country.france_id, + }, + ) def test_as_authorized_prescriber_with_non_proxied_job_seeker(self, client): # Make sure the job seeker does manage its own account self.job_seeker.last_login = timezone.now() - relativedelta(months=1) self.job_seeker.save(update_fields=["last_login"]) authorized_prescriber = PrescriberOrganizationWithMembershipFactory(authorized=True).members.first() - self._check_nothing_permitted(client, authorized_prescriber) + self._check_only_administrative_allowed(client, authorized_prescriber) def test_as_company_with_proxied_job_seeker(self, client, snapshot): # Make sure the job seeker does not manage its own account @@ -4020,15 +4029,18 @@ def test_as_company_with_non_proxied_job_seeker(self, client): self.job_seeker.save(update_fields=["last_login"]) self._check_only_administrative_allowed(client, self.company.members.first()) - def test_without_job_seeker_session(self, client): + def test_with_invalid_job_seeker_session(self, client): client.force_login(self.company.members.first()) + invalid_session_name = uuid.uuid4() + kwargs = {"session_uuid": invalid_session_name} for url in [ - self.step_2_url, - self.step_3_url, - self.step_end_url, + reverse("job_seekers_views:update_job_seeker_step_1", kwargs=kwargs), + reverse("job_seekers_views:update_job_seeker_step_2", kwargs=kwargs), + reverse("job_seekers_views:update_job_seeker_step_3", kwargs=kwargs), + reverse("job_seekers_views:update_job_seeker_step_end", kwargs=kwargs), ]: response = client.get(url) - assert response.status_code == 403 + assert response.status_code == 404 def test_with_job_seeker_without_nir(self, client, snapshot): # Make sure the job seeker does not manage its own account (and has no nir) @@ -4080,20 +4092,23 @@ def test_job_seeker_with_profile_has_check_boxes_ticked_in_step3(self, client): ) apply_session.save() - # STEP 1 to setup jobseeker session - response = client.get( - reverse( - "job_seekers_views:update_job_seeker_step_1", - kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, - ) - ) - assert response.status_code == 200 + # START to setup jobseeker session + params = { + "job_seeker": job_seeker.public_id, + "company": company.pk, + } + url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + response = client.get(url) + assert response.status_code == 302 # Go straight to STEP 3 + [job_seeker_session_name] = [ + k for k in client.session.keys() if k not in KNOWN_SESSION_KEYS and not k.startswith("job_application") + ] response = client.get( reverse( "job_seekers_views:update_job_seeker_step_3", - kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, + kwargs={"session_uuid": job_seeker_session_name}, ) ) assertContains( @@ -4857,12 +4872,11 @@ def test_company(self, client): jobseeker_profile__lack_of_nir_reason=LackOfNIRReason.TEMPORARY_NUMBER, ) client.force_login(company.members.first()) - response = client.get( - reverse( - "job_seekers_views:check_job_seeker_info_for_hire", - kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, - ) + url_check_infos = reverse( + "job_seekers_views:check_job_seeker_info_for_hire", + kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, ) + response = client.get(url_check_infos) assertContains( response, '

Informations personnelles de Son Prénom Son Nom De Famille

', @@ -4870,13 +4884,16 @@ def test_company(self, client): ) assertTemplateNotUsed(response, "approvals/includes/box.html") assertContains(response, "Éligibilité IAE à valider") - assertContains( - response, - reverse( - "job_seekers_views:update_job_seeker_step_1_for_hire", - kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, - ), - ) + params = { + "job_seeker": job_seeker.public_id, + "company": company.pk, + "from_url": url_check_infos, + } + url_update = f""" + Mettre à jour + """ + assertContains(response, url_update, html=True) assertContains( response, reverse( @@ -4900,25 +4917,27 @@ def test_geiq(self, client): jobseeker_profile__lack_of_nir_reason=LackOfNIRReason.TEMPORARY_NUMBER, ) client.force_login(company.members.first()) - response = client.get( - reverse( - "job_seekers_views:check_job_seeker_info_for_hire", - kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, - ) + url_check_infos = reverse( + "job_seekers_views:check_job_seeker_info_for_hire", + kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, ) + response = client.get(url_check_infos) assertContains( response, '

Informations personnelles de Son Prénom Son Nom De Famille

', html=True, ) assertTemplateNotUsed(response, "approvals/includes/box.html") - assertContains( - response, - reverse( - "job_seekers_views:update_job_seeker_step_1_for_hire", - kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, - ), - ) + params = { + "job_seeker": job_seeker.public_id, + "company": company.pk, + "from_url": url_check_infos, + } + url_update = f""" + Mettre à jour + """ + assertContains(response, url_update, html=True) assertContains( response, reverse( diff --git a/tests/www/job_seekers_views/test_create_or_update.py b/tests/www/job_seekers_views/test_create_or_update.py index 7b1f631b67..35f390ebfe 100644 --- a/tests/www/job_seekers_views/test_create_or_update.py +++ b/tests/www/job_seekers_views/test_create_or_update.py @@ -1,4 +1,5 @@ import datetime +import uuid import pytest from django.urls import reverse @@ -6,10 +7,9 @@ from itou.asp.models import Commune, Country from itou.users.enums import Title +from itou.utils.urls import add_url_params from tests.companies.factories import CompanyFactory -from tests.users.factories import ( - JobSeekerFactory, -) +from tests.users.factories import JobSeekerFactory from tests.utils.test import KNOWN_SESSION_KEYS @@ -190,6 +190,109 @@ def test_birth_country_france_and_no_birthplace(self, client): ) +class TestUpdateJobSeekerStart: + def test_update_start_with_valid_parameters(self, client): + job_seeker = JobSeekerFactory() + company = CompanyFactory(with_membership=True) + user = company.members.get() + client.force_login(user) + + from_url = reverse( + "apply:application_jobs", kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id} + ) + params = {"job_seeker": job_seeker.public_id, "company": company.pk, "from_url": from_url} + start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + + response = client.get(start_url) + [job_seeker_session_name] = [k for k in client.session.keys() if k not in KNOWN_SESSION_KEYS] + step_1_url = reverse( + "job_seekers_views:update_job_seeker_step_1", + kwargs={"session_uuid": job_seeker_session_name}, + ) + + assertRedirects(response, step_1_url) + assert client.session[job_seeker_session_name].get("config").get("from_url") == from_url + response = client.get(step_1_url) + assertContains( + response, + f""" + + + Annuler + + """, + html=True, + ) + + def test_update_start_with_invalid_parameters(self, client): + job_seeker = JobSeekerFactory() + company = CompanyFactory(with_membership=True) + user = company.members.get() + client.force_login(user) + + # Invalid uuid + params = {"job_seeker": "invalid_uuid", "company": company.pk} + start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + response = client.get(start_url) + assert response.status_code == 404 + + # Valid UUID but no job seeker associated to it + params = { + "job_seeker": uuid.uuid4(), + "company": company.pk, + } + start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + response = client.get(start_url) + assert response.status_code == 404 + + # No company parameter + params = { + "job_seeker": job_seeker.public_id, + } + start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + response = client.get(start_url) + assert response.status_code == 404 + + # Invalid company parameter + params = { + "job_seeker": job_seeker.public_id, + "company": "stringAndNotNumber", + } + start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + response = client.get(start_url) + assert response.status_code == 404 + + # No from_url parameter + params = { + "job_seeker": job_seeker.public_id, + "company": company.pk, + } + start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + response = client.get(start_url) + + [job_seeker_session_name] = [k for k in client.session.keys() if k not in KNOWN_SESSION_KEYS] + step_1_url = reverse( + "job_seekers_views:update_job_seeker_step_1", + kwargs={"session_uuid": job_seeker_session_name}, + ) + assert client.session[job_seeker_session_name].get("config").get("from_url") == reverse("dashboard:index") + response = client.get(step_1_url) + assertContains( + response, + f""" + + + Annuler + + """, + html=True, + ) + + class TestUpdateJobSeekerStep1: @pytest.mark.parametrize( "born_in_france", [pytest.param(True, id="born_in_france"), pytest.param(False, id="born_outside_france")] @@ -200,11 +303,20 @@ def test_create_step_1(self, born_in_france, client): job_seeker = JobSeekerFactory(created_by=user, title=Title.M, jobseeker_profile__nir="111116411111144") client.force_login(user) + # Init session + params = { + "job_seeker": job_seeker.public_id, + "company": company.pk, + } + start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + client.get(start_url) + [job_seeker_session_name] = [k for k in client.session.keys() if k not in KNOWN_SESSION_KEYS] + birthdate = datetime.date(1911, 11, 1) response = client.post( reverse( "job_seekers_views:update_job_seeker_step_1", - kwargs={"job_seeker_public_id": job_seeker.public_id, "company_pk": company.pk}, + kwargs={"session_uuid": job_seeker_session_name}, ), { "title": Title.M, @@ -225,7 +337,7 @@ def test_create_step_1(self, born_in_france, client): response, reverse( "job_seekers_views:update_job_seeker_step_2", - kwargs={"job_seeker_public_id": job_seeker.public_id, "company_pk": company.pk}, + kwargs={"session_uuid": job_seeker_session_name}, ), ) @@ -235,11 +347,20 @@ def test_birth_country_not_france_and_birthplace(self, client): job_seeker = JobSeekerFactory(created_by=user, title=Title.M, jobseeker_profile__nir="111116411111144") client.force_login(user) + # Init session + params = { + "job_seeker": job_seeker.public_id, + "company": company.pk, + } + start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + client.get(start_url) + [job_seeker_session_name] = [k for k in client.session.keys() if k not in KNOWN_SESSION_KEYS] + birthdate = datetime.date(1911, 11, 1) response = client.post( reverse( "job_seekers_views:update_job_seeker_step_1", - kwargs={"job_seeker_public_id": job_seeker.public_id, "company_pk": company.pk}, + kwargs={"session_uuid": job_seeker_session_name}, ), { "title": Title.M, @@ -266,10 +387,19 @@ def test_birth_country_france_and_no_birthplace(self, client): job_seeker = JobSeekerFactory(created_by=user, title=Title.M, jobseeker_profile__nir="111116411111144") client.force_login(user) + # Init session + params = { + "job_seeker": job_seeker.public_id, + "company": company.pk, + } + start_url = add_url_params(reverse("job_seekers_views:update_job_seeker_start"), params) + client.get(start_url) + [job_seeker_session_name] = [k for k in client.session.keys() if k not in KNOWN_SESSION_KEYS] + response = client.post( reverse( "job_seekers_views:update_job_seeker_step_1", - kwargs={"job_seeker_public_id": job_seeker.public_id, "company_pk": company.pk}, + kwargs={"session_uuid": job_seeker_session_name}, ), { "title": Title.M, From 8a6b01930245a25e46bcde7d0e4198a518aca82b Mon Sep 17 00:00:00 2001 From: Ewen Corre Date: Fri, 13 Dec 2024 10:12:18 +0100 Subject: [PATCH 3/5] job_seekers_views: deprecated Update views and URLs This commit allows two things: - prevent errors in production (b/c continuous integration) - keep track of the deprecated code that will have to be removed when we are assured that the old URLs aren't in use anymore --- itou/www/job_seekers_views/urls.py | 46 + itou/www/job_seekers_views/views.py | 298 +- .../www/apply/__snapshots__/test_submit.ambr | 9010 ++++++++++++----- tests/www/apply/test_submit.py | 547 +- 4 files changed, 7259 insertions(+), 2642 deletions(-) diff --git a/itou/www/job_seekers_views/urls.py b/itou/www/job_seekers_views/urls.py index 4c37869d32..30d6f506bb 100644 --- a/itou/www/job_seekers_views/urls.py +++ b/itou/www/job_seekers_views/urls.py @@ -72,6 +72,31 @@ name="create_job_seeker_step_end_for_hire", kwargs={"hire_process": True}, ), + # TODO(ewen): deprecated URLs + path( + "/hire/update//1", + views.DeprecatedUpdateJobSeekerStep1View.as_view(), + name="update_job_seeker_step_1_for_hire", + kwargs={"hire_process": True}, + ), + path( + "/hire/update//2", + views.DeprecatedUpdateJobSeekerStep2View.as_view(), + name="update_job_seeker_step_2_for_hire", + kwargs={"hire_process": True}, + ), + path( + "/hire/update//3", + views.DeprecatedUpdateJobSeekerStep3View.as_view(), + name="update_job_seeker_step_3_for_hire", + kwargs={"hire_process": True}, + ), + path( + "/hire/update//end", + views.DeprecatedUpdateJobSeekerStepEndView.as_view(), + name="update_job_seeker_step_end_for_hire", + kwargs={"hire_process": True}, + ), path( "/hire//check-infos", views.CheckJobSeekerInformationsForHire.as_view(), @@ -110,6 +135,27 @@ views.UpdateJobSeekerStepEndView.as_view(), name="update_job_seeker_step_end", ), + # TODO(ewen): deprecated URLs + path( + "/update//1", + views.DeprecatedUpdateJobSeekerStep1View.as_view(), + name="update_job_seeker_step_1", + ), + path( + "/update//2", + views.DeprecatedUpdateJobSeekerStep2View.as_view(), + name="update_job_seeker_step_2", + ), + path( + "/update//3", + views.DeprecatedUpdateJobSeekerStep3View.as_view(), + name="update_job_seeker_step_3", + ), + path( + "/update//end", + views.DeprecatedUpdateJobSeekerStepEndView.as_view(), + name="update_job_seeker_step_end", + ), # Common path( "/create//check-infos", diff --git a/itou/www/job_seekers_views/views.py b/itou/www/job_seekers_views/views.py index 630740d0f1..a116523d9c 100644 --- a/itou/www/job_seekers_views/views.py +++ b/itou/www/job_seekers_views/views.py @@ -26,9 +26,9 @@ from itou.utils.apis.exceptions import AddressLookupError from itou.utils.emails import redact_email_address from itou.utils.pagination import ItouPaginator -from itou.utils.session import SessionNamespace +from itou.utils.session import SessionNamespace, SessionNamespaceRequiredMixin from itou.utils.urls import get_safe_url -from itou.www.apply.views.submit_views import ApplicationBaseView +from itou.www.apply.views.submit_views import ApplicationBaseView, ApplyStepBaseView from .forms import ( CheckJobSeekerInfoForm, @@ -1071,6 +1071,300 @@ def get_context_data(self, **kwargs): return super().get_context_data(**kwargs) | {"profile": self.profile, "progress": "80"} +class DeprecatedUpdateJobSeekerBaseView(SessionNamespaceRequiredMixin, ApplyStepBaseView): + def __init__(self): + super().__init__() + self.job_seeker_session = None + + def get_job_seeker_queryset(self): + return User.objects.filter(kind=UserKind.JOB_SEEKER) + + def setup(self, request, *args, **kwargs): + self.job_seeker = get_object_or_404(self.get_job_seeker_queryset(), public_id=kwargs["job_seeker_public_id"]) + self.job_seeker_session = SessionNamespace(request.session, f"job_seeker-{self.job_seeker.public_id}") + if request.user.is_job_seeker or not request.user.can_view_personal_information(self.job_seeker): + # Since the link leading to this process isn't visible to those users, this should never happen + raise PermissionDenied("Votre utilisateur n'est pas autorisé à vérifier les informations de ce candidat") + super().setup(request, *args, **kwargs) + + def get_context_data(self, **kwargs): + return super().get_context_data(**kwargs) | { + "update_job_seeker": True, + "job_seeker": self.job_seeker, + "step_3_url": reverse( + "job_seekers_views:update_job_seeker_step_3_for_hire" + if self.hire_process + else "job_seekers_views:update_job_seeker_step_3", + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ), + "reset_url": reverse( + "apply:application_jobs", + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ), + "readonly_form": False, + } + + def _disable_form(self): + for field in self.form: + field.field.disabled = True + + def get_back_url(self): + view_name = self.previous_hire_url if self.hire_process else self.previous_apply_url + return reverse( + view_name, + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ) + + def get_next_url(self): + view_name = self.next_hire_url if self.hire_process else self.next_apply_url + return reverse( + view_name, + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ) + + +class DeprecatedUpdateJobSeekerStep1View(DeprecatedUpdateJobSeekerBaseView): + template_name = "job_seekers_views/create_or_update_job_seeker/step_1.html" + + previous_apply_url = "apply:application_jobs" + previous_hire_url = "job_seekers_views:check_job_seeker_info_for_hire" + next_apply_url = "job_seekers_views:update_job_seeker_step_2" + next_hire_url = "job_seekers_views:update_job_seeker_step_2_for_hire" + + def __init__(self): + super().__init__() + self.form = None + + def get_job_seeker_queryset(self): + return super().get_job_seeker_queryset().select_related("jobseeker_profile") + + def setup(self, request, *args, **kwargs): + super().setup(request, *args, **kwargs) + if not self.job_seeker_session.exists(): + self.job_seeker_session.init({"user": {}}) + session_nir = self.job_seeker_session.get("profile", {}).get("nir") + session_lack_of_nir_reason = self.job_seeker_session.get("profile", {}).get("lack_of_nir_reason") + + self.form = CreateOrUpdateJobSeekerStep1Form( + instance=self.job_seeker, + initial=self.job_seeker_session.get("user", {}) + | { + "nir": session_nir if session_nir is not None else self.job_seeker.jobseeker_profile.nir, + "lack_of_nir_reason": ( + session_lack_of_nir_reason + if session_lack_of_nir_reason is not None + else self.job_seeker.jobseeker_profile.lack_of_nir_reason + ), + }, + data=request.POST or None, + ) + if not self.request.user.can_edit_personal_information(self.job_seeker): + self._disable_form() + + def post(self, request, *args, **kwargs): + if not self.request.user.can_edit_personal_information(self.job_seeker): + return HttpResponseRedirect(self.get_next_url()) + if self.form.is_valid(): + self.job_seeker_session.set( + "user", + self.job_seeker_session.get("user", {}) | self.form.cleaned_data_without_profile_fields, + ) + self.job_seeker_session.set( + "profile", + self.job_seeker_session.get("profile", {}) | self.form.cleaned_data_from_profile_fields, + ) + return HttpResponseRedirect(self.get_next_url()) + + return self.render_to_response(self.get_context_data(**kwargs)) + + def get_context_data(self, **kwargs): + return super().get_context_data(**kwargs) | { + "confirmation_needed": False, + "form": self.form, + "matomo_form_name": "apply-update-job-seeker-identity", + "readonly_form": not self.request.user.can_edit_personal_information(self.job_seeker), + "progress": "20", + } + + +class DeprecatedUpdateJobSeekerStep2View(DeprecatedUpdateJobSeekerBaseView): + template_name = "job_seekers_views/create_or_update_job_seeker/step_2.html" + required_session_namespaces = [ + "job_seeker_session" + ] + DeprecatedUpdateJobSeekerBaseView.required_session_namespaces + + previous_apply_url = "job_seekers_views:update_job_seeker_step_1" + previous_hire_url = "job_seekers_views:update_job_seeker_step_1_for_hire" + next_apply_url = "job_seekers_views:update_job_seeker_step_3" + next_hire_url = "job_seekers_views:update_job_seeker_step_3_for_hire" + + def __init__(self): + super().__init__() + self.form = None + + def setup(self, request, *args, **kwargs): + super().setup(request, *args, **kwargs) + self.form = CreateOrUpdateJobSeekerStep2Form( + instance=self.job_seeker, + initial=self.job_seeker_session.get("user", {}), + data=request.POST or None, + ) + if not self.request.user.can_edit_personal_information(self.job_seeker): + self._disable_form() + + def post(self, request, *args, **kwargs): + if not self.request.user.can_edit_personal_information(self.job_seeker): + return HttpResponseRedirect(self.get_next_url()) + if self.form.is_valid(): + self.job_seeker_session.set("user", self.job_seeker_session.get("user") | self.form.cleaned_data) + return HttpResponseRedirect(self.get_next_url()) + + return self.render_to_response(self.get_context_data(**kwargs)) + + def get_context_data(self, **kwargs): + return super().get_context_data(**kwargs) | { + "form": self.form, + "readonly_form": not self.request.user.can_edit_personal_information(self.job_seeker), + "progress": "40", + } + + +class DeprecatedUpdateJobSeekerStep3View(DeprecatedUpdateJobSeekerBaseView): + template_name = "job_seekers_views/create_or_update_job_seeker/step_3.html" + required_session_namespaces = [ + "job_seeker_session" + ] + DeprecatedUpdateJobSeekerBaseView.required_session_namespaces + + previous_apply_url = "job_seekers_views:update_job_seeker_step_2" + previous_hire_url = "job_seekers_views:update_job_seeker_step_2_for_hire" + next_apply_url = "job_seekers_views:update_job_seeker_step_end" + next_hire_url = "job_seekers_views:update_job_seeker_step_end_for_hire" + + def __init__(self): + super().__init__() + self.form = None + + def get_job_seeker_queryset(self): + return super().get_job_seeker_queryset().select_related("jobseeker_profile") + + def setup(self, request, *args, **kwargs): + super().setup(request, *args, **kwargs) + + self.form = CreateOrUpdateJobSeekerStep3Form( + instance=self.job_seeker.jobseeker_profile if self.job_seeker.has_jobseeker_profile else None, + initial=self.job_seeker_session.get("profile", {}), + data=request.POST or None, + ) + + def post(self, request, *args, **kwargs): + if self.form.is_valid(): + self.job_seeker_session.set("profile", self.job_seeker_session.get("profile", {}) | self.form.cleaned_data) + return HttpResponseRedirect(self.get_next_url()) + + return self.render_to_response(self.get_context_data(**kwargs)) + + def get_context_data(self, **kwargs): + return super().get_context_data(**kwargs) | { + "form": self.form, + "progress": "60", + } + + +class DeprecatedUpdateJobSeekerStepEndView(DeprecatedUpdateJobSeekerBaseView): + template_name = "job_seekers_views/create_or_update_job_seeker/step_end.html" + required_session_namespaces = [ + "job_seeker_session" + ] + DeprecatedUpdateJobSeekerBaseView.required_session_namespaces + + previous_apply_url = "job_seekers_views:update_job_seeker_step_3" + previous_hire_url = "job_seekers_views:update_job_seeker_step_3_for_hire" + next_apply_url = "apply:application_jobs" + next_hire_url = "job_seekers_views:check_job_seeker_info_for_hire" + + def __init__(self): + super().__init__() + self.profile = None + self.updated_user_fields = [] + + def _get_profile_data_from_session(self): + fields_to_exclude = [ + # Dummy fields used by CreateOrUpdateJobSeekerStep3Form() + "pole_emploi", + "pole_emploi_id_forgotten", + "rsa_allocation", + "unemployed", + "ass_allocation", + "aah_allocation", + "lack_of_nir", + # ForeignKeys - the session value will be the ID serialization and not the instance + "birth_place", + "birth_country", + ] + + birth_data = { + "birth_place_id": self.job_seeker_session.get("profile", {}).get("birth_place"), + "birth_country_id": self.job_seeker_session.get("profile", {}).get("birth_country"), + } + + return birth_data | { + k: v for k, v in self.job_seeker_session.get("profile", {}).items() if k not in fields_to_exclude + } + + def setup(self, request, *args, **kwargs): + super().setup(request, *args, **kwargs) + + allowed_user_fields_to_update = [] + if self.request.user.can_edit_personal_information(self.job_seeker): + allowed_user_fields_to_update.extend(CreateOrUpdateJobSeekerStep1Form.Meta.fields) + allowed_user_fields_to_update.extend(CreateOrUpdateJobSeekerStep2Form.Meta.fields) + + for field in allowed_user_fields_to_update: + if field in self.job_seeker_session.get("user", {}): + session_value = self.job_seeker_session.get("user")[field] + if session_value != getattr(self.job_seeker, field): + setattr(self.job_seeker, field, session_value) + self.updated_user_fields.append(field) + + if not self.job_seeker.has_jobseeker_profile: + self.profile = JobSeekerProfile( + user=self.job_seeker, + **self._get_profile_data_from_session(), + ) + else: + self.profile = self.job_seeker.jobseeker_profile + for k, v in self._get_profile_data_from_session().items(): + setattr(self.profile, k, v) + + @transaction.atomic + def post(self, request, *args, **kwargs): + self.updated_user_fields.append("last_checked_at") + try: + if "address_line_1" in self.updated_user_fields or "post_code" in self.updated_user_fields: + try: + self.job_seeker.geocode_address() + except AddressLookupError: + # Nothing to do: re-raised and already logged as error + pass + else: + self.updated_user_fields.extend(["coords", "geocoding_score"]) + self.job_seeker.last_checked_at = timezone.now() + self.job_seeker.save(update_fields=self.updated_user_fields) + except ValidationError as e: + messages.error(request, " ".join(e.messages)) + url = reverse( + "job_seekers_views:update_job_seeker_step_1", + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ) + else: + self.profile.save() + self.job_seeker_session.delete() + url = self.get_next_url() + return HttpResponseRedirect(url) + + def get_context_data(self, **kwargs): + return super().get_context_data(**kwargs) | {"profile": self.profile, "progress": "80"} + + class CheckJobSeekerInformations(ApplicationBaseView): """ Ensure the job seeker has all required info. diff --git a/tests/www/apply/__snapshots__/test_submit.ambr b/tests/www/apply/__snapshots__/test_submit.ambr index d739cf49b6..a93341f06b 100644 --- a/tests/www/apply/__snapshots__/test_submit.ambr +++ b/tests/www/apply/__snapshots__/test_submit.ambr @@ -2103,9 +2103,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - start] +# name: TestUpdateJobSeeker.test_as_authorized_prescriber_with_proxied_job_seeker_deprecated[queries - step 2] dict({ - 'num_queries': 11, + 'num_queries': 8, 'queries': list([ dict({ 'origin': list([ @@ -2168,103 +2168,51 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" - FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ @@ -2275,7 +2223,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -2318,7 +2267,30 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -2374,38 +2346,12 @@ ]), 'sql': 'RELEASE SAVEPOINT ""', }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), ]), }) # --- -# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 1] +# name: TestUpdateJobSeeker.test_as_authorized_prescriber_with_proxied_job_seeker_deprecated[queries - step 3] dict({ - 'num_queries': 14, + 'num_queries': 8, 'queries': list([ dict({ 'origin': list([ @@ -2421,20 +2367,6 @@ LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -2482,56 +2414,197 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", "companies_company"."block_job_applications", "companies_company"."job_applications_blocked_at", "companies_company"."convention_id", @@ -2540,58 +2613,3403 @@ "companies_company"."rdv_solidarites_id", EXISTS (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - start] + dict({ + 'num_queries': 11, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 1] + dict({ + 'num_queries': 14, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 2] + dict({ + 'num_queries': 10, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 3] + dict({ + 'num_queries': 10, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker_deprecated[queries - step 2] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker_deprecated[queries - step 3] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - start] + dict({ + 'num_queries': 11, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 1] + dict({ + 'num_queries': 13, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 2] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 3] + dict({ + 'num_queries': 9, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login", + "users_jobseekerprofile"."user_id", + "users_jobseekerprofile"."birthdate", + "users_jobseekerprofile"."birth_place_id", + "users_jobseekerprofile"."birth_country_id", + "users_jobseekerprofile"."nir", + "users_jobseekerprofile"."lack_of_nir_reason", + "users_jobseekerprofile"."pole_emploi_id", + "users_jobseekerprofile"."lack_of_pole_emploi_id_reason", + "users_jobseekerprofile"."asp_uid", + "users_jobseekerprofile"."education_level", + "users_jobseekerprofile"."resourceless", + "users_jobseekerprofile"."rqth_employee", + "users_jobseekerprofile"."oeth_employee", + "users_jobseekerprofile"."pole_emploi_since", + "users_jobseekerprofile"."unemployed_since", + "users_jobseekerprofile"."has_rsa_allocation", + "users_jobseekerprofile"."rsa_allocation_since", + "users_jobseekerprofile"."ass_allocation_since", + "users_jobseekerprofile"."aah_allocation_since", + "users_jobseekerprofile"."are_allocation_since", + "users_jobseekerprofile"."activity_bonus_since", + "users_jobseekerprofile"."cape_freelance", + "users_jobseekerprofile"."cesa_freelance", + "users_jobseekerprofile"."actor_met_for_business_creation", + "users_jobseekerprofile"."mean_monthly_income_before_process", + "users_jobseekerprofile"."eiti_contributions", + "users_jobseekerprofile"."hexa_lane_number", + "users_jobseekerprofile"."hexa_std_extension", + "users_jobseekerprofile"."hexa_non_std_extension", + "users_jobseekerprofile"."hexa_lane_type", + "users_jobseekerprofile"."hexa_lane_name", + "users_jobseekerprofile"."hexa_additional_address", + "users_jobseekerprofile"."hexa_post_code", + "users_jobseekerprofile"."hexa_commune_id", + "users_jobseekerprofile"."pe_obfuscated_nir", + "users_jobseekerprofile"."pe_last_certification_attempt_at" + FROM "users_user" + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker_deprecated[queries - step 2] + dict({ + 'num_queries': 8, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 ''', }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), - 'sql': 'SAVEPOINT ""', + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -2643,8 +6061,135 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker_deprecated[queries - step 3] + dict({ + 'num_queries': 8, + 'queries': list([ + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -2718,96 +6263,97 @@ FROM "users_user" LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s - AND "users_user"."id" = %s) + AND "users_user"."public_id" = %s) LIMIT 21 ''', }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 - ''', - }), - dict({ - 'origin': list([ - 'CustomFieldRenderer.render[utils/custom_renderer.py]', - 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'BlockNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - ]), - 'sql': ''' - SELECT "asp_country"."id", - "asp_country"."code", - "asp_country"."name", - "asp_country"."group", - "asp_country"."department" - FROM "asp_country" - ORDER BY "asp_country"."name" ASC - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'SAVEPOINT ""', + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', }), dict({ 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 ''', }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': 'RELEASE SAVEPOINT ""', }), ]), }) # --- -# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 2] +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - start] dict({ - 'num_queries': 10, + 'num_queries': 11, 'queries': list([ dict({ 'origin': list([ @@ -2823,20 +6369,6 @@ LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -2991,9 +6523,50 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -3045,88 +6618,42 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."id" = %s) - LIMIT 21 - ''', + 'sql': 'RELEASE SAVEPOINT ""', }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + 'sql': 'SAVEPOINT ""', }), dict({ 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s ''', }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), ]), }) # --- -# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 3] +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 1] dict({ - 'num_queries': 10, + 'num_queries': 14, 'queries': list([ dict({ 'origin': list([ @@ -3310,9 +6837,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -3364,8 +6891,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -3458,7 +6985,7 @@ 'IncludeNode[layout/base.html]', 'IfNode[layout/base.html]', 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', ]), 'sql': ''' SELECT %s AS "a" @@ -3477,12 +7004,58 @@ LIMIT 1 ''', }), + dict({ + 'origin': list([ + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), ]), }) # --- -# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - start] +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 2] dict({ - 'num_queries': 11, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -3498,6 +7071,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -3545,105 +7132,116 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC ''', }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), - 'sql': 'SAVEPOINT ""', + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC + ''', }), dict({ 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'Atomic.__enter__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', + 'sql': 'SAVEPOINT ""', }), dict({ 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -3695,21 +7293,46 @@ }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 ''', }), dict({ @@ -3720,36 +7343,38 @@ }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', ]), 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 ''', }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), ]), }) # --- -# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 1] +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 3] dict({ - 'num_queries': 13, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -3826,51 +7451,103 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC ''', }), dict({ @@ -3881,9 +7558,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -3935,8 +7612,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -4016,80 +7693,42 @@ }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'CustomFieldRenderer.render[utils/custom_renderer.py]', - 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'BlockNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - ]), - 'sql': ''' - SELECT "asp_country"."id", - "asp_country"."code", - "asp_country"."name", - "asp_country"."group", - "asp_country"."department" - FROM "asp_country" - ORDER BY "asp_country"."name" ASC - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s - ''', + 'sql': 'RELEASE SAVEPOINT ""', }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', }), ]), }) # --- -# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 2] +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir_deprecated[queries - step 2] dict({ 'num_queries': 9, 'queries': list([ @@ -4107,20 +7746,6 @@ LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -4168,64 +7793,25 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC ''', }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -4265,20 +7851,57 @@ "companies_company"."rdv_solidarites_id", EXISTS (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC ''', }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -4315,28 +7938,63 @@ "users_user"."first_login" FROM "users_user" WHERE ("users_user"."kind" = %s - AND "users_user"."id" = %s) + AND "users_user"."public_id" = %s) LIMIT 21 ''', }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 ''', }), dict({ @@ -4345,10 +8003,38 @@ ]), 'sql': 'RELEASE SAVEPOINT ""', }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), ]), }) # --- -# name: TestUpdateJobSeeker.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 3] +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir_deprecated[queries - step 3] dict({ 'num_queries': 9, 'queries': list([ @@ -4366,20 +8052,6 @@ LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -4427,64 +8099,25 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC ''', }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -4524,20 +8157,57 @@ "companies_company"."rdv_solidarites_id", EXISTS (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC ''', }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -4611,28 +8281,63 @@ FROM "users_user" LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s - AND "users_user"."id" = %s) + AND "users_user"."public_id" = %s) LIMIT 21 ''', }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 ''', }), dict({ @@ -4641,10 +8346,38 @@ ]), 'sql': 'RELEASE SAVEPOINT ""', }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), ]), }) # --- -# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - start] +# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - start] dict({ 'num_queries': 11, 'queries': list([ @@ -4698,31 +8431,10 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE "users_user"."id" = %s - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 ''', }), dict({ @@ -4730,82 +8442,51 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" - FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ @@ -4909,6 +8590,25 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', @@ -4944,9 +8644,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 1] +# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 1] dict({ - 'num_queries': 14, + 'num_queries': 13, 'queries': list([ dict({ 'origin': list([ @@ -5012,114 +8712,62 @@ "users_user"."last_checked_at", "users_user"."public_id", "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE "users_user"."id" = %s - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" - FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ @@ -5265,38 +8913,30 @@ }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") LIMIT 1 ''', }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), dict({ 'origin': list([ 'CustomFieldRenderer.render[utils/custom_renderer.py]', @@ -5346,9 +8986,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 2] +# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 2] dict({ - 'num_queries': 10, + 'num_queries': 9, 'queries': list([ dict({ 'origin': list([ @@ -5370,158 +9010,106 @@ ]), 'sql': ''' SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE "users_user"."id" = %s - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" - FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE "users_user"."id" = %s + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ @@ -5630,44 +9218,36 @@ }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") LIMIT 1 ''', }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), ]), }) # --- -# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 3] +# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 3] dict({ - 'num_queries': 10, + 'num_queries': 9, 'queries': list([ dict({ 'origin': list([ @@ -5744,103 +9324,51 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" - FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ @@ -5986,42 +9514,34 @@ }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") LIMIT 1 ''', }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - start] +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - start] dict({ 'num_queries': 11, 'queries': list([ @@ -6086,51 +9606,103 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC ''', }), dict({ @@ -6217,40 +9789,21 @@ "companies_company"."source", "companies_company"."created_by_id", "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" - FROM "companies_company" - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 ''', }), dict({ @@ -6288,9 +9841,9 @@ ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 1] +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 1] dict({ - 'num_queries': 13, + 'num_queries': 14, 'queries': list([ dict({ 'origin': list([ @@ -6367,51 +9920,103 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC ''', }), dict({ @@ -6557,29 +10162,37 @@ }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 - ''', + 'sql': 'RELEASE SAVEPOINT ""', }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', }), dict({ 'origin': list([ @@ -6630,9 +10243,9 @@ ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 2] +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 2] dict({ - 'num_queries': 9, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -6707,53 +10320,105 @@ dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + ]), + 'sql': ''' + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC ''', }), dict({ @@ -6862,36 +10527,44 @@ }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 - ''', + 'sql': 'RELEASE SAVEPOINT ""', }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_authorized_prescriber_with_proxied_job_seeker[queries - step 3] +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 3] dict({ - 'num_queries': 9, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -6968,51 +10641,103 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC ''', }), dict({ @@ -7158,36 +10883,44 @@ }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 - ''', + 'sql': 'RELEASE SAVEPOINT ""', }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - start] +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker_deprecated[queries - step 2] dict({ - 'num_queries': 11, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -7357,7 +11090,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -7400,7 +11134,10 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -7452,42 +11189,64 @@ }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'Company.has_member[common_apps/organizations/models.py]', + 'DeprecatedUpdateJobSeekerStep2View.dispatch[www/apply/views/submit_views.py]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': 'SAVEPOINT ""', + 'sql': 'RELEASE SAVEPOINT ""', }), dict({ 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', ]), 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 ''', }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 1] +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker_deprecated[queries - step 3] dict({ - 'num_queries': 14, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -7503,20 +11262,6 @@ LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -7671,62 +11416,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" - FROM "companies_company" - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -7798,10 +11489,85 @@ "users_jobseekerprofile"."pe_obfuscated_nir", "users_jobseekerprofile"."pe_last_certification_attempt_at" FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") - WHERE ("users_user"."kind" = %s + LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Company.has_member[common_apps/organizations/models.py]', + 'DeprecatedUpdateJobSeekerStep3View.dispatch[www/apply/views/submit_views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active")) AND "users_user"."id" = %s) - LIMIT 21 + LIMIT 1 ''', }), dict({ @@ -7819,7 +11585,7 @@ 'IncludeNode[layout/base.html]', 'IfNode[layout/base.html]', 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', ]), 'sql': ''' SELECT %s AS "a" @@ -7838,58 +11604,12 @@ LIMIT 1 ''', }), - dict({ - 'origin': list([ - 'CustomFieldRenderer.render[utils/custom_renderer.py]', - 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'BlockNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - ]), - 'sql': ''' - SELECT "asp_country"."id", - "asp_country"."code", - "asp_country"."name", - "asp_country"."group", - "asp_country"."department" - FROM "asp_country" - ORDER BY "asp_country"."name" ASC - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 2] +# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - start] dict({ - 'num_queries': 10, + 'num_queries': 11, 'queries': list([ dict({ 'origin': list([ @@ -7905,20 +11625,6 @@ LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -7966,116 +11672,105 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + 'Atomic.__enter__[/django/db/transaction.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" - FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 ''', }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -8127,46 +11822,21 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."id" = %s) - LIMIT 21 + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 ''', }), dict({ @@ -8177,38 +11847,36 @@ }), dict({ 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s ''', }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 3] +# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 1] dict({ - 'num_queries': 10, + 'num_queries': 13, 'queries': list([ dict({ 'origin': list([ @@ -8285,103 +11953,51 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "companies_companymembership"."id", - "companies_companymembership"."user_id", - "companies_companymembership"."joined_at", - "companies_companymembership"."is_admin", - "companies_companymembership"."is_active", - "companies_companymembership"."created_at", - "companies_companymembership"."updated_at", - "companies_companymembership"."company_id", - "companies_companymembership"."updated_by_id", - "companies_companymembership"."notifications" - FROM "companies_companymembership" - WHERE ("companies_companymembership"."user_id" = %s - AND "companies_companymembership"."is_active") - ORDER BY "companies_companymembership"."created_at" ASC - ''', - }), - dict({ - 'origin': list([ - 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1) AS "has_convention_in_grace_period", - "companies_siaeconvention"."id", - "companies_siaeconvention"."kind", - "companies_siaeconvention"."siret_signature", - "companies_siaeconvention"."is_active", - "companies_siaeconvention"."deactivated_at", - "companies_siaeconvention"."reactivated_by_id", - "companies_siaeconvention"."reactivated_at", - "companies_siaeconvention"."asp_id", - "companies_siaeconvention"."created_at", - "companies_siaeconvention"."updated_at" - FROM "companies_company" - INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") - LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_companymembership"."user_id" = %s - AND "companies_company"."id" IN (%s) - AND (NOT ("companies_company"."kind" IN (%s, - %s, - %s, - %s, - %s)) - OR "companies_company"."source" = %s - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."id" = ("companies_company"."convention_id") - AND U0."is_active") - LIMIT 1) - OR EXISTS - (SELECT %s AS "a" - FROM "companies_siaeconvention" U0 - WHERE (U0."deactivated_at" >= %s - AND U0."id" = ("companies_company"."convention_id")) - LIMIT 1))) - ORDER BY RANDOM() ASC + SELECT "prescribers_prescribermembership"."id", + "prescribers_prescribermembership"."user_id", + "prescribers_prescribermembership"."joined_at", + "prescribers_prescribermembership"."is_admin", + "prescribers_prescribermembership"."is_active", + "prescribers_prescribermembership"."created_at", + "prescribers_prescribermembership"."updated_at", + "prescribers_prescribermembership"."organization_id", + "prescribers_prescribermembership"."updated_by_id", + "prescribers_prescriberorganization"."id", + "prescribers_prescriberorganization"."address_line_1", + "prescribers_prescriberorganization"."address_line_2", + "prescribers_prescriberorganization"."post_code", + "prescribers_prescriberorganization"."city", + "prescribers_prescriberorganization"."department", + "prescribers_prescriberorganization"."coords", + "prescribers_prescriberorganization"."geocoding_score", + "prescribers_prescriberorganization"."geocoding_updated_at", + "prescribers_prescriberorganization"."ban_api_resolved_address", + "prescribers_prescriberorganization"."insee_city_id", + "prescribers_prescriberorganization"."name", + "prescribers_prescriberorganization"."created_at", + "prescribers_prescriberorganization"."updated_at", + "prescribers_prescriberorganization"."uid", + "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", + "prescribers_prescriberorganization"."automatic_geocoding_update", + "prescribers_prescriberorganization"."siret", + "prescribers_prescriberorganization"."is_head_office", + "prescribers_prescriberorganization"."kind", + "prescribers_prescriberorganization"."is_brsa", + "prescribers_prescriberorganization"."phone", + "prescribers_prescriberorganization"."email", + "prescribers_prescriberorganization"."website", + "prescribers_prescriberorganization"."description", + "prescribers_prescriberorganization"."is_authorized", + "prescribers_prescriberorganization"."code_safir_pole_emploi", + "prescribers_prescriberorganization"."created_by_id", + "prescribers_prescriberorganization"."authorization_status", + "prescribers_prescriberorganization"."authorization_updated_at", + "prescribers_prescriberorganization"."authorization_updated_by_id" + FROM "prescribers_prescribermembership" + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active") + ORDER BY "prescribers_prescribermembership"."created_at" ASC ''', }), dict({ @@ -8392,9 +12008,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -8446,8 +12062,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -8525,6 +12141,26 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'User.is_prescriber_with_authorized_org[users/models.py]', + 'User.can_edit_personal_information[users/models.py]', + 'User.can_view_personal_information[users/models.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "prescribers_prescribermembership" + INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") + INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") + WHERE ("prescribers_prescribermembership"."user_id" = %s + AND "prescribers_prescribermembership"."is_active" + AND "prescribers_prescriberorganization"."is_authorized" + AND "users_user"."is_active") + LIMIT 1 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', @@ -8533,38 +12169,56 @@ }), dict({ 'origin': list([ - 'Company.has_admin[common_apps/organizations/models.py]', - 'Company.convention_can_be_accessed_by[companies/models.py]', - 'nav[utils/templatetags/nav.py]', - 'InclusionNode[layout/_header_authenticated.html]', - 'IncludeNode[layout/base.html]', - 'IfNode[layout/base.html]', + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "users_user" - INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") - WHERE ("companies_companymembership"."id" IN - (SELECT U0."id" - FROM "companies_companymembership" U0 - INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") - WHERE (U0."company_id" = %s - AND U2."is_active" - AND U0."is_active" - AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s ''', }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - start] +# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 2] dict({ - 'num_queries': 11, + 'num_queries': 9, 'queries': list([ dict({ 'origin': list([ @@ -8580,6 +12234,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -8682,50 +12350,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -8775,12 +12402,57 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'User.is_prescriber_with_authorized_org[users/models.py]', 'User.can_edit_personal_information[users/models.py]', 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" @@ -8800,38 +12472,12 @@ ]), 'sql': 'RELEASE SAVEPOINT ""', }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 1] +# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 3] dict({ - 'num_queries': 13, + 'num_queries': 9, 'queries': list([ dict({ 'origin': list([ @@ -8963,9 +12609,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -9017,8 +12663,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -9101,8 +12747,8 @@ 'User.is_prescriber_with_authorized_org[users/models.py]', 'User.can_edit_personal_information[users/models.py]', 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" @@ -9122,58 +12768,12 @@ ]), 'sql': 'RELEASE SAVEPOINT ""', }), - dict({ - 'origin': list([ - 'CustomFieldRenderer.render[utils/custom_renderer.py]', - 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'BlockNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - ]), - 'sql': ''' - SELECT "asp_country"."id", - "asp_country"."code", - "asp_country"."name", - "asp_country"."group", - "asp_country"."department" - FROM "asp_country" - ORDER BY "asp_country"."name" ASC - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 2] +# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - start] dict({ - 'num_queries': 9, + 'num_queries': 11, 'queries': list([ dict({ 'origin': list([ @@ -9189,20 +12789,6 @@ LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -9250,51 +12836,103 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC ''', }), dict({ @@ -9305,9 +12943,50 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -9359,80 +13038,42 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."id" = %s) - LIMIT 21 - ''', + 'sql': 'SAVEPOINT ""', }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s ''', }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': 'RELEASE SAVEPOINT ""', }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_as_unauthorized_prescriber_that_created_proxied_job_seeker[queries - step 3] +# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - step 1] dict({ - 'num_queries': 9, + 'num_queries': 14, 'queries': list([ dict({ 'origin': list([ @@ -9509,51 +13150,103 @@ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), 'sql': ''' - SELECT "prescribers_prescribermembership"."id", - "prescribers_prescribermembership"."user_id", - "prescribers_prescribermembership"."joined_at", - "prescribers_prescribermembership"."is_admin", - "prescribers_prescribermembership"."is_active", - "prescribers_prescribermembership"."created_at", - "prescribers_prescribermembership"."updated_at", - "prescribers_prescribermembership"."organization_id", - "prescribers_prescribermembership"."updated_by_id", - "prescribers_prescriberorganization"."id", - "prescribers_prescriberorganization"."address_line_1", - "prescribers_prescriberorganization"."address_line_2", - "prescribers_prescriberorganization"."post_code", - "prescribers_prescriberorganization"."city", - "prescribers_prescriberorganization"."department", - "prescribers_prescriberorganization"."coords", - "prescribers_prescriberorganization"."geocoding_score", - "prescribers_prescriberorganization"."geocoding_updated_at", - "prescribers_prescriberorganization"."ban_api_resolved_address", - "prescribers_prescriberorganization"."insee_city_id", - "prescribers_prescriberorganization"."name", - "prescribers_prescriberorganization"."created_at", - "prescribers_prescriberorganization"."updated_at", - "prescribers_prescriberorganization"."uid", - "prescribers_prescriberorganization"."active_members_email_reminder_last_sent_at", - "prescribers_prescriberorganization"."automatic_geocoding_update", - "prescribers_prescriberorganization"."siret", - "prescribers_prescriberorganization"."is_head_office", - "prescribers_prescriberorganization"."kind", - "prescribers_prescriberorganization"."is_brsa", - "prescribers_prescriberorganization"."phone", - "prescribers_prescriberorganization"."email", - "prescribers_prescriberorganization"."website", - "prescribers_prescriberorganization"."description", - "prescribers_prescriberorganization"."is_authorized", - "prescribers_prescriberorganization"."code_safir_pole_emploi", - "prescribers_prescriberorganization"."created_by_id", - "prescribers_prescriberorganization"."authorization_status", - "prescribers_prescriberorganization"."authorization_updated_at", - "prescribers_prescriberorganization"."authorization_updated_by_id" - FROM "prescribers_prescribermembership" - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active") - ORDER BY "prescribers_prescribermembership"."created_at" ASC + SELECT "companies_companymembership"."id", + "companies_companymembership"."user_id", + "companies_companymembership"."joined_at", + "companies_companymembership"."is_admin", + "companies_companymembership"."is_active", + "companies_companymembership"."created_at", + "companies_companymembership"."updated_at", + "companies_companymembership"."company_id", + "companies_companymembership"."updated_by_id", + "companies_companymembership"."notifications" + FROM "companies_companymembership" + WHERE ("companies_companymembership"."user_id" = %s + AND "companies_companymembership"."is_active") + ORDER BY "companies_companymembership"."created_at" ASC + ''', + }), + dict({ + 'origin': list([ + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1) AS "has_convention_in_grace_period", + "companies_siaeconvention"."id", + "companies_siaeconvention"."kind", + "companies_siaeconvention"."siret_signature", + "companies_siaeconvention"."is_active", + "companies_siaeconvention"."deactivated_at", + "companies_siaeconvention"."reactivated_by_id", + "companies_siaeconvention"."reactivated_at", + "companies_siaeconvention"."asp_id", + "companies_siaeconvention"."created_at", + "companies_siaeconvention"."updated_at" + FROM "companies_company" + INNER JOIN "companies_companymembership" ON ("companies_company"."id" = "companies_companymembership"."company_id") + LEFT OUTER JOIN "companies_siaeconvention" ON ("companies_company"."convention_id" = "companies_siaeconvention"."id") + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_companymembership"."user_id" = %s + AND "companies_company"."id" IN (%s) + AND (NOT ("companies_company"."kind" IN (%s, + %s, + %s, + %s, + %s)) + OR "companies_company"."source" = %s + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."id" = ("companies_company"."convention_id") + AND U0."is_active") + LIMIT 1) + OR EXISTS + (SELECT %s AS "a" + FROM "companies_siaeconvention" U0 + WHERE (U0."deactivated_at" >= %s + AND U0."id" = ("companies_company"."convention_id")) + LIMIT 1))) + ORDER BY RANDOM() ASC ''', }), dict({ @@ -9564,9 +13257,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -9618,8 +13311,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -9694,41 +13387,95 @@ LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s AND "users_user"."id" = %s) - LIMIT 21 + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__exit__[/django/db/transaction.py]', + ]), + 'sql': 'RELEASE SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 ''', }), dict({ 'origin': list([ - 'User.is_prescriber_with_authorized_org[users/models.py]', - 'User.can_edit_personal_information[users/models.py]', - 'User.can_view_personal_information[users/models.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'CustomFieldRenderer.render[utils/custom_renderer.py]', + 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'BlockNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', ]), 'sql': ''' - SELECT %s AS "a" - FROM "prescribers_prescribermembership" - INNER JOIN "users_user" ON ("prescribers_prescribermembership"."user_id" = "users_user"."id") - INNER JOIN "prescribers_prescriberorganization" ON ("prescribers_prescribermembership"."organization_id" = "prescribers_prescriberorganization"."id") - WHERE ("prescribers_prescribermembership"."user_id" = %s - AND "prescribers_prescribermembership"."is_active" - AND "prescribers_prescriberorganization"."is_authorized" - AND "users_user"."is_active") - LIMIT 1 + SELECT "asp_country"."id", + "asp_country"."code", + "asp_country"."name", + "asp_country"."group", + "asp_country"."department" + FROM "asp_country" + ORDER BY "asp_country"."name" ASC + ''', + }), + dict({ + 'origin': list([ + 'Atomic.__enter__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': 'SAVEPOINT ""', + }), + dict({ + 'origin': list([ + 'Session.save[/django/db/models/base.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + UPDATE "django_session" + SET "session_data" = %s, + "expire_date" = %s + WHERE "django_session"."session_key" = %s ''', }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', + 'SessionStore.save[/django/contrib/sessions/backends/db.py]', ]), 'sql': 'RELEASE SAVEPOINT ""', }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - start] +# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - step 2] dict({ - 'num_queries': 11, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -9744,6 +13491,20 @@ LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', + ]), + 'sql': ''' + SELECT "django_session"."session_key", + "django_session"."session_data", + "django_session"."expire_date" + FROM "django_session" + WHERE ("django_session"."expire_date" > %s + AND "django_session"."session_key" = %s) + LIMIT 21 + ''', + }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -9898,50 +13659,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" - FROM "users_user" - WHERE ("users_user"."kind" = %s - AND "users_user"."public_id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStartView.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -9993,42 +13713,88 @@ }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."id" = %s) + LIMIT 21 + ''', }), dict({ 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'Atomic.__exit__[/django/db/transaction.py]', ]), - 'sql': 'SAVEPOINT ""', + 'sql': 'RELEASE SAVEPOINT ""', }), dict({ 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', + 'Company.has_admin[common_apps/organizations/models.py]', + 'Company.convention_can_be_accessed_by[companies/models.py]', + 'nav[utils/templatetags/nav.py]', + 'InclusionNode[layout/_header_authenticated.html]', + 'IncludeNode[layout/base.html]', + 'IfNode[layout/base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_2.html]', ]), 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active" + AND U0."is_admin" + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 ''', }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - step 1] +# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - step 3] dict({ - 'num_queries': 14, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -10212,9 +13978,9 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -10266,8 +14032,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -10360,7 +14126,7 @@ 'IncludeNode[layout/base.html]', 'IfNode[layout/base.html]', 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.html]', ]), 'sql': ''' SELECT %s AS "a" @@ -10374,61 +14140,15 @@ AND U2."is_active" AND U0."is_active" AND U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 - ''', - }), - dict({ - 'origin': list([ - 'CustomFieldRenderer.render[utils/custom_renderer.py]', - 'SimpleNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'IfNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - 'BlockNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'BlockNode[layout/base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_base.html]', - 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_1.html]', - ]), - 'sql': ''' - SELECT "asp_country"."id", - "asp_country"."code", - "asp_country"."name", - "asp_country"."group", - "asp_country"."department" - FROM "asp_country" - ORDER BY "asp_country"."name" ASC - ''', - }), - dict({ - 'origin': list([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'SAVEPOINT ""', - }), - dict({ - 'origin': list([ - 'Session.save[/django/db/models/base.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - UPDATE "django_session" - SET "session_data" = %s, - "expire_date" = %s - WHERE "django_session"."session_key" = %s + AND U2."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 ''', }), - dict({ - 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': 'RELEASE SAVEPOINT ""', - }), ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - step 2] +# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir_deprecated[queries - step 2] dict({ 'num_queries': 10, 'queries': list([ @@ -10446,20 +14166,6 @@ LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -10614,9 +14320,54 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "users_user"."id", + "users_user"."password", + "users_user"."last_login", + "users_user"."is_superuser", + "users_user"."username", + "users_user"."first_name", + "users_user"."last_name", + "users_user"."is_staff", + "users_user"."is_active", + "users_user"."date_joined", + "users_user"."address_line_1", + "users_user"."address_line_2", + "users_user"."post_code", + "users_user"."city", + "users_user"."department", + "users_user"."coords", + "users_user"."geocoding_score", + "users_user"."geocoding_updated_at", + "users_user"."ban_api_resolved_address", + "users_user"."insee_city_id", + "users_user"."title", + "users_user"."email", + "users_user"."phone", + "users_user"."kind", + "users_user"."identity_provider", + "users_user"."has_completed_welcoming_tour", + "users_user"."created_by_id", + "users_user"."external_data_source_history", + "users_user"."last_checked_at", + "users_user"."public_id", + "users_user"."address_filled_at", + "users_user"."first_login" + FROM "users_user" + WHERE ("users_user"."kind" = %s + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep2View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "companies_company"."id", @@ -10668,46 +14419,22 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep2View.setup[www/job_seekers_views/views.py]', + 'Company.has_member[common_apps/organizations/models.py]', + 'DeprecatedUpdateJobSeekerStep2View.dispatch[www/apply/views/submit_views.py]', ]), 'sql': ''' - SELECT "users_user"."id", - "users_user"."password", - "users_user"."last_login", - "users_user"."is_superuser", - "users_user"."username", - "users_user"."first_name", - "users_user"."last_name", - "users_user"."is_staff", - "users_user"."is_active", - "users_user"."date_joined", - "users_user"."address_line_1", - "users_user"."address_line_2", - "users_user"."post_code", - "users_user"."city", - "users_user"."department", - "users_user"."coords", - "users_user"."geocoding_score", - "users_user"."geocoding_updated_at", - "users_user"."ban_api_resolved_address", - "users_user"."insee_city_id", - "users_user"."title", - "users_user"."email", - "users_user"."phone", - "users_user"."kind", - "users_user"."identity_provider", - "users_user"."has_completed_welcoming_tour", - "users_user"."created_by_id", - "users_user"."external_data_source_history", - "users_user"."last_checked_at", - "users_user"."public_id", - "users_user"."address_filled_at", - "users_user"."first_login" + SELECT %s AS "a" FROM "users_user" - WHERE ("users_user"."kind" = %s + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active")) AND "users_user"."id" = %s) - LIMIT 21 + LIMIT 1 ''', }), dict({ @@ -10747,7 +14474,7 @@ ]), }) # --- -# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - step 3] +# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir_deprecated[queries - step 3] dict({ 'num_queries': 10, 'queries': list([ @@ -10765,20 +14492,6 @@ LIMIT 21 ''', }), - dict({ - 'origin': list([ - 'SessionStore._get_session_from_db[/django/contrib/sessions/backends/db.py]', - ]), - 'sql': ''' - SELECT "django_session"."session_key", - "django_session"."session_data", - "django_session"."expire_date" - FROM "django_session" - WHERE ("django_session"."expire_date" > %s - AND "django_session"."session_key" = %s) - LIMIT 21 - ''', - }), dict({ 'origin': list([ 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', @@ -10933,62 +14646,8 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - ]), - 'sql': ''' - SELECT "companies_company"."id", - "companies_company"."address_line_1", - "companies_company"."address_line_2", - "companies_company"."post_code", - "companies_company"."city", - "companies_company"."department", - "companies_company"."coords", - "companies_company"."geocoding_score", - "companies_company"."geocoding_updated_at", - "companies_company"."ban_api_resolved_address", - "companies_company"."insee_city_id", - "companies_company"."name", - "companies_company"."created_at", - "companies_company"."updated_at", - "companies_company"."uid", - "companies_company"."active_members_email_reminder_last_sent_at", - "companies_company"."automatic_geocoding_update", - "companies_company"."siret", - "companies_company"."naf", - "companies_company"."kind", - "companies_company"."brand", - "companies_company"."phone", - "companies_company"."email", - "companies_company"."auth_email", - "companies_company"."website", - "companies_company"."description", - "companies_company"."provided_support", - "companies_company"."source", - "companies_company"."created_by_id", - "companies_company"."block_job_applications", - "companies_company"."job_applications_blocked_at", - "companies_company"."convention_id", - "companies_company"."job_app_score", - "companies_company"."is_searchable", - "companies_company"."rdv_solidarites_id", - EXISTS - (SELECT %s AS "a" - FROM "companies_companymembership" U0 - WHERE (U0."company_id" = ("companies_company"."id") - AND U0."is_active") - LIMIT 1) AS "has_active_members" - FROM "companies_company" - WHERE (NOT ("companies_company"."siret" = %s) - AND "companies_company"."id" = %s) - LIMIT 21 - ''', - }), - dict({ - 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT "users_user"."id", @@ -11062,10 +14721,85 @@ FROM "users_user" LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") WHERE ("users_user"."kind" = %s - AND "users_user"."id" = %s) + AND "users_user"."public_id" = %s) + LIMIT 21 + ''', + }), + dict({ + 'origin': list([ + 'DeprecatedUpdateJobSeekerStep3View.setup[www/apply/views/submit_views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[utils/session.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + ]), + 'sql': ''' + SELECT "companies_company"."id", + "companies_company"."address_line_1", + "companies_company"."address_line_2", + "companies_company"."post_code", + "companies_company"."city", + "companies_company"."department", + "companies_company"."coords", + "companies_company"."geocoding_score", + "companies_company"."geocoding_updated_at", + "companies_company"."ban_api_resolved_address", + "companies_company"."insee_city_id", + "companies_company"."name", + "companies_company"."created_at", + "companies_company"."updated_at", + "companies_company"."uid", + "companies_company"."active_members_email_reminder_last_sent_at", + "companies_company"."automatic_geocoding_update", + "companies_company"."siret", + "companies_company"."naf", + "companies_company"."kind", + "companies_company"."brand", + "companies_company"."phone", + "companies_company"."email", + "companies_company"."auth_email", + "companies_company"."website", + "companies_company"."description", + "companies_company"."provided_support", + "companies_company"."source", + "companies_company"."created_by_id", + "companies_company"."block_job_applications", + "companies_company"."job_applications_blocked_at", + "companies_company"."convention_id", + "companies_company"."job_app_score", + "companies_company"."is_searchable", + "companies_company"."rdv_solidarites_id", + EXISTS + (SELECT %s AS "a" + FROM "companies_companymembership" U0 + WHERE (U0."company_id" = ("companies_company"."id") + AND U0."is_active") + LIMIT 1) AS "has_active_members" + FROM "companies_company" + WHERE (NOT ("companies_company"."siret" = %s) + AND "companies_company"."id" = %s) LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'Company.has_member[common_apps/organizations/models.py]', + 'DeprecatedUpdateJobSeekerStep3View.dispatch[www/apply/views/submit_views.py]', + ]), + 'sql': ''' + SELECT %s AS "a" + FROM "users_user" + INNER JOIN "companies_companymembership" ON ("users_user"."id" = "companies_companymembership"."user_id") + WHERE ("companies_companymembership"."id" IN + (SELECT U0."id" + FROM "companies_companymembership" U0 + INNER JOIN "users_user" U2 ON (U0."user_id" = U2."id") + WHERE (U0."company_id" = %s + AND U2."is_active" + AND U0."is_active")) + AND "users_user"."id" = %s) + LIMIT 1 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', diff --git a/tests/www/apply/test_submit.py b/tests/www/apply/test_submit.py index 7601428482..75b80756dd 100644 --- a/tests/www/apply/test_submit.py +++ b/tests/www/apply/test_submit.py @@ -269,6 +269,17 @@ def test_404_when_trying_to_update_a_prescriber(self, client): response = client.get(url) assert response.status_code == 404 + # TODO(ewen): deprecated URL + for viewname in [ + "job_seekers_views:update_job_seeker_step_1_for_hire", + "job_seekers_views:update_job_seeker_step_2_for_hire", + "job_seekers_views:update_job_seeker_step_3_for_hire", + "job_seekers_views:update_job_seeker_step_end_for_hire", + ]: + url = reverse(viewname, kwargs={"company_pk": company.pk, "job_seeker_public_id": prescriber.public_id}) + response = client.get(url) + assert response.status_code == 404 + def test_404_when_trying_to_hire_a_prescriber(self, client): company = CompanyFactory(with_jobs=True, with_membership=True) prescriber = PrescriberFactory() @@ -3472,10 +3483,27 @@ def setup_method(self, settings, mocker): "config": {"from_url": from_url}, "job_seeker_pk": self.job_seeker.pk, } + self.step_1_url = reverse( + self.STEP_1_VIEW_NAME, + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ) + self.step_2_url = reverse( + self.STEP_2_VIEW_NAME, + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ) + self.step_3_url = reverse( + self.STEP_3_VIEW_NAME, + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ) + self.step_end_url = reverse( + self.STEP_END_VIEW_NAME, + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ) [self.city] = create_test_cities(["67"], num_per_department=1) self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT = "Informations modifiables par le candidat uniquement" + self.job_seeker_session_key = f"job_seeker-{self.job_seeker.public_id}" settings.API_BAN_BASE_URL = "http://ban-api" mocker.patch( @@ -3506,11 +3534,27 @@ def _check_nothing_permitted(self, client, user): response = client.get(self.start_url) assert response.status_code == 403 + def _check_nothing_permitted_deprecated(self, client, user): + client.force_login(user) + for url in [ + self.step_1_url, + self.step_2_url, + self.step_3_url, + self.step_end_url, + ]: + response = client.get(url) + assert response.status_code == 403 + def _check_that_last_step_doesnt_crash_with_direct_access(self, client, user): client.force_login(user) client.get(self.start_url) # Setup job_seeker_session client.get(self.get_step_url("end", client)) # Use partial job_seeker_session + def _check_that_last_step_doesnt_crash_with_direct_access_deprecated(self, client, user): + client.force_login(user) + client.get(self.step_1_url) # Setup job_seeker_session + client.get(self.step_end_url) # Use partial job_seeker_session + def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=None): client.force_login(user) @@ -3702,6 +3746,192 @@ def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=No assert self.job_seeker.last_checked_at != previous_last_checked_at + def _check_everything_allowed_deprecated(self, client, snapshot, user, extra_post_data_1=None): + client.force_login(user) + + # STEP 1 + response = client.get(self.step_1_url) + assertContains(response, self.job_seeker.first_name) + assertNotContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) + + # Let's check for consistency between the NIR, the birthdate and the title. + # (but do not check when there is no NIR) + # ---------------------------------------------------------------------- + + if self.job_seeker.jobseeker_profile.nir != "": + post_data = { + "title": "MME", # Inconsistent title + "first_name": self.job_seeker.first_name, + "last_name": self.job_seeker.last_name, + "birthdate": self.job_seeker.jobseeker_profile.birthdate, + "lack_of_nir": False, + "lack_of_nir_reason": "", + } + response = client.post(self.step_1_url, data=post_data) + assert response.status_code == 200 + assertContains(response, JobSeekerProfile.ERROR_JOBSEEKER_INCONSISTENT_NIR_TITLE % "") + + post_data = { + "title": "M", + "first_name": self.job_seeker.first_name, + "last_name": self.job_seeker.last_name, + "birthdate": datetime.date(1978, 11, 20), # Inconsistent birthdate + "lack_of_nir": False, + "lack_of_nir_reason": "", + } + response = client.post(self.step_1_url, data=post_data) + assert response.status_code == 200 + assertContains(response, JobSeekerProfile.ERROR_JOBSEEKER_INCONSISTENT_NIR_BIRTHDATE % "") + + # Resume to valid data and proceed with "normal" flow. + # ---------------------------------------------------------------------- + + NEW_FIRST_NAME = "New first name" + PROCESS_TITLE = "Modification du compte candidat" + + post_data = { + "title": "M", + "first_name": NEW_FIRST_NAME, + "last_name": "New last name", + "birthdate": self.job_seeker.jobseeker_profile.birthdate, + "lack_of_nir": False, + "lack_of_nir_reason": "", + } + if extra_post_data_1 is not None: + post_data.update(extra_post_data_1) + response = client.post(self.step_1_url, data=post_data) + assertRedirects(response, self.step_2_url, fetch_redirect_response=False) + + # Data is stored in the session but user is untouched + # (nir value is retrieved from the job_seeker and stored in the session) + lack_of_nir_reason = post_data.pop("lack_of_nir_reason") + nir = post_data.pop("nir", None) + birthdate = post_data.pop("birthdate", None) + birth_place = post_data.pop("birth_place", None) + birth_country = post_data.pop("birth_country", None) + expected_job_seeker_session = { + "user": post_data, + "profile": { + "birth_place": birth_place or self.job_seeker.jobseeker_profile.birth_place, + "birth_country": birth_country or self.job_seeker.jobseeker_profile.birth_country, + "birthdate": birthdate or self.job_seeker.jobseeker_profile.birthdate, + "nir": nir or self.job_seeker.jobseeker_profile.nir, + "lack_of_nir_reason": lack_of_nir_reason, + }, + } + assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + self.job_seeker.refresh_from_db() + assert self.job_seeker.first_name != NEW_FIRST_NAME + + # If you go back to step 1, new data is shown + response = client.get(self.step_1_url) + assertContains(response, PROCESS_TITLE, html=True) + assertContains(response, NEW_FIRST_NAME) + + # STEP 2 + with assertSnapshotQueries(snapshot(name="queries - step 2")): + response = client.get(self.step_2_url) + assertContains(response, PROCESS_TITLE, html=True) + assertContains(response, self.job_seeker.phone) + assertNotContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) + + NEW_ADDRESS_LINE = "382 ROUTE DE JOLLIVET" + + fields = [NEW_ADDRESS_LINE, f"{self.city.post_codes[0]} {self.city}"] + new_geocoding_address = ", ".join([field for field in fields if field]) + + post_data = { + "ban_api_resolved_address": new_geocoding_address, + "address_line_1": NEW_ADDRESS_LINE, + "post_code": self.city.post_codes[0], + "insee_code": self.city.code_insee, + "city": self.city.name, + "phone": self.job_seeker.phone, + "fill_mode": "ban_api", + } + + response = client.post(self.step_2_url, data=post_data) + assertRedirects(response, self.step_3_url, fetch_redirect_response=False) + + # Data is stored in the session but user is untouched + expected_job_seeker_session["user"] |= post_data | {"address_line_2": "", "address_for_autocomplete": None} + assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + self.job_seeker.refresh_from_db() + assert self.job_seeker.address_line_1 != NEW_ADDRESS_LINE + + # If you go back to step 2, new data is shown + response = client.get(self.step_2_url) + assertContains(response, NEW_ADDRESS_LINE) + + # STEP 3 + with assertSnapshotQueries(snapshot(name="queries - step 3")): + response = client.get(self.step_3_url) + assertContains(response, PROCESS_TITLE, html=True) + assertContains(response, "Niveau de formation") + + post_data = { + "education_level": EducationLevel.BAC_LEVEL.value, + } + response = client.post(self.step_3_url, data=post_data) + assertRedirects(response, self.step_end_url, fetch_redirect_response=False) + + # Data is stored in the session but user & profiles are untouched + expected_job_seeker_session["profile"] |= post_data | { + "pole_emploi_id": "", + "lack_of_pole_emploi_id_reason": LackOfPoleEmploiId.REASON_NOT_REGISTERED, + "resourceless": False, + "rqth_employee": False, + "oeth_employee": False, + "pole_emploi": False, + "pole_emploi_id_forgotten": "", + "pole_emploi_since": "", + "unemployed": False, + "unemployed_since": "", + "rsa_allocation": False, + "has_rsa_allocation": RSAAllocation.NO.value, + "rsa_allocation_since": "", + "ass_allocation": False, + "ass_allocation_since": "", + "aah_allocation": False, + "aah_allocation_since": "", + } + assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + self.job_seeker.refresh_from_db() + + # If you go back to step 3, new data is shown + response = client.get(self.step_3_url) + assertContains(response, '', html=True) + + # Step END + response = client.get(self.step_end_url) + assertContains(response, PROCESS_TITLE, html=True) + assertContains(response, NEW_FIRST_NAME.title()) # User.get_full_name() changes the firstname display + assertContains(response, NEW_ADDRESS_LINE) + assertContains(response, "Formation de niveau BAC") + assertContains(response, "Valider les informations") + + previous_last_checked_at = self.job_seeker.last_checked_at + + response = client.post(self.step_end_url) + assertRedirects( + response, + reverse( + self.FINAL_REDIRECT_VIEW_NAME, + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ), + fetch_redirect_response=False, + ) + assert client.session.get(self.job_seeker_session_key) is None + + self.job_seeker.refresh_from_db() + assert self.job_seeker.has_jobseeker_profile is True + assert self.job_seeker.first_name == NEW_FIRST_NAME + assert self.job_seeker.address_line_1 == NEW_ADDRESS_LINE + self.job_seeker.jobseeker_profile.refresh_from_db() + assert self.job_seeker.jobseeker_profile.education_level == EducationLevel.BAC_LEVEL + + assert self.job_seeker.last_checked_at != previous_last_checked_at + def _check_only_administrative_allowed(self, client, user): client.force_login(user) @@ -3791,21 +4021,128 @@ def _check_only_administrative_allowed(self, client, user): assert self.job_seeker.jobseeker_profile.education_level == EducationLevel.BAC_LEVEL assert self.job_seeker.last_checked_at != previous_last_checked_at + def _check_only_administrative_allowed_deprecated(self, client, user): + client.force_login(user) + + # STEP 1 + response = client.get(self.step_1_url) + assertContains(response, self.job_seeker.first_name) + assertContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) + + response = client.post(self.step_1_url) + assertRedirects(response, self.step_2_url, fetch_redirect_response=False) + + # Session is created + expected_job_seeker_session = {"user": {}} + assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + + # STEP 2 + response = client.get(self.step_2_url) + assertContains(response, self.job_seeker.phone) + assertContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) + + response = client.post(self.step_2_url) + assertRedirects(response, self.step_3_url, fetch_redirect_response=False) + + # Data is stored in the session but user is untouched + assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + + # STEP 3 + response = client.get(self.step_3_url) + assertContains(response, "Niveau de formation") + + post_data = { + "education_level": EducationLevel.BAC_LEVEL.value, + } + response = client.post(self.step_3_url, data=post_data) + assertRedirects(response, self.step_end_url, fetch_redirect_response=False) + + # Data is stored in the session but user & profiles are untouched + expected_job_seeker_session["profile"] = post_data | { + "pole_emploi_id": "", + "lack_of_pole_emploi_id_reason": LackOfPoleEmploiId.REASON_NOT_REGISTERED, + "resourceless": False, + "rqth_employee": False, + "oeth_employee": False, + "pole_emploi": False, + "pole_emploi_id_forgotten": "", + "pole_emploi_since": "", + "unemployed": False, + "unemployed_since": "", + "rsa_allocation": False, + "has_rsa_allocation": RSAAllocation.NO.value, + "rsa_allocation_since": "", + "ass_allocation": False, + "ass_allocation_since": "", + "aah_allocation": False, + "aah_allocation_since": "", + } + assert client.session[self.job_seeker_session_key] == expected_job_seeker_session + self.job_seeker.refresh_from_db() + + # If you go back to step 3, new data is shown + response = client.get(self.step_3_url) + assertContains(response, '', html=True) + + # Step END + response = client.get(self.step_end_url) + assertContains(response, "Formation de niveau BAC") + + previous_last_checked_at = self.job_seeker.last_checked_at + + response = client.post(self.step_end_url) + assertRedirects( + response, + reverse( + self.FINAL_REDIRECT_VIEW_NAME, + kwargs={"company_pk": self.company.pk, "job_seeker_public_id": self.job_seeker.public_id}, + ), + fetch_redirect_response=False, + ) + assert client.session.get(self.job_seeker_session_key) is None + + self.job_seeker.refresh_from_db() + assert self.job_seeker.has_jobseeker_profile is True + assert self.job_seeker.jobseeker_profile.education_level == EducationLevel.BAC_LEVEL + assert self.job_seeker.last_checked_at != previous_last_checked_at + class TestUpdateJobSeeker(UpdateJobSeekerTestMixin): - TUNNEL = "apply" + STEP_1_VIEW_NAME = "job_seekers_views:update_job_seeker_step_1" + STEP_2_VIEW_NAME = "job_seekers_views:update_job_seeker_step_2" + STEP_3_VIEW_NAME = "job_seekers_views:update_job_seeker_step_3" + STEP_END_VIEW_NAME = "job_seekers_views:update_job_seeker_step_end" FINAL_REDIRECT_VIEW_NAME = "apply:application_jobs" def test_anonymous_start(self, client): response = client.get(self.start_url) assertRedirects(response, add_url_params(reverse("account_login"), {"next": self.start_url})) + # TODO(ewen): deprecated + def test_anonymous_step_1(self, client): + response = client.get(self.step_1_url) + assertRedirects(response, reverse("account_login") + f"?next={self.step_1_url}") + + def test_anonymous_step_2(self, client): + response = client.get(self.step_2_url) + assertRedirects(response, reverse("account_login") + f"?next={self.step_2_url}") + + def test_anonymous_step_3(self, client): + response = client.get(self.step_3_url) + assertRedirects(response, reverse("account_login") + f"?next={self.step_3_url}") + + def test_anonymous_step_end(self, client): + response = client.get(self.step_end_url) + assertRedirects(response, reverse("account_login") + f"?next={self.step_end_url}") + def test_as_job_seeker(self, client): self._check_nothing_permitted(client, self.job_seeker) + self._check_nothing_permitted_deprecated(client, self.job_seeker) def test_as_unauthorized_prescriber(self, client): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() self._check_nothing_permitted(client, prescriber) + self._check_nothing_permitted_deprecated(client, prescriber) def test_as_unauthorized_prescriber_that_created_proxied_job_seeker(self, client, snapshot): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() @@ -3826,6 +4163,25 @@ def test_as_unauthorized_prescriber_that_created_proxied_job_seeker(self, client }, ) + def test_as_unauthorized_prescriber_that_created_proxied_job_seeker_deprecated(self, client, snapshot): + prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() + self.job_seeker.created_by = prescriber + self.job_seeker.last_login = None + self.job_seeker.save(update_fields=["created_by", "last_login"]) + + geispolsheim = create_city_geispolsheim() + birthdate = self.job_seeker.jobseeker_profile.birthdate + + self._check_everything_allowed_deprecated( + client, + snapshot, + prescriber, + extra_post_data_1={ + "birth_place": Commune.objects.by_insee_code_and_period(geispolsheim.code_insee, birthdate).id, + "birth_country": Country.france_id, + }, + ) + def test_as_unauthorized_prescriber_that_created_the_non_proxied_job_seeker(self, client): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() self.job_seeker.created_by = prescriber @@ -3833,6 +4189,7 @@ def test_as_unauthorized_prescriber_that_created_the_non_proxied_job_seeker(self self.job_seeker.last_login = timezone.now() - relativedelta(months=1) self.job_seeker.save(update_fields=["created_by", "last_login"]) self._check_nothing_permitted(client, prescriber) + self._check_nothing_permitted_deprecated(client, prescriber) def test_as_authorized_prescriber_with_proxied_job_seeker(self, client, snapshot): # Make sure the job seeker does not manage its own account @@ -3854,12 +4211,33 @@ def test_as_authorized_prescriber_with_proxied_job_seeker(self, client, snapshot }, ) + def test_as_authorized_prescriber_with_proxied_job_seeker_deprecated(self, client, snapshot): + # Make sure the job seeker does not manage its own account + self.job_seeker.created_by = PrescriberFactory() + self.job_seeker.last_login = None + self.job_seeker.save(update_fields=["created_by", "last_login"]) + authorized_prescriber = PrescriberOrganizationWithMembershipFactory(authorized=True).members.first() + + geispolsheim = create_city_geispolsheim() + birthdate = self.job_seeker.jobseeker_profile.birthdate + + self._check_everything_allowed_deprecated( + client, + snapshot, + authorized_prescriber, + extra_post_data_1={ + "birth_place": Commune.objects.by_insee_code_and_period(geispolsheim.code_insee, birthdate).id, + "birth_country": Country.france_id, + }, + ) + def test_as_authorized_prescriber_with_non_proxied_job_seeker(self, client): # Make sure the job seeker does manage its own account self.job_seeker.last_login = timezone.now() - relativedelta(months=1) self.job_seeker.save(update_fields=["last_login"]) authorized_prescriber = PrescriberOrganizationWithMembershipFactory(authorized=True).members.first() self._check_only_administrative_allowed(client, authorized_prescriber) + self._check_only_administrative_allowed_deprecated(client, authorized_prescriber) def test_as_company_with_proxied_job_seeker(self, client, snapshot): # Make sure the job seeker does not manage its own account @@ -3880,11 +4258,31 @@ def test_as_company_with_proxied_job_seeker(self, client, snapshot): }, ) + def test_as_company_with_proxied_job_seeker_deprecated(self, client, snapshot): + # Make sure the job seeker does not manage its own account + self.job_seeker.created_by = EmployerFactory() + self.job_seeker.last_login = None + self.job_seeker.save(update_fields=["created_by", "last_login"]) + + geispolsheim = create_city_geispolsheim() + birthdate = self.job_seeker.jobseeker_profile.birthdate + + self._check_everything_allowed_deprecated( + client, + snapshot, + self.company.members.first(), + extra_post_data_1={ + "birth_place": Commune.objects.by_insee_code_and_period(geispolsheim.code_insee, birthdate).id, + "birth_country": Country.france_id, + }, + ) + def test_as_company_with_non_proxied_job_seeker(self, client): # Make sure the job seeker does manage its own account self.job_seeker.last_login = timezone.now() - relativedelta(months=1) self.job_seeker.save(update_fields=["last_login"]) self._check_only_administrative_allowed(client, self.company.members.first()) + self._check_only_administrative_allowed_deprecated(client, self.company.members.first()) def test_with_invalid_job_seeker_session(self, client): client.force_login(self.company.members.first()) @@ -3899,6 +4297,15 @@ def test_with_invalid_job_seeker_session(self, client): response = client.get(url) assert response.status_code == 404 + # TODO(ewen): deprecated + for url in [ + self.step_2_url, + self.step_3_url, + self.step_end_url, + ]: + response = client.get(url) + assert response.status_code == 403 + def test_with_job_seeker_without_nir(self, client, snapshot): # Make sure the job seeker does not manage its own account (and has no nir) self.job_seeker.jobseeker_profile.nir = "" @@ -3927,28 +4334,79 @@ def test_with_job_seeker_without_nir(self, client, snapshot): # Check that we could update its NIR infos assert self.job_seeker.jobseeker_profile.lack_of_nir_reason == LackOfNIRReason.TEMPORARY_NUMBER + def test_with_job_seeker_without_nir_deprecated(self, client, snapshot): + # Make sure the job seeker does not manage its own account (and has no nir) + self.job_seeker.jobseeker_profile.nir = "" + self.job_seeker.jobseeker_profile.lack_of_nir_reason = "" + self.job_seeker.jobseeker_profile.save(update_fields=["nir", "lack_of_nir_reason"]) + + self.job_seeker.created_by = EmployerFactory() + self.job_seeker.last_login = None + self.job_seeker.save(update_fields=["created_by", "last_login"]) + + geispolsheim = create_city_geispolsheim() + birthdate = self.job_seeker.jobseeker_profile.birthdate + + self._check_everything_allowed_deprecated( + client, + snapshot, + self.company.members.first(), + extra_post_data_1={ + "nir": "", + "lack_of_nir": True, + "lack_of_nir_reason": LackOfNIRReason.TEMPORARY_NUMBER.value, + "birth_place": Commune.objects.by_insee_code_and_period(geispolsheim.code_insee, birthdate).id, + "birth_country": Country.france_id, + }, + ) + # Check that we could update its NIR infos + assert self.job_seeker.jobseeker_profile.lack_of_nir_reason == LackOfNIRReason.TEMPORARY_NUMBER + def test_as_company_that_last_step_doesnt_crash_with_direct_access(self, client): # Make sure the job seeker does not manage its own account self.job_seeker.created_by = EmployerFactory() self.job_seeker.last_login = None self.job_seeker.save(update_fields=["created_by", "last_login"]) self._check_that_last_step_doesnt_crash_with_direct_access(client, self.company.members.first()) + self._check_that_last_step_doesnt_crash_with_direct_access_deprecated(client, self.company.members.first()) class TestUpdateJobSeekerForHire(UpdateJobSeekerTestMixin): - TUNNEL = "hire" + STEP_1_VIEW_NAME = "job_seekers_views:update_job_seeker_step_1_for_hire" + STEP_2_VIEW_NAME = "job_seekers_views:update_job_seeker_step_2_for_hire" + STEP_3_VIEW_NAME = "job_seekers_views:update_job_seeker_step_3_for_hire" + STEP_END_VIEW_NAME = "job_seekers_views:update_job_seeker_step_end_for_hire" FINAL_REDIRECT_VIEW_NAME = "job_seekers_views:check_job_seeker_info_for_hire" def test_anonymous_start(self, client): response = client.get(self.start_url) assertRedirects(response, add_url_params(reverse("account_login"), {"next": self.start_url})) + # TODO(ewen): deprecated + def test_anonymous_step_1(self, client): + response = client.get(self.step_1_url) + assertRedirects(response, reverse("account_login") + f"?next={self.step_1_url}") + + def test_anonymous_step_2(self, client): + response = client.get(self.step_2_url) + assertRedirects(response, reverse("account_login") + f"?next={self.step_2_url}") + + def test_anonymous_step_3(self, client): + response = client.get(self.step_3_url) + assertRedirects(response, reverse("account_login") + f"?next={self.step_3_url}") + + def test_anonymous_step_end(self, client): + response = client.get(self.step_end_url) + assertRedirects(response, reverse("account_login") + f"?next={self.step_end_url}") + def test_as_job_seeker(self, client): self._check_nothing_permitted(client, self.job_seeker) + self._check_nothing_permitted_deprecated(client, self.job_seeker) def test_as_unauthorized_prescriber(self, client): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() self._check_nothing_permitted(client, prescriber) + self._check_nothing_permitted_deprecated(client, prescriber) def test_as_unauthorized_prescriber_that_created_proxied_job_seeker(self, client, snapshot): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() @@ -3968,6 +4426,7 @@ def test_as_unauthorized_prescriber_that_created_proxied_job_seeker(self, client "birth_country": Country.france_id, }, ) + self._check_nothing_permitted_deprecated(client, prescriber) def test_as_unauthorized_prescriber_that_created_the_non_proxied_job_seeker(self, client): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() @@ -3976,6 +4435,7 @@ def test_as_unauthorized_prescriber_that_created_the_non_proxied_job_seeker(self self.job_seeker.last_login = timezone.now() - relativedelta(months=1) self.job_seeker.save(update_fields=["created_by", "last_login"]) self._check_nothing_permitted(client, prescriber) + self._check_nothing_permitted_deprecated(client, prescriber) def test_as_authorized_prescriber_with_proxied_job_seeker(self, client, snapshot): # Make sure the job seeker does not manage its own account @@ -3996,6 +4456,7 @@ def test_as_authorized_prescriber_with_proxied_job_seeker(self, client, snapshot "birth_country": Country.france_id, }, ) + self._check_nothing_permitted_deprecated(client, authorized_prescriber) def test_as_authorized_prescriber_with_non_proxied_job_seeker(self, client): # Make sure the job seeker does manage its own account @@ -4003,6 +4464,7 @@ def test_as_authorized_prescriber_with_non_proxied_job_seeker(self, client): self.job_seeker.save(update_fields=["last_login"]) authorized_prescriber = PrescriberOrganizationWithMembershipFactory(authorized=True).members.first() self._check_only_administrative_allowed(client, authorized_prescriber) + self._check_nothing_permitted_deprecated(client, authorized_prescriber) def test_as_company_with_proxied_job_seeker(self, client, snapshot): # Make sure the job seeker does not manage its own account @@ -4023,11 +4485,31 @@ def test_as_company_with_proxied_job_seeker(self, client, snapshot): }, ) + def test_as_company_with_proxied_job_seeker_deprecated(self, client, snapshot): + # Make sure the job seeker does not manage its own account + self.job_seeker.created_by = EmployerFactory() + self.job_seeker.last_login = None + self.job_seeker.save(update_fields=["created_by", "last_login"]) + + geispolsheim = create_city_geispolsheim() + birthdate = self.job_seeker.jobseeker_profile.birthdate + + self._check_everything_allowed_deprecated( + client, + snapshot, + self.company.members.first(), + extra_post_data_1={ + "birth_place": Commune.objects.by_insee_code_and_period(geispolsheim.code_insee, birthdate).id, + "birth_country": Country.france_id, + }, + ) + def test_as_company_with_non_proxied_job_seeker(self, client): # Make sure the job seeker does manage its own account self.job_seeker.last_login = timezone.now() - relativedelta(months=1) self.job_seeker.save(update_fields=["last_login"]) self._check_only_administrative_allowed(client, self.company.members.first()) + self._check_only_administrative_allowed_deprecated(client, self.company.members.first()) def test_with_invalid_job_seeker_session(self, client): client.force_login(self.company.members.first()) @@ -4042,6 +4524,15 @@ def test_with_invalid_job_seeker_session(self, client): response = client.get(url) assert response.status_code == 404 + # TODO(ewen): deprecated + for url in [ + self.step_2_url, + self.step_3_url, + self.step_end_url, + ]: + response = client.get(url) + assert response.status_code == 403 + def test_with_job_seeker_without_nir(self, client, snapshot): # Make sure the job seeker does not manage its own account (and has no nir) self.job_seeker.jobseeker_profile.nir = "" @@ -4070,12 +4561,41 @@ def test_with_job_seeker_without_nir(self, client, snapshot): # Check that we could update its NIR infos assert self.job_seeker.jobseeker_profile.lack_of_nir_reason == LackOfNIRReason.TEMPORARY_NUMBER + def test_with_job_seeker_without_nir_deprecated(self, client, snapshot): + # Make sure the job seeker does not manage its own account (and has no nir) + self.job_seeker.jobseeker_profile.nir = "" + self.job_seeker.jobseeker_profile.lack_of_nir_reason = "" + self.job_seeker.jobseeker_profile.save(update_fields=["nir", "lack_of_nir_reason"]) + + self.job_seeker.created_by = EmployerFactory() + self.job_seeker.last_login = None + self.job_seeker.save(update_fields=["created_by", "last_login"]) + + geispolsheim = create_city_geispolsheim() + birthdate = self.job_seeker.jobseeker_profile.birthdate + + self._check_everything_allowed_deprecated( + client, + snapshot, + self.company.members.first(), + extra_post_data_1={ + "nir": "", + "lack_of_nir": True, + "lack_of_nir_reason": LackOfNIRReason.TEMPORARY_NUMBER.value, + "birth_place": Commune.objects.by_insee_code_and_period(geispolsheim.code_insee, birthdate).id, + "birth_country": Country.france_id, + }, + ) + # Check that we could update its NIR infos + assert self.job_seeker.jobseeker_profile.lack_of_nir_reason == LackOfNIRReason.TEMPORARY_NUMBER + def test_as_company_that_last_step_doesnt_crash_with_direct_access(self, client): # Make sure the job seeker does not manage its own account self.job_seeker.created_by = EmployerFactory() self.job_seeker.last_login = None self.job_seeker.save(update_fields=["created_by", "last_login"]) self._check_that_last_step_doesnt_crash_with_direct_access(client, self.company.members.first()) + self._check_that_last_step_doesnt_crash_with_direct_access_deprecated(client, self.company.members.first()) class TestUpdateJobSeekerStep3View: @@ -4117,6 +4637,29 @@ def test_job_seeker_with_profile_has_check_boxes_ticked_in_step3(self, client): html=True, ) + # TODO(ewen): Deprecated + # STEP 1 to setup jobseeker session + response = client.get( + reverse( + "job_seekers_views:update_job_seeker_step_1", + kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, + ) + ) + assert response.status_code == 200 + + # Go straight to STEP 3 + response = client.get( + reverse( + "job_seekers_views:update_job_seeker_step_3", + kwargs={"company_pk": company.pk, "job_seeker_public_id": job_seeker.public_id}, + ) + ) + assertContains( + response, + '', + html=True, + ) + @pytest.mark.ignore_unknown_variable_template_error("confirmation_needed", "job_seeker") def test_detect_existing_job_seeker(client): From f4446b0107d1922524045d6bcd3df4969a350b17 Mon Sep 17 00:00:00 2001 From: Ewen Corre Date: Mon, 6 Jan 2025 15:52:12 +0100 Subject: [PATCH 4/5] job_seekers_views: ensure we perform the action the session was created for When initializing the job_seeker_session, we set a `tunnel` key to determine which action will be performed in the job_seekers_views block with that session (here, `job-seeker-update`). This is to prevent a (malicious) user from playing with session, and using a session that was not intended for updating a job seeker to do so. --- itou/www/job_seekers_views/views.py | 14 +++++++++- tests/www/apply/test_submit.py | 2 +- .../test_create_or_update.py | 26 +++++++++++++++++++ 3 files changed, 40 insertions(+), 2 deletions(-) diff --git a/itou/www/job_seekers_views/views.py b/itou/www/job_seekers_views/views.py index a116523d9c..c5f3f9a862 100644 --- a/itou/www/job_seekers_views/views.py +++ b/itou/www/job_seekers_views/views.py @@ -185,6 +185,8 @@ def get_queryset(self): class JobSeekerBaseView(TemplateView): + EXPECTED_SESSION_KIND = None + def __init__(self): super().__init__() self.company = None @@ -198,6 +200,11 @@ def setup(self, request, *args, session_uuid, hire_process=False, **kwargs): self.job_seeker_session = SessionNamespace(request.session, session_uuid) if not self.job_seeker_session.exists(): raise Http404 + # Ensure we are performing the action (update, create…) the session was created for. + if ( + session_kind := self.job_seeker_session.get("config").get("session_kind") + ) and session_kind != self.EXPECTED_SESSION_KIND: + raise Http404 self.is_gps = "gps" in request.GET and request.GET["gps"] == "true" if company_pk := self.job_seeker_session.get("apply", {}).get("company_pk"): self.company = ( @@ -269,6 +276,7 @@ def dispatch(self, request, *args, **kwargs): class CheckNIRForJobSeekerView(JobSeekerBaseView): template_name = "job_seekers_views/step_check_job_seeker_nir.html" + EXPECTED_SESSION_KIND = "job-seeker-get-or-create-job-seeker" def __init__(self): super().__init__() @@ -328,6 +336,7 @@ def get_context_data(self, **kwargs): class CheckNIRForSenderView(JobSeekerForSenderBaseView): template_name = "job_seekers_views/step_check_job_seeker_nir.html" + EXPECTED_SESSION_KIND = "job-seeker-get-or-create-sender" def __init__(self): super().__init__() @@ -779,7 +788,7 @@ def setup(self, request, *args, **kwargs): self.job_seeker_session = SessionNamespace.create_uuid_namespace( request.session, data={ - "config": {"from_url": from_url}, + "config": {"from_url": from_url, "session_kind": "job-seeker-update"}, "job_seeker_pk": job_seeker.pk, "apply": {"company_pk": company.pk}, }, @@ -794,6 +803,8 @@ def get(self, request, *args, **kwargs): class UpdateJobSeekerBaseView(JobSeekerBaseView): + EXPECTED_SESSION_KIND = "job-seeker-update" + def __init__(self): super().__init__() self.job_seeker_session = None @@ -803,6 +814,7 @@ def get_job_seeker_queryset(self): def setup(self, request, *args, **kwargs): super().setup(request, *args, **kwargs) + self.job_seeker = get_object_or_404( self.get_job_seeker_queryset(), pk=self.job_seeker_session.get("job_seeker_pk") ) diff --git a/tests/www/apply/test_submit.py b/tests/www/apply/test_submit.py index 75b80756dd..81bc5b8a3b 100644 --- a/tests/www/apply/test_submit.py +++ b/tests/www/apply/test_submit.py @@ -3480,7 +3480,7 @@ def setup_method(self, settings, mocker): ) self.config = { "apply": {"company_pk": self.company.pk}, - "config": {"from_url": from_url}, + "config": {"from_url": from_url, "session_kind": "job-seeker-update"}, "job_seeker_pk": self.job_seeker.pk, } self.step_1_url = reverse( diff --git a/tests/www/job_seekers_views/test_create_or_update.py b/tests/www/job_seekers_views/test_create_or_update.py index 35f390ebfe..65ba8be4bb 100644 --- a/tests/www/job_seekers_views/test_create_or_update.py +++ b/tests/www/job_seekers_views/test_create_or_update.py @@ -7,8 +7,10 @@ from itou.asp.models import Commune, Country from itou.users.enums import Title +from itou.utils.session import SessionNamespace from itou.utils.urls import add_url_params from tests.companies.factories import CompanyFactory +from tests.prescribers.factories import PrescriberOrganizationWithMembershipFactory from tests.users.factories import JobSeekerFactory from tests.utils.test import KNOWN_SESSION_KEYS @@ -190,6 +192,30 @@ def test_birth_country_france_and_no_birthplace(self, client): ) +class TestUpdateJobSeeker: + def test_update_with_wrong_tunnel_in_session(self, client): + job_seeker = JobSeekerFactory() + company = CompanyFactory(with_membership=True) + prescriber = PrescriberOrganizationWithMembershipFactory(authorized=True).members.first() + client.force_login(prescriber) + + # Create a session with a wrong tunnel key + job_seeker_session = SessionNamespace.create_uuid_namespace( + client.session, + data={ + "config": {"from_url": reverse("dashboard:index"), "session_kind": "job-seeker-get-or-create-sender"}, + "job_seeker_pk": job_seeker.pk, + "apply": {"company_pk": company.pk}, + }, + ) + job_seeker_session.save() + + url = reverse("job_seekers_views:update_job_seeker_step_1", kwargs={"session_uuid": job_seeker_session.name}) + response = client.get(url) + + assert response.status_code == 404 + + class TestUpdateJobSeekerStart: def test_update_start_with_valid_parameters(self, client): job_seeker = JobSeekerFactory() From d7140a110013f673b1a9d0039a956d3c60207b2b Mon Sep 17 00:00:00 2001 From: Ewen Corre Date: Wed, 8 Jan 2025 10:34:00 +0100 Subject: [PATCH 5/5] Remove useless .is_authenticated Since #5178, views are *protected* by default. --- itou/www/apply/views/submit_views.py | 2 +- itou/www/job_seekers_views/views.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/itou/www/apply/views/submit_views.py b/itou/www/apply/views/submit_views.py index 393f6e8ba6..6ff1f98b99 100644 --- a/itou/www/apply/views/submit_views.py +++ b/itou/www/apply/views/submit_views.py @@ -227,7 +227,7 @@ def setup(self, request, *args, **kwargs): self.sender = request.user def dispatch(self, request, *args, **kwargs): - if self.sender.is_authenticated and self.sender.kind not in [UserKind.PRESCRIBER, UserKind.EMPLOYER]: + if self.sender.kind not in [UserKind.PRESCRIBER, UserKind.EMPLOYER]: logger.info(f"dispatch ({request.path}) : {self.sender.kind} in sender tunnel") return HttpResponseRedirect(reverse("apply:start", kwargs={"company_pk": self.company.pk})) return super().dispatch(request, *args, **kwargs) diff --git a/itou/www/job_seekers_views/views.py b/itou/www/job_seekers_views/views.py index c5f3f9a862..3a8102132e 100644 --- a/itou/www/job_seekers_views/views.py +++ b/itou/www/job_seekers_views/views.py @@ -268,7 +268,7 @@ def setup(self, request, *args, **kwargs): self.sender = request.user def dispatch(self, request, *args, **kwargs): - if self.sender.is_authenticated and self.sender.kind not in [UserKind.PRESCRIBER, UserKind.EMPLOYER]: + if self.sender.kind not in [UserKind.PRESCRIBER, UserKind.EMPLOYER]: logger.info(f"dispatch ({request.path}) : {self.sender.kind} in sender tunnel") return HttpResponseRedirect(reverse("apply:start", kwargs={"company_pk": self.company.pk})) return super().dispatch(request, *args, **kwargs)