GitLab-backed analysis

Adservio Code Review Analysis

A read-only analysis of recent merge request review behavior in GitLab, focused on visible review discussion, reviewer distribution, queue health, MR size, and traceability gaps.

Period: 2026-06-28 07:00 to 2026-07-05 07:00
Primary source: GitLab merge request metadata, notes, labels, commits, and approvals endpoints.

Bottom line: review throughput is not the main risk here; traceability and queue hygiene are. The team is still merging code, but most merges leave no durable visible review trail and the open queue is overwhelmingly stale.

What Matters

  • Traceability is the clearest control gap: 46 of 53 merged MRs (86.8%) showed no visible non-author review comment in GitLab.
  • `CR - Approved` is currently too weak as evidence on its own: 60.4% of merged MRs carried that label without any visible review discussion.
  • Queue health is poor: 77.3% of active open MRs are already older than 48 working hours. The oldest example is adservio/web!2091 at 251.5d open.
  • Visible review capacity is thin and concentrated: only 7 visible review touches were detected in the whole window, and the top 3 reviewers handled 57.1% of them.
  • adservio/frontend is the highest-volume review surface with 20 merged MRs and only 15.0% visible review coverage. adservio/web is the next meaningful flow at 16 merges and 6.2% visible review coverage.
  • MR size is not the main story: median changed files were 3, and only 20.8% of merged MRs were above 20 files. Even the slowest merged example, adservio/frontend!1837, took 28.9d with 21 changed files, so the dominant problem still looks like review discipline and queue ownership rather than consistently oversized MRs.

Leadership Analysis

  • The operating rhythm is serviceable at the median (21.7h created-to-merged), which means the biggest leverage is improving process fidelity rather than pushing for even more raw throughput.
  • With 77.3% of active MRs already stale, the open list is functioning more like inventory than prioritization support. adservio/web!2091 being open for 251.5d is a strong sign that ownership and review handoffs are not being actively reset.
  • The spread between a 3-file median MR and a 28.9d longest merged cycle (adservio/frontend!1837, 21 changed files) suggests a few ownership-heavy exceptions are dragging on outside normal flow. Those should be managed as explicit escalations, not left to age inside the common queue.

Recommended Actions

  • Make one durable review artifact mandatory before merge: a substantive non-author GitLab review comment, a recorded approval, or both. A label alone should no longer count as sufficient evidence. The approval API coverage is also low, so the fix should include tooling or policy that leaves an auditable trace by default.
  • Run a stale-MR reset on anything older than 48 working hours: close abandoned work, re-confirm owner and reviewer on the rest, and turn the open list back into a real queue instead of a parking lot. Start with adservio/web!2091 and the rest of the oldest backlog because their age now obscures whether they are still real priorities.
  • Put adservio/helm2 under explicit review guardrails for the next cycle. It combines enough volume with weak visible review coverage, which makes it the best place to tighten the process and see impact quickly.
  • Broaden the reviewer bench beyond Dragoș Ivan and the current small reviewer set. The present concentration is a continuity risk and will keep queue health fragile when one person is away.

Improvement Ideas

  • Set explicit operating standards for the next quarter: require one auditable peer-review artifact before merge, target first review inside one working day for active MRs, and keep the stale active backlog below 15%. What gets measured this clearly is far more likely to improve.
  • Run a four-week process experiment on adservio/helm2: dedicated reviewer-of-the-week coverage, explicit reviewer assignment at MR creation, and a lightweight weekly audit of silent merges. It is the highest-yield place to test whether better ownership changes the data.

Supporting Evidence

  • 46 of 53 merged MRs (86.8%) had no visible non-author review comment in GitLab.
  • 38 of 53 merged MRs (71.7%) carried the `CR - Approved` label.
  • 32 merged MRs (60.4%) were labeled `CR - Approved` without any visible non-author review comment.
  • 20.8% of merged MRs changed more than 20 files, while 9.4% changed more than 50 files.
  • Among MRs with visible review discussion, the median last-author-commit to first-review time was 16.7h.
  • The median last-author-commit to `CR - Approved` time was 41.7h.
  • The top 3 reviewers accounted for 57.1% of visible review touches.
  • 34 of 44 active open MRs (77.3%) were older than 48 working hours.
Merged MRs
Merged MRs inside the analysis window.
53
Open MRs
All currently open group MRs.
51
Active open MRs
Open MRs excluding drafts.
44
Draft open MRs
Open MRs marked draft/WIP.
7
Visible review rate
Merged MRs with at least one visible non-author GitLab comment.
13.2%
Merged without visible review comment
Merged MRs with zero visible non-author comments.
86.8%
CR - Approved label coverage
Merged MRs carrying the CR-approved label.
71.7%
Approval API coverage
Merged MRs with at least one approver in the GitLab approvals API.
13.2%
CR - Approved without visible review comment
CR-approved MRs with no visible non-author comment.
60.4%
Median MR created -> first review
Working time from MR creation to first visible non-author comment.
3.0d
Median last author commit -> first review
Working time from last author commit before review to first visible non-author comment.
16.7h
Median first review -> CR - Approved
Working time from first visible comment to CR-approved label after review start, else merge.
22.5h
Median MR created -> CR - Approved
Working time from MR creation to CR-approved label after review start, else merge.
4.9d
Median last author commit -> CR - Approved
Working time from last author commit before review to CR-approved label after review start, else merge.
41.7h
Median MR created -> merged
Working time from MR creation to merge.
21.7h
Median changed files
Median GitLab `changes_count` value.
3
MRs > 5 files
Merged MRs where `changes_count` is above 5.
35.8%
MRs > 10 files
Merged MRs where `changes_count` is above 10.
28.3%
MRs > 20 files
Merged MRs where `changes_count` is above 20.
20.8%
MRs > 50 files
Merged MRs where `changes_count` is above 50.
9.4%
Top 3 reviewer touch share
Share of visible review touches handled by the top 3 reviewers.
57.1%
Active open backlog rate
Non-draft open MRs older than 48 working hours.
77.3%

These headline timing medians bring back the anchor-to-anchor numbers directly, using working time with weekends excluded.

Median MR created -> first review3.0d
Median last author commit -> first review16.7h
Median MR created -> CR - Approved4.9d
Median first review -> CR - Approved22.5h
Median last author commit -> CR - Approved41.7h
Median MR created -> merged21.7h
Dragoș Ivan2728.6%
Ioana Ivan1414.3%
Andrei Dragan1114.3%
Alex Murarescu1914.3%
Andrei Alexandru1514.3%
Achim Stefan1514.3%
adservio/frontend2015.0%90.0%4.0
adservio/web166.2%81.2%2.0
adservio/helm260.0%0.0%2.0
adservio/admission/backend540.0%60.0%84
adservio/uni/backend250.0%50.0%20.5
adservio/billing/backend10.0%100.0%1
adservio/docgen2/backend10.0%100.0%2
adservio/services/backend-for-frontend10.0%0.0%5
adservio/social10.0%100.0%6

Visible Review Discussion MRs

Compact by default: key CR metrics stay visible, and each row expands inline for the full audit trail. The table starts sorted by Last Commit -> First Review.

Details
adservio/admission/backend!170[ADS-7430] - extend report functionality4/5 Strong2.4h1.3h45.1h
adservio/frontend!1887[S: ADS-7496] Situație școlară - Medii Examen finalizare4/5 Strong17.2d2.2h18.0d
adservio/frontend!1986[ADS-8131] - debounce faculty search/ loading states3/5 Solid3.0h3.0h3.9h
adservio/frontend!1938[ADS-7641]: Specializare/sectie asociata pe student4/5 Strong7.8d16.7h8.1d
adservio/admission/backend!165[ADS-8072] - finalize admission folder structure/names/cleanup4/5 Strong19.8h17.1h46.5h
adservio/uni/backend!212ADS-7641 Specializare/sectie asociata pe student4/5 Strong8.9d19.2h9.8d
adservio/web!2594[ADS-8008] cleanup legacy news3/5 Solid3.0d3.1d4.9d

No Visible Review Comment Audit

These merged MRs had no visible non-author GitLab comment under the current heuristic. Use this section to audit whether the gap is a real review-process issue or a GitLab traceability issue.

Total MRs46
With CR Label32
With Approval API5
  • Open the MR link and check the Overview tab for CR - Approved and any approval widget signal.
  • Check Activity / Discussions for real human reviewer comments.
  • If you only see system notes, merge notes, mentions, or bot activity, it stays in this audit set.
  • If you find a genuine reviewer comment from someone other than the author, treat that MR as a false positive of this heuristic.
full audit table (46 MRs). Click again to collapse.
adservio/social!32adservio/socialNews Guard RefactorAlex Murarescu2026-06-29Yes
adservio/admission/backend!166adservio/admission/backendadded faculty name to sessions tableGeorge Murgoci2026-06-29
adservio/frontend!1951adservio/frontend[ADS-8001]: Change studentID param format.Ioana Ivan2026-06-29Yes
adservio/web!2595adservio/web[ADS-8001]: Change studentID param format.Ioana Ivan2026-06-29Yes
adservio/web!2602adservio/web[ADS-7642]: Add DSS National InstitutionIoana Ivan2026-06-29YesYes
adservio/frontend!1961adservio/frontend[ADS-7642]: Add DSS National InstitutionIoana Ivan2026-06-29YesYes
adservio/web!2612adservio/web[S: ADS-7896] Migrare fisiere tuiasiCatalin Cojan2026-06-29Yes
adservio/frontend!1837adservio/frontend[ADS-7165]: Accommodations PaymentObligations responsivenessIuliana Gugeanu2026-06-30Yes
adservio/docgen2/backend!149adservio/docgen2/backend[ADS-8075] Procesul verbal de la sfarsitul catalogului PDF pentru clasele...Petronel Pavel2026-06-30Yes
adservio/web!2613adservio/web[ADS-7904]: Add filtering for only promoted students in reportsAndrei Dragan2026-06-30Yes
adservio/frontend!1969adservio/frontend[ADS-7904]: Top Students only promoted toggleDragoș Ivan2026-06-30Yes
adservio/admission/backend!167adservio/admission/backend[ADS-6980] Tracing & Error LoggingAlex Murarescu2026-06-30Yes
adservio/frontend!1968adservio/frontendDraft: [ADS-7497] Graduation moduleAchim Stefan2026-06-30Yes
adservio/web!2615adservio/web[ADS-7732] Tuiasi - fs errorMarian Andrei2026-07-01
adservio/frontend!1970adservio/frontend[ADS-8076] Nefunctionalitate filtru la statistici-promovabilitate mediiPetronel Pavel2026-07-01Yes
adservio/web!2616adservio/web[ADS-8094] Form builder layout is misaligned on /ro/teacher/forms/build_form/1216Petronel Pavel2026-07-01YesYes
adservio/frontend!1971adservio/frontend[ADS-8101] FE] - Eroare inregistrare plataEdgar Alexa2026-07-01Yes
adservio/frontend!1976adservio/frontend[ads-7767-translations] translations fixEdgar Alexa2026-07-01Yes
adservio/web!2582adservio/web[ADS-7641] UNI School config - departmentsIonut Ciolan2026-07-01YesYes
adservio/frontend!1975adservio/frontend[ADS-8116]: Fix filtering conditions on DSS NationalIoana Ivan2026-07-01Yes
adservio/web!2619adservio/web[ADS-8116]: DSS-National : Skip incidentRade tor conties with no incidents.Ioana Ivan2026-07-01Yes
adservio/helm2!297adservio/helm2tuiasi monitoring: fix tempo trace-export failures (gRPC 16MB, 5MB per-trace...Rojan Shrestha2026-07-02
adservio/web!2618adservio/web[S: ADS-7896] Migrate encoded filesCatalin Cojan2026-07-02Yes
adservio/frontend!1972adservio/frontend[ADS-406] Missing description in ‘’Istoric’ when sharing documentsPetronel Pavel2026-07-02Yes
adservio/web!2620adservio/web[ADS-7266] Portofoliu updatesPetronel Pavel2026-07-02Yes
adservio/web!2593adservio/web[ADS-7748] make thumb validationIonut Ciolan2026-07-02Yes
adservio/frontend!1973adservio/frontend[ADS-8046] POST /api/v2/clase/locks returns HTTP 500 when class-lock scope fields are emptyPetronel Pavel2026-07-02Yes
adservio/helm2!300adservio/helm2monitoring alerts: add KubePodContainerRestartingFrequently (>2 restarts/30m)Rojan Shrestha2026-07-02
adservio/services/backend-for-frontend!9adservio/services/backend-for-frontendfix(newsfeed): filter calendar events by date, export isItemActiveOnDateStefan Musat2026-07-02
adservio/web!2617adservio/web[ADS-8024]: Get marketing info based on countyID (incidents, complaints, extracuricular periods)Ioana Ivan2026-07-02Yes
adservio/web!2623adservio/web[ADS-8044]: Swap intre tipuri de absente.Ioana Ivan2026-07-02
adservio/frontend!1959adservio/frontend[ADS-7474]: Calendar view optimisationsDragoș Ivan2026-07-02
adservio/frontend!1982adservio/frontend[partial-payments-fix] Actualizare suma minima si info bannerEdgar Alexa2026-07-02Yes
adservio/helm2!301adservio/helm2prod: enable rabbitmq ingress (rabbitmq.internal.prod.ads-dns.net,...Rojan Shrestha2026-07-02
adservio/helm2!302adservio/helm2tuiasi: re-seal superset-env with current controller cert + refresh stale repo certRojan Shrestha2026-07-02
adservio/helm2!303adservio/helm2ads-8125 render superset-env by moving supersetEnv under superset.secretsRojan Shrestha2026-07-02
adservio/helm2!299adservio/helm2ADS-8117 mitigate library-api OOM: disable audit interceptor, bump memory, enable HPARojan Shrestha2026-07-03
adservio/frontend!1983adservio/frontend[ADS-7475]: Plan de Invatamant - fix testeDana Mihaela Maritca2026-07-03
adservio/frontend!1984adservio/frontend[ADS-8070]: Add new grade type for MaarifIoana Ivan2026-07-03Yes
adservio/web!2622adservio/web[ADS-8070]: Add retake exam language entries for English and RomanianAndrei Dragan2026-07-03Yes
adservio/billing/backend!257adservio/billing/backend[charges-optimisation] Compute charges optimisationEdgar Alexa2026-07-03Yes
adservio/frontend!1979adservio/frontend[ADS-7430] - small bugfixingGeorge Murgoci2026-07-03Yes
adservio/admission/backend!168adservio/admission/backendSync shared folderAlex Murarescu2026-07-03Yes
adservio/uni/backend!224adservio/uni/backend[ADS-8099] Calcul Medie PromovareAndrei Alexandru2026-07-03Yes
adservio/frontend!1987adservio/frontend[ADS-7959] La descarcarea template-ului de import note sa apara nr grupeiAchim Stefan2026-07-03Yes
adservio/web!2624adservio/web[ADS-8078][ADS-7575] GDPR delete user & Query failedMarian Andrei2026-07-03

Oldest Active Open MRs (> 48 Working Hours)

adservio/web!2091adservio/webAndrei Dragan251.5d5
adservio/helm2!137adservio/helm2Raul Popovici227.6d0
adservio/services/websocket!8adservio/services/websocketRaul Popovici224.5d0
adservio/services/videothumb!5adservio/services/videothumbRaul Popovici224.5d0
adservio/services/fet-generator!9adservio/services/fet-generatorRaul Popovici224.5d0
adservio/ai/backend!62adservio/ai/backendRobert125.6d0
adservio/frontend!1556adservio/frontendGeorge Murgoci116.3d0
adservio/web!2344adservio/webGeorge Murgoci115.4d0
adservio/library/backend!26adservio/library/backendRaul Popovici95.4d0
adservio/subscriptions/backend!103adservio/subscriptions/backendEdgar Alexa93.4d4
adservio/frontend!1837adservio/frontendIuliana Gugeanu28.9d210
adservio/frontend!1887adservio/frontendAchim Stefan18.1d674
adservio/uni/backend!212adservio/uni/backendFrancisc Gabriel Virlan13.0d395
adservio/frontend!1938adservio/frontendDana Mihaela Maritca9.9d355
adservio/web!2582adservio/webIonut Ciolan9.1d70
adservio/web!2593adservio/webIonut Ciolan7.8d10
adservio/frontend!1959adservio/frontendDragoș Ivan6.0d310
adservio/web!2594adservio/webMarian Andrei4.9d261
adservio/web!2595adservio/webIoana Ivan3.9d10
adservio/frontend!1951adservio/frontendIoana Ivan3.9d10

Methodology And Limits

  • This report uses visible non-author GitLab comments as the strongest review-start proxy.
  • GitLab approval API coverage is shown separately; missing approval API data should be read as traceability gap, not proof that no approval happened.
  • Review completion uses the first `CR - Approved` label-add event after review starts when GitLab label history provides one; otherwise it falls back to merge time.
  • Last-author-commit metrics use the latest non-merge MR commit authored by the MR author strictly before review starts.
  • Timing metrics in this report exclude Saturday and Sunday hours using the Europe/Bucharest calendar.
  • Review-quality scoring is heuristic: it rewards visible substantive comments, multiple reviewers, and post-review pushes, and it penalizes large MRs with shallow visible discussion.
  • `Active open backlog rate` excludes draft MRs and uses a > 48 working-hour age threshold.
  • Open MR backlog age is a queue-health signal, not proof that every old open MR is actively waiting for review right now.