[de-duplication] fix bug causing under-aggregation

Reviewed By: jeremydubreil

Differential Revision: D6520644

fbshipit-source-id: f7bb550
master
Sam Blackshear 7 years ago committed by Facebook Github Bot
parent 647e1cd62d
commit d81faea3b3

@ -63,20 +63,15 @@ let update_reported (pname, access) reported =
let dedup (issues: Jsonbug_t.jsonbug list) = let dedup (issues: Jsonbug_t.jsonbug list) =
List.fold issues ~init:(AccessMap.empty, []) ~f: List.fold issues ~init:(empty_reported, []) ~f:
(fun (reported_map, nondup_issues) (issue: Jsonbug_t.jsonbug) -> (fun (reported, nondup_issues) (issue: Jsonbug_t.jsonbug) ->
match issue.access with match issue.access with
| Some access_serial -> | Some access_serial ->
let access : Access.t = Marshal.from_string (B64.decode access_serial) 0 in let access : Access.t = Marshal.from_string (B64.decode access_serial) 0 in
let reported = if is_duplicate_report access reported then (reported, nondup_issues)
Option.value (AccessMap.find_opt access reported_map) ~default:empty_reported else (update_reported access reported, {issue with access= None} :: nondup_issues)
in
if is_duplicate_report access reported then (reported_map, nondup_issues)
else
( AccessMap.add access (update_reported access reported) reported_map
, {issue with access= None} :: nondup_issues )
| None -> | None ->
(reported_map, {issue with access= None} :: nondup_issues) ) (reported, {issue with access= None} :: nondup_issues) )
|> snd |> snd

Loading…
Cancel
Save