Merge pull request #10259 from tchak/improuve-stats
fix(stats): more accurat stats about deleted dossiers
This commit is contained in:
commit
63052ea063
8 changed files with 38 additions and 17 deletions
|
@ -14,6 +14,6 @@ class Cron::Datagouv::FileByMonthJob < Cron::CronJob
|
||||||
end
|
end
|
||||||
|
|
||||||
def data
|
def data
|
||||||
Dossier.where(created_at: 1.month.ago.all_month).count
|
Dossier.visible_by_user_or_administration.where(created_at: 1.month.ago.all_month).count
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -14,6 +14,8 @@ class Cron::Datagouv::FileDeposeByMonthJob < Cron::CronJob
|
||||||
end
|
end
|
||||||
|
|
||||||
def data
|
def data
|
||||||
Dossier.where(depose_at: 1.month.ago.all_month).count
|
Dossier.visible_by_user_or_administration
|
||||||
|
.where(depose_at: 1.month.ago.all_month).count + DeletedDossier
|
||||||
|
.where(depose_at: 1.month.ago.all_month).count
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -36,6 +36,7 @@ class DeletedDossier < ApplicationRecord
|
||||||
user_id: dossier.user_id,
|
user_id: dossier.user_id,
|
||||||
procedure: dossier.procedure,
|
procedure: dossier.procedure,
|
||||||
state: dossier.state,
|
state: dossier.state,
|
||||||
|
depose_at: dossier.depose_at,
|
||||||
deleted_at: Time.zone.now
|
deleted_at: Time.zone.now
|
||||||
).create_or_find_by!(dossier_id: dossier.id)
|
).create_or_find_by!(dossier_id: dossier.id)
|
||||||
end
|
end
|
||||||
|
|
|
@ -14,11 +14,11 @@ class Stat < ApplicationRecord
|
||||||
dossiers_termines: states['termines'],
|
dossiers_termines: states['termines'],
|
||||||
dossiers_cumulative: cumulative_month_serie([
|
dossiers_cumulative: cumulative_month_serie([
|
||||||
[Dossier.state_not_brouillon, :depose_at],
|
[Dossier.state_not_brouillon, :depose_at],
|
||||||
[DeletedDossier.where.not(state: :brouillon), :deleted_at]
|
[DeletedDossier.where.not(state: :brouillon), :depose_at]
|
||||||
]),
|
]),
|
||||||
dossiers_in_the_last_4_months: last_four_months_serie([
|
dossiers_in_the_last_4_months: last_four_months_serie([
|
||||||
[Dossier.state_not_brouillon, :depose_at],
|
[Dossier.state_not_brouillon, :depose_at],
|
||||||
[DeletedDossier.where.not(state: :brouillon), :deleted_at]
|
[DeletedDossier.where.not(state: :brouillon), :depose_at]
|
||||||
]),
|
]),
|
||||||
administrations_partenaires: AdministrateursProcedure.joins(:procedure).merge(Procedure.publiees_ou_closes).select('distinct administrateur_id').count
|
administrations_partenaires: AdministrateursProcedure.joins(:procedure).merge(Procedure.publiees_ou_closes).select('distinct administrateur_id').count
|
||||||
)
|
)
|
||||||
|
@ -37,8 +37,7 @@ class Stat < ApplicationRecord
|
||||||
COUNT(*) FILTER ( WHERE state = 'en_instruction' ) AS "en_instruction",
|
COUNT(*) FILTER ( WHERE state = 'en_instruction' ) AS "en_instruction",
|
||||||
COUNT(*) FILTER ( WHERE state in ('accepte', 'refuse', 'sans_suite') ) AS "termines"
|
COUNT(*) FILTER ( WHERE state in ('accepte', 'refuse', 'sans_suite') ) AS "termines"
|
||||||
FROM dossiers
|
FROM dossiers
|
||||||
WHERE hidden_at IS NULL
|
WHERE revision_id NOT IN (SELECT r.id FROM procedure_revisions r LEFT JOIN procedures p ON r.procedure_id=p.id WHERE p.aasm_state = 'brouillon')
|
||||||
AND revision_id NOT IN (SELECT r.id FROM procedure_revisions r LEFT JOIN procedures p ON r.procedure_id=p.id WHERE p.aasm_state = 'brouillon')
|
|
||||||
EOF
|
EOF
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
@ -47,8 +46,8 @@ class Stat < ApplicationRecord
|
||||||
sanitize_and_exec(DeletedDossier, <<-EOF
|
sanitize_and_exec(DeletedDossier, <<-EOF
|
||||||
SELECT
|
SELECT
|
||||||
COUNT(*) AS "not_brouillon",
|
COUNT(*) AS "not_brouillon",
|
||||||
COUNT(*) FILTER ( WHERE deleted_at BETWEEN :one_month_ago AND :now ) AS "dossiers_depose_avant_30_jours",
|
COUNT(*) FILTER ( WHERE depose_at BETWEEN :one_month_ago AND :now ) AS "dossiers_depose_avant_30_jours",
|
||||||
COUNT(*) FILTER ( WHERE deleted_at BETWEEN :two_months_ago AND :one_month_ago ) AS "dossiers_deposes_entre_60_et_30_jours",
|
COUNT(*) FILTER ( WHERE depose_at BETWEEN :two_months_ago AND :one_month_ago ) AS "dossiers_deposes_entre_60_et_30_jours",
|
||||||
COUNT(*) FILTER ( WHERE state = 'en_construction' ) AS "en_construction",
|
COUNT(*) FILTER ( WHERE state = 'en_construction' ) AS "en_construction",
|
||||||
COUNT(*) FILTER ( WHERE state = 'en_instruction' ) AS "en_instruction",
|
COUNT(*) FILTER ( WHERE state = 'en_instruction' ) AS "en_instruction",
|
||||||
COUNT(*) FILTER ( WHERE state in ('accepte', 'refuse', 'sans_suite') ) AS "termines"
|
COUNT(*) FILTER ( WHERE state in ('accepte', 'refuse', 'sans_suite') ) AS "termines"
|
||||||
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Maintenance
|
||||||
|
class BackfillDeposeAtOnDeletedDossiersTask < MaintenanceTasks::Task
|
||||||
|
def collection
|
||||||
|
DeletedDossier.where(depose_at: nil)
|
||||||
|
end
|
||||||
|
|
||||||
|
def process(element)
|
||||||
|
element.update_column(:depose_at, element.deleted_at)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,5 @@
|
||||||
|
class AddDeposeAtToDeletedDossiers < ActiveRecord::Migration[7.0]
|
||||||
|
def change
|
||||||
|
add_column :deleted_dossiers, :depose_at, :date
|
||||||
|
end
|
||||||
|
end
|
|
@ -10,7 +10,7 @@
|
||||||
#
|
#
|
||||||
# It's strongly recommended that you check this file into your version control system.
|
# It's strongly recommended that you check this file into your version control system.
|
||||||
|
|
||||||
ActiveRecord::Schema[7.0].define(version: 2024_03_25_161743) do
|
ActiveRecord::Schema[7.0].define(version: 2024_04_02_212902) do
|
||||||
# These are extensions that must be enabled in order to support this database
|
# These are extensions that must be enabled in order to support this database
|
||||||
enable_extension "pg_buffercache"
|
enable_extension "pg_buffercache"
|
||||||
enable_extension "pg_stat_statements"
|
enable_extension "pg_stat_statements"
|
||||||
|
@ -359,6 +359,7 @@ ActiveRecord::Schema[7.0].define(version: 2024_03_25_161743) do
|
||||||
create_table "deleted_dossiers", force: :cascade do |t|
|
create_table "deleted_dossiers", force: :cascade do |t|
|
||||||
t.datetime "created_at", precision: nil, null: false
|
t.datetime "created_at", precision: nil, null: false
|
||||||
t.datetime "deleted_at", precision: nil
|
t.datetime "deleted_at", precision: nil
|
||||||
|
t.date "depose_at"
|
||||||
t.bigint "dossier_id"
|
t.bigint "dossier_id"
|
||||||
t.bigint "groupe_instructeur_id"
|
t.bigint "groupe_instructeur_id"
|
||||||
t.bigint "procedure_id"
|
t.bigint "procedure_id"
|
||||||
|
|
|
@ -2,14 +2,14 @@ describe Stat, type: :model do
|
||||||
describe '.deleted_dossiers_states' do
|
describe '.deleted_dossiers_states' do
|
||||||
subject { Stat.send(:deleted_dossiers_states) }
|
subject { Stat.send(:deleted_dossiers_states) }
|
||||||
it 'find counts for columns' do
|
it 'find counts for columns' do
|
||||||
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :accepte)
|
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :accepte, deleted_at: Time.zone.now, depose_at: Time.zone.now)
|
||||||
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :en_construction, deleted_at: 1.month.ago)
|
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :en_construction, deleted_at: 33.days.ago, depose_at: 33.days.ago)
|
||||||
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :en_construction, deleted_at: 2.months.ago)
|
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :en_construction, deleted_at: 66.days.ago, depose_at: 66.days.ago)
|
||||||
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :en_construction, deleted_at: 3.months.ago)
|
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :en_construction, deleted_at: 3.months.ago, depose_at: 3.months.ago)
|
||||||
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :en_instruction, deleted_at: 3.months.ago)
|
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :en_instruction, deleted_at: 3.months.ago, depose_at: 3.months.ago)
|
||||||
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :accepte, deleted_at: 3.months.ago)
|
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :accepte, deleted_at: 3.months.ago, depose_at: 3.months.ago)
|
||||||
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :refuse, deleted_at: 3.months.ago)
|
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :refuse, deleted_at: 3.months.ago, depose_at: 3.months.ago)
|
||||||
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :sans_suite, deleted_at: 3.months.ago)
|
create(:deleted_dossier, dossier_id: create(:dossier).id, state: :sans_suite, deleted_at: 3.months.ago, depose_at: 3.months.ago)
|
||||||
|
|
||||||
expect(subject["not_brouillon"]).to eq(8)
|
expect(subject["not_brouillon"]).to eq(8)
|
||||||
expect(subject["dossiers_depose_avant_30_jours"]).to eq(1)
|
expect(subject["dossiers_depose_avant_30_jours"]).to eq(1)
|
||||||
|
|
Loading…
Reference in a new issue