diff --git a/itou/www/job_seekers_views/urls.py b/itou/www/job_seekers_views/urls.py index 9a1d1d31345..40d3ba206f4 100644 --- a/itou/www/job_seekers_views/urls.py +++ b/itou/www/job_seekers_views/urls.py @@ -96,6 +96,31 @@ name="update_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(), @@ -129,6 +154,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 f9578f4865e..30789ca5ec1 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, @@ -1112,6 +1112,321 @@ 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_authenticated and ( + 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 request.user.is_authenticated: + # Do nothing, LoginRequiredMixin will raise in dispatch() + return + 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) + + session_pole_emploi_id = self.job_seeker_session.get("profile", {}).get("pole_emploi_id") + session_lack_of_pole_emploi_id_reason = self.job_seeker_session.get("profile", {}).get( + "lack_of_pole_emploi_id_reason" + ) + initial_form_data = self.job_seeker_session.get("profile", {}) | { + "pole_emploi_id": ( + session_pole_emploi_id + if session_pole_emploi_id is not None + else self.job_seeker.jobseeker_profile.pole_emploi_id + ), + "lack_of_pole_emploi_id_reason": ( + session_lack_of_pole_emploi_id_reason + if session_lack_of_pole_emploi_id_reason is not None + else self.job_seeker.jobseeker_profile.lack_of_pole_emploi_id_reason + ), + } + self.form = CreateOrUpdateJobSeekerStep3Form( + instance=self.job_seeker.jobseeker_profile if self.job_seeker.has_jobseeker_profile else None, + initial=initial_form_data, + 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 86d4ee39ffc..155c3a2696a 100644 --- a/tests/www/apply/__snapshots__/test_submit.ambr +++ b/tests/www/apply/__snapshots__/test_submit.ambr @@ -1779,9 +1779,9 @@ ]), }) # --- -# 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 2] dict({ - 'num_queries': 13, + 'num_queries': 8, 'queries': list([ dict({ 'origin': list([ @@ -1844,116 +1844,129 @@ '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([ + '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_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]', + '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", @@ -2005,8 +2018,34 @@ }), 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_authorized_prescriber_with_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", @@ -2040,130 +2079,232 @@ "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"."ata_allocation_since", - "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"."id" = %s) + WHERE "users_user"."id" = %s LIMIT 21 ''', }), dict({ 'origin': list([ - 'Atomic.__exit__[/django/db/transaction.py]', + 'ItouCurrentOrganizationMiddleware.__call__[utils/perms/middleware.py]', ]), - 'sql': 'RELEASE SAVEPOINT ""', + '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([ - '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]', + 'Atomic.__enter__[/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 U0."is_admin" - AND U2."is_active")) - AND "users_user"."id" = %s) - LIMIT 1 - ''', + 'sql': '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]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.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 + 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"."ata_allocation_since", + "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([ - 'Atomic.__enter__[/django/db/transaction.py]', - 'SessionStore.save[/django/contrib/sessions/backends/db.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]', + 'DeprecatedUpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.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([ - '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_as_company_with_proxied_job_seeker[queries - step 1] dict({ - 'num_queries': 9, + 'num_queries': 13, 'queries': list([ dict({ 'origin': list([ @@ -2333,9 +2474,9 @@ }), 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]', + '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", @@ -2387,8 +2528,8 @@ }), dict({ 'origin': list([ - '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]', ]), 'sql': ''' SELECT "users_user"."id", @@ -2422,13 +2563,44 @@ "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 - ''', - }), + "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"."ata_allocation_since", + "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]', @@ -2444,7 +2616,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_1.html]', ]), 'sql': ''' SELECT %s AS "a" @@ -2463,10 +2635,56 @@ 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 3] +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker[queries - step 2] dict({ 'num_queries': 9, 'queries': list([ @@ -2638,9 +2856,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]', + '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", @@ -2692,8 +2910,8 @@ }), 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]', ]), 'sql': ''' SELECT "users_user"."id", @@ -2727,39 +2945,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"."ata_allocation_since", - "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"."id" = %s) LIMIT 21 @@ -2780,7 +2967,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" @@ -2802,9 +2989,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': 9, 'queries': list([ dict({ 'origin': list([ @@ -2867,64 +3054,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([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.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", @@ -2964,25 +3112,116 @@ "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([ - 'UpdateJobSeekerStep1View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep1View.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", + '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", @@ -3049,26 +3288,6 @@ 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]', @@ -3077,56 +3296,38 @@ }), 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]', + '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 "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]', + 'ExtendsNode[job_seekers_views/create_or_update_job_seeker/step_3.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 2] +# name: TestUpdateJobSeeker.test_as_company_with_proxied_job_seeker_deprecated[queries - step 2] dict({ - 'num_queries': 8, + 'num_queries': 9, 'queries': list([ dict({ 'origin': list([ @@ -3189,64 +3390,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", @@ -3286,31 +3448,68 @@ "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([ - '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", + 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", @@ -3336,28 +3535,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({ @@ -3366,12 +3600,40 @@ ]), '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_as_company_with_proxied_job_seeker_deprecated[queries - step 3] dict({ - 'num_queries': 8, + 'num_queries': 9, 'queries': list([ dict({ 'origin': list([ @@ -3434,51 +3696,3472 @@ '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({ + '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"."ata_allocation_since", + "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 - step 1] + dict({ + 'num_queries': 12, + '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([ + '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"."ata_allocation_since", + "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': 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([ + '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': 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([ + '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"."ata_allocation_since", + "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([ + '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", + "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 ""', + }), + ]), + }) +# --- +# 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", + "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"."ata_allocation_since", + "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", + "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 ""', + }), + ]), + }) +# --- +# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[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([ + '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"."ata_allocation_since", + "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': 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([ + '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': 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([ + '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"."ata_allocation_since", + "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_with_job_seeker_without_nir_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_with_job_seeker_without_nir_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"."ata_allocation_since", + "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: 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([ + '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({ @@ -3489,9 +7172,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", @@ -3543,8 +7226,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", @@ -3618,36 +7301,110 @@ }), 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]', + 'Company.has_member[common_apps/organizations/models.py]', + 'UpdateJobSeekerStep1View.dispatch[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") + 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]', + ]), + '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 1] +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 2] dict({ - 'num_queries': 13, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -3817,9 +7574,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]', + '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", @@ -3871,8 +7628,8 @@ }), dict({ 'origin': list([ - '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]', ]), 'sql': ''' SELECT "users_user"."id", @@ -3906,44 +7663,33 @@ "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"."ata_allocation_since", - "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"."id" = %s) LIMIT 21 ''', }), + dict({ + 'origin': list([ + 'Company.has_member[common_apps/organizations/models.py]', + 'UpdateJobSeekerStep2View.dispatch[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 "users_user"."id" = %s) + LIMIT 1 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', @@ -3959,7 +7705,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" @@ -3978,58 +7724,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: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 2] +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker[queries - step 3] dict({ - 'num_queries': 9, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -4199,9 +7899,9 @@ }), 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]', + '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", @@ -4253,8 +7953,8 @@ }), dict({ 'origin': list([ - '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]', ]), 'sql': ''' SELECT "users_user"."id", @@ -4288,13 +7988,64 @@ "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"."ata_allocation_since", + "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([ + 'Company.has_member[common_apps/organizations/models.py]', + 'UpdateJobSeekerStep3View.dispatch[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 "users_user"."id" = %s) + LIMIT 1 + ''', + }), dict({ 'origin': list([ 'Atomic.__exit__[/django/db/transaction.py]', @@ -4310,7 +8061,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" @@ -4332,9 +8083,9 @@ ]), }) # --- -# name: TestUpdateJobSeeker.test_with_job_seeker_without_nir[queries - step 3] +# name: TestUpdateJobSeekerForHire.test_as_company_with_proxied_job_seeker_deprecated[queries - step 2] dict({ - 'num_queries': 9, + 'num_queries': 10, 'queries': list([ dict({ 'origin': list([ @@ -4504,9 +8255,54 @@ }), 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]', + '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", @@ -4558,77 +8354,22 @@ }), dict({ 'origin': list([ - 'UpdateJobSeekerStep3View.setup[www/job_seekers_views/views.py]', - 'UpdateJobSeekerStep3View.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", - "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"."ata_allocation_since", - "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" + SELECT %s AS "a" FROM "users_user" - LEFT OUTER JOIN "users_jobseekerprofile" ON ("users_user"."id" = "users_jobseekerprofile"."user_id") - 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({ @@ -4646,7 +8387,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" @@ -4668,9 +8409,9 @@ ]), }) # --- -# 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([ @@ -4840,62 +8581,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", @@ -4963,14 +8650,69 @@ 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]', - 'UpdateJobSeekerStep1View.dispatch[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.dispatch[www/apply/views/submit_views.py]', ]), 'sql': ''' SELECT %s AS "a" @@ -5002,7 +8744,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" @@ -5021,58 +8763,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_with_job_seeker_without_nir[queries - step 1] dict({ - 'num_queries': 10, + 'num_queries': 14, 'queries': list([ dict({ 'origin': list([ @@ -5242,9 +8938,9 @@ }), 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]', + '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", @@ -5296,8 +8992,8 @@ }), dict({ 'origin': list([ - '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]', ]), 'sql': ''' SELECT "users_user"."id", @@ -5331,8 +9027,39 @@ "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"."ata_allocation_since", + "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 @@ -5341,7 +9068,7 @@ dict({ 'origin': list([ 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep2View.dispatch[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep1View.dispatch[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" @@ -5373,7 +9100,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_1.html]', ]), 'sql': ''' SELECT %s AS "a" @@ -5392,10 +9119,56 @@ 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 3] +# name: TestUpdateJobSeekerForHire.test_with_job_seeker_without_nir[queries - step 2] dict({ 'num_queries': 10, 'queries': list([ @@ -5567,9 +9340,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]', + '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", @@ -5621,8 +9394,8 @@ }), 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]', ]), 'sql': ''' SELECT "users_user"."id", @@ -5656,39 +9429,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"."ata_allocation_since", - "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"."id" = %s) LIMIT 21 @@ -5697,7 +9439,7 @@ dict({ 'origin': list([ 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep3View.dispatch[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep2View.dispatch[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" @@ -5729,7 +9471,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" @@ -5751,9 +9493,9 @@ ]), }) # --- -# 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([ @@ -5923,9 +9665,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", @@ -5977,8 +9719,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", @@ -6053,7 +9795,7 @@ dict({ 'origin': list([ 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep1View.dispatch[www/job_seekers_views/views.py]', + 'UpdateJobSeekerStep3View.dispatch[www/job_seekers_views/views.py]', ]), 'sql': ''' SELECT %s AS "a" @@ -6085,7 +9827,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" @@ -6104,56 +9846,10 @@ 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_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([ @@ -6325,9 +10021,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", @@ -6377,54 +10118,10 @@ 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([ 'Company.has_member[common_apps/organizations/models.py]', - 'UpdateJobSeekerStep2View.dispatch[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep2View.dispatch[www/apply/views/submit_views.py]', ]), 'sql': ''' SELECT %s AS "a" @@ -6478,7 +10175,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([ @@ -6650,62 +10347,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", @@ -6773,14 +10416,69 @@ 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]', - 'UpdateJobSeekerStep3View.dispatch[www/job_seekers_views/views.py]', + 'DeprecatedUpdateJobSeekerStep3View.dispatch[www/apply/views/submit_views.py]', ]), 'sql': ''' SELECT %s AS "a" diff --git a/tests/www/apply/test_submit.py b/tests/www/apply/test_submit.py index 32807f8e7b6..9bf81657003 100644 --- a/tests/www/apply/test_submit.py +++ b/tests/www/apply/test_submit.py @@ -280,6 +280,11 @@ def test_404_when_trying_to_update_a_prescriber(self, client): response = client.get(url) assert response.status_code == 404 + # TODO(ewen): deprecated URL + 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() @@ -3569,9 +3574,26 @@ def setup_method(self, client, settings, mocker): ) self.job_seeker_session_key = job_seeker_session.name + self.step_1_url_deprecated = 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_deprecated = 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_deprecated = 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_deprecated = 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_deprecated = f"job_seeker-{self.job_seeker.public_id}" settings.API_BAN_BASE_URL = "http://ban-api" mocker.patch( @@ -3590,11 +3612,28 @@ def _check_nothing_permitted(self, client, user): response = client.get(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_deprecated, + self.step_2_url_deprecated, + self.step_3_url_deprecated, + self.step_end_url_deprecated, + ]: + 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.step_end_url) # no need to setup with step_1, 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_deprecated) # Setup job_seeker_session + client.get(self.step_end_url_deprecated) # Use partial job_seeker_session + def _check_everything_allowed(self, client, snapshot, user, extra_post_data_1=None): client.force_login(user) @@ -3782,6 +3821,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_deprecated) + 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_deprecated, 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_deprecated, 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_deprecated, data=post_data) + assertRedirects(response, self.step_2_url_deprecated, 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_deprecated] == 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_deprecated) + 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_deprecated) + 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_deprecated, data=post_data) + assertRedirects(response, self.step_3_url_deprecated, 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_deprecated] == 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_deprecated) + assertContains(response, NEW_ADDRESS_LINE) + + # STEP 3 + with assertSnapshotQueries(snapshot(name="queries - step 3")): + response = client.get(self.step_3_url_deprecated) + 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_deprecated, data=post_data) + assertRedirects(response, self.step_end_url_deprecated, 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_deprecated] == 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_deprecated) + assertContains(response, '', html=True) + + # Step END + response = client.get(self.step_end_url_deprecated) + 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_deprecated) + 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_deprecated) 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) @@ -3867,6 +4092,91 @@ 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_deprecated) + assertContains(response, self.job_seeker.first_name) + assertContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) + + response = client.post(self.step_1_url_deprecated) + assertRedirects(response, self.step_2_url_deprecated, fetch_redirect_response=False) + + # Session is created + expected_job_seeker_session = {"user": {}} + assert client.session[self.job_seeker_session_key_deprecated] == expected_job_seeker_session + + # STEP 2 + response = client.get(self.step_2_url_deprecated) + assertContains(response, self.job_seeker.phone) + assertContains(response, self.INFO_MODIFIABLE_PAR_CANDIDAT_UNIQUEMENT) + + response = client.post(self.step_2_url_deprecated) + assertRedirects(response, self.step_3_url_deprecated, fetch_redirect_response=False) + + # Data is stored in the session but user is untouched + assert client.session[self.job_seeker_session_key_deprecated] == expected_job_seeker_session + + # STEP 3 + response = client.get(self.step_3_url_deprecated) + assertContains(response, "Niveau de formation") + + post_data = { + "education_level": EducationLevel.BAC_LEVEL.value, + } + response = client.post(self.step_3_url_deprecated, data=post_data) + assertRedirects(response, self.step_end_url_deprecated, 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_deprecated] == 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_deprecated) + assertContains(response, '', html=True) + + # Step END + response = client.get(self.step_end_url_deprecated) + assertContains(response, "Formation de niveau BAC") + + previous_last_checked_at = self.job_seeker.last_checked_at + + response = client.post(self.step_end_url_deprecated) + 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_deprecated) 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): STEP_1_VIEW_NAME = "job_seekers_views:update_job_seeker_step_1" @@ -3878,25 +4188,35 @@ class TestUpdateJobSeeker(UpdateJobSeekerTestMixin): 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}") + response = client.get(self.step_1_url_deprecated) + assertRedirects(response, reverse("account_login") + f"?next={self.step_1_url_deprecated}") def test_anonymous_step_2(self, client): response = client.get(self.step_2_url) assert response.status_code == 302 # session isn't missing, but not logged in + response = client.get(self.step_2_url_deprecated) + assert response.status_code == 403 # because missing session def test_anonymous_step_3(self, client): response = client.get(self.step_3_url) assert response.status_code == 302 # session isn't missing, but not logged in + response = client.get(self.step_3_url_deprecated) + assert response.status_code == 403 # because missing session def test_anonymous_step_end(self, client): response = client.get(self.step_end_url) assert response.status_code == 302 # session isn't missing, but not logged in + response = client.get(self.step_end_url_deprecated) + assert response.status_code == 403 # because missing session 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() @@ -3917,6 +4237,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 @@ -3924,6 +4263,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 @@ -3945,12 +4285,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 @@ -3971,11 +4332,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_without_job_seeker_session(self, client): client.force_login(self.company.members.first()) @@ -3990,6 +4371,14 @@ def test_without_job_seeker_session(self, client): response = client.get(url) assert response.status_code == 404 + for url in [ + self.step_2_url_deprecated, + self.step_3_url_deprecated, + self.step_end_url_deprecated, + ]: + 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 = "" @@ -4018,6 +4407,34 @@ 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() @@ -4036,25 +4453,35 @@ class TestUpdateJobSeekerForHire(UpdateJobSeekerTestMixin): 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}") + response = client.get(self.step_1_url_deprecated) + assertRedirects(response, reverse("account_login") + f"?next={self.step_1_url_deprecated}") def test_anonymous_step_2(self, client): response = client.get(self.step_2_url) assert response.status_code == 302 # session isn't missing, but not logged in + response = client.get(self.step_2_url_deprecated) + assert response.status_code == 403 # because missing session def test_anonymous_step_3(self, client): response = client.get(self.step_3_url) assert response.status_code == 302 # session isn't missing, but not logged in + response = client.get(self.step_3_url_deprecated) + assert response.status_code == 403 # because missing session def test_anonymous_step_end(self, client): response = client.get(self.step_end_url) assert response.status_code == 302 # session isn't missing, but not logged in + response = client.get(self.step_end_url_deprecated) + assert response.status_code == 403 # because missing session 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): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() @@ -4062,6 +4489,7 @@ def test_as_unauthorized_prescriber_that_created_proxied_job_seeker(self, client self.job_seeker.last_login = None 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_unauthorized_prescriber_that_created_the_non_proxied_job_seeker(self, client): prescriber = PrescriberOrganizationWithMembershipFactory(authorized=False).members.first() @@ -4070,6 +4498,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): # Make sure the job seeker does not manage its own account @@ -4078,6 +4507,7 @@ def test_as_authorized_prescriber_with_proxied_job_seeker(self, client): self.job_seeker.save(update_fields=["created_by", "last_login"]) authorized_prescriber = PrescriberOrganizationWithMembershipFactory(authorized=True).members.first() self._check_nothing_permitted(client, authorized_prescriber) + 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 @@ -4085,6 +4515,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_nothing_permitted(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 @@ -4105,11 +4536,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_without_job_seeker_session(self, client): client.force_login(self.company.members.first()) @@ -4124,6 +4575,14 @@ def test_without_job_seeker_session(self, client): response = client.get(url) assert response.status_code == 404 + for url in [ + self.step_2_url_deprecated, + self.step_3_url_deprecated, + self.step_end_url_deprecated, + ]: + 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 = "" @@ -4152,12 +4611,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: @@ -4192,6 +4680,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):