[impurity] sort edges before comparing them

Summary:
This was a correctness issue as nothing guarantees that bindings are in
a specific order. The following commit violates that assumptions and
made the impurity tests fail without this change.

Reviewed By: ezgicicek

Differential Revision: D26488379

fbshipit-source-id: e9cc41147
master
Jules Villard 4 years ago committed by Facebook GitHub Bot
parent 94930e3b11
commit d22e08cf82

@ -10,7 +10,7 @@ module L = Logging
open PulseBasicInterface open PulseBasicInterface
open PulseDomainInterface open PulseDomainInterface
let debug fmt = L.(debug Analysis Verbose fmt) let debug fmt = L.debug Analysis Verbose fmt
let get_matching_dest_addr_opt ~edges_pre ~edges_post : let get_matching_dest_addr_opt ~edges_pre ~edges_post :
(BaseMemory.Access.t * AbstractValue.t) list option = (BaseMemory.Access.t * AbstractValue.t) list option =
@ -20,8 +20,9 @@ let get_matching_dest_addr_opt ~edges_pre ~edges_post :
if AbstractValue.equal addr_dest_pre addr_dest_post then if AbstractValue.equal addr_dest_pre addr_dest_post then
Option.map acc ~f:(fun acc -> (access, addr_dest_pre) :: acc) Option.map acc ~f:(fun acc -> (access, addr_dest_pre) :: acc)
else None ) else None )
(BaseMemory.Edges.bindings edges_pre) (BaseMemory.Edges.bindings edges_pre |> List.sort ~compare:[%compare: BaseMemory.Access.t * _])
(BaseMemory.Edges.bindings edges_post) ( BaseMemory.Edges.bindings edges_post
|> List.sort ~compare:[%compare: BaseMemory.Access.t * _] )
with with
| Unequal_lengths -> | Unequal_lengths ->
debug "Mismatch in pre and post.\n" ; debug "Mismatch in pre and post.\n" ;

Loading…
Cancel
Save