From 9353a89cbc6c70e581aa1b2bc562a4e205ba0c88 Mon Sep 17 00:00:00 2001 From: Antoine Augusti Date: Tue, 10 Dec 2024 14:43:21 +0100 Subject: [PATCH] NewDatagouvDatasetsJob : recherche pour ZFE et gestion accents --- .../lib/jobs/new_datagouv_datasets_job.ex | 31 +++++++++++++------ .../jobs/new_datagouv_datasets_job_test.exs | 3 ++ 2 files changed, 24 insertions(+), 10 deletions(-) diff --git a/apps/transport/lib/jobs/new_datagouv_datasets_job.ex b/apps/transport/lib/jobs/new_datagouv_datasets_job.ex index 7fd762161f..80782e52dd 100644 --- a/apps/transport/lib/jobs/new_datagouv_datasets_job.ex +++ b/apps/transport/lib/jobs/new_datagouv_datasets_job.ex @@ -15,12 +15,10 @@ defmodule Transport.Jobs.NewDatagouvDatasetsJob do tags: MapSet.new([ "bus", - "deplacements", + "déplacement", "déplacements", "horaires", - "mobilite", "mobilité", - "temps-reel", "temps-réel", "transport", "transports" @@ -53,13 +51,13 @@ defmodule Transport.Jobs.NewDatagouvDatasetsJob do "etalab/schema-comptage-mobilites-measure", "etalab/schema-comptage-mobilites-site" ], - tags: MapSet.new(["cyclable", "parking", "stationnement", "velo", "vélo"]), + tags: MapSet.new(["cyclable", "parking", "stationnement", "vélo"]), formats: MapSet.new([]) }, %{ category: "Covoiturage et ZFE", schemas: ["etalab/schema-lieux-covoiturage", "etalab/schema-zfe"], - tags: MapSet.new(["covoiturage", "zfe"]), + tags: MapSet.new(["covoiturage", "zfe", "zfe-m", "zone à faible émission"]), formats: MapSet.new([]) }, %{ @@ -71,8 +69,7 @@ defmodule Transport.Jobs.NewDatagouvDatasetsJob do "borne de recharge", "irve", "sdirve", - "électrique", - "electrique" + "électrique" ]), formats: MapSet.new([]) } @@ -223,12 +220,12 @@ defmodule Transport.Jobs.NewDatagouvDatasetsJob do defp string_matches?(nil, _rule), do: false defp string_matches?(str, %{formats: formats, tags: tags} = _rule) when is_binary(str) do - searches = MapSet.union(formats, tags) |> MapSet.to_list() - str |> String.downcase() |> String.contains?(searches) + searches = MapSet.union(formats, tags) |> MapSet.to_list() |> Enum.map(&normalize/1) + str |> normalize() |> String.contains?(searches) end defp tags_is_relevant?(%{"tags" => tags} = _dataset, rule) do - tags |> Enum.map(&string_matches?(String.downcase(&1), rule)) |> Enum.any?() + tags |> Enum.map(&string_matches?(&1, rule)) |> Enum.any?() end defp resource_is_relevant?(%{} = resource, rule) do @@ -250,4 +247,18 @@ defmodule Transport.Jobs.NewDatagouvDatasetsJob do end defp resource_schema_is_relevant?(%{}, _rule), do: false + + @doc """ + Clean up a string, lowercase it and replace accented letters with ASCII letters. + + iex> normalize("Paris") + "paris" + iex> normalize("vélo") + "velo" + iex> normalize("Châteauroux") + "chateauroux" + """ + def normalize(value) do + value |> String.normalize(:nfd) |> String.replace(~r/[^A-z]/u, "") |> String.downcase() + end end diff --git a/apps/transport/test/transport/jobs/new_datagouv_datasets_job_test.exs b/apps/transport/test/transport/jobs/new_datagouv_datasets_job_test.exs index 74ef6facb0..e8e75f37d4 100644 --- a/apps/transport/test/transport/jobs/new_datagouv_datasets_job_test.exs +++ b/apps/transport/test/transport/jobs/new_datagouv_datasets_job_test.exs @@ -36,6 +36,9 @@ defmodule Transport.Test.Transport.Jobs.NewDatagouvDatasetsJobTest do assert %{category: "Transport en commun"} = relevant_fn.(%{base | "description" => "GTFS de Dijon"}) assert %{category: "Transport en commun"} = relevant_fn.(%{base | "tags" => [Ecto.UUID.generate(), "gtfs"]}) + assert %{category: "Covoiturage et ZFE"} = + relevant_fn.(%{base | "description" => "Périmètre de la Zone à Faible Émission (ZFE) de Dijon Métropole."}) + assert %{category: "Freefloating"} = relevant_fn.(%{ base