[reporting] Exceptions of visibility Exn_developer are now logged using EventLogger when not running in developer mode

Reviewed By: dulmarod

Differential Revision: D7082468

fbshipit-source-id: 410d560
master
Varun Arora 7 years ago committed by Facebook Github Bot
parent 69bfc0535c
commit 32b2a707e8

@ -234,8 +234,8 @@ let update errlog_old errlog_new =
ErrLogHash.iter (fun err_key l -> ignore (add_issue errlog_old err_key l)) errlog_new ErrLogHash.iter (fun err_key l -> ignore (add_issue errlog_old err_key l)) errlog_new
let log_issue err_kind err_log loc (node_id, node_key) session ltr ?linters_def_file ?doc_url let log_issue procname err_kind err_log loc (node_id, node_key) session ltr ?linters_def_file
?access exn = ?doc_url ?access exn =
let error = Exceptions.recognize_exception exn in let error = Exceptions.recognize_exception exn in
let err_kind = match error.kind with Some err_kind -> err_kind | _ -> err_kind in let err_kind = match error.kind with Some err_kind -> err_kind | _ -> err_kind in
let hide_java_loc_zero = let hide_java_loc_zero =
@ -249,12 +249,24 @@ let log_issue err_kind err_log loc (node_id, node_key) session ltr ?linters_def_
| _ -> | _ ->
false false
in in
let log_it = let exn_developer = Exceptions.equal_visibility error.visibility Exceptions.Exn_developer in
let should_report =
Exceptions.equal_visibility error.visibility Exceptions.Exn_user Exceptions.equal_visibility error.visibility Exceptions.Exn_user
|| Config.developer_mode || Config.developer_mode && exn_developer
&& Exceptions.equal_visibility error.visibility Exceptions.Exn_developer
in in
if log_it && not hide_java_loc_zero && not hide_memory_error then ( if exn_developer then
let issue =
EventLogger.AnalysisIssue
(* TODO: Add clang_method_kind field (T26423401) *)
{ bug_type= error.name.IssueType.unique_id
; bug_kind= Exceptions.err_kind_string err_kind
; exception_triggered_location= Option.map ~f:Logging.ml_loc_to_string error.ml_loc
; lang= Typ.Procname.get_language procname |> Language.to_explicit_string
; procedure_name= Typ.Procname.to_string procname
; source_location= loc }
in
EventLogger.log issue ) ;
if should_report && not hide_java_loc_zero && not hide_memory_error then
let added = let added =
let node_id_key = {node_id; node_key} in let node_id_key = {node_id; node_key} in
let err_data = let err_data =

@ -93,5 +93,5 @@ val update : t -> t -> unit
(** Update an old error log with a new one *) (** Update an old error log with a new one *)
val log_issue : val log_issue :
Exceptions.err_kind -> t -> Location.t -> int * Caml.Digest.t -> int -> loc_trace Typ.Procname.t -> Exceptions.err_kind -> t -> Location.t -> int * Caml.Digest.t -> int
-> ?linters_def_file:string -> ?doc_url:string -> ?access:string -> exn -> unit -> loc_trace -> ?linters_def_file:string -> ?doc_url:string -> ?access:string -> exn -> unit

@ -16,8 +16,8 @@ type log_t =
type log_issue_from_errlog = Errlog.t -> log_t type log_issue_from_errlog = Errlog.t -> log_t
let log_issue_from_errlog err_kind err_log ?loc ?node_id ?session ?ltr ?linters_def_file ?doc_url let log_issue_from_errlog procname err_kind err_log ?loc ?node_id ?session ?ltr ?linters_def_file
?access exn = ?doc_url ?access exn =
let issue_type = (Exceptions.recognize_exception exn).name in let issue_type = (Exceptions.recognize_exception exn).name in
if not Config.filtering (* no-filtering takes priority *) || issue_type.IssueType.enabled then if not Config.filtering (* no-filtering takes priority *) || issue_type.IssueType.enabled then
let loc = match loc with None -> State.get_loc () | Some loc -> loc in let loc = match loc with None -> State.get_loc () | Some loc -> loc in
@ -32,14 +32,15 @@ let log_issue_from_errlog err_kind err_log ?loc ?node_id ?session ?ltr ?linters_
match session with None -> (State.get_session () :> int) | Some session -> session match session with None -> (State.get_session () :> int) | Some session -> session
in in
let ltr = match ltr with None -> State.get_loc_trace () | Some ltr -> ltr in let ltr = match ltr with None -> State.get_loc_trace () | Some ltr -> ltr in
Errlog.log_issue err_kind err_log loc node_id session ltr ?linters_def_file ?doc_url ?access Errlog.log_issue procname err_kind err_log loc node_id session ltr ?linters_def_file ?doc_url
exn ?access exn
let log_issue_from_summary err_kind summary ?loc ?node_id ?session ?ltr ?linters_def_file ?doc_url let log_issue_from_summary err_kind summary ?loc ?node_id ?session ?ltr ?linters_def_file ?doc_url
?access exn = ?access exn =
let procname = Specs.get_proc_name summary in
let is_java_generated_method = let is_java_generated_method =
match Specs.get_proc_name summary with match procname with
| Typ.Procname.Java java_pname -> | Typ.Procname.Java java_pname ->
Typ.Procname.Java.is_generated java_pname Typ.Procname.Java.is_generated java_pname
| _ -> | _ ->
@ -53,8 +54,8 @@ let log_issue_from_summary err_kind summary ?loc ?node_id ?session ?ltr ?linters
if should_suppress_lint || is_java_generated_method then () (* Skip the reporting *) if should_suppress_lint || is_java_generated_method then () (* Skip the reporting *)
else else
let err_log = Specs.get_err_log summary in let err_log = Specs.get_err_log summary in
log_issue_from_errlog err_kind err_log ?loc ?node_id ?session ?ltr ?linters_def_file ?doc_url log_issue_from_errlog procname err_kind err_log ?loc ?node_id ?session ?ltr ?linters_def_file
?access exn ?doc_url ?access exn
let log_issue_deprecated ?(store_summary= false) err_kind proc_name ?loc ?node_id ?session ?ltr let log_issue_deprecated ?(store_summary= false) err_kind proc_name ?loc ?node_id ?session ?ltr

@ -32,7 +32,7 @@ val log_info_deprecated : ?store_summary:bool -> Typ.Procname.t -> log_t
DEPRECATED as it can create race conditions between checkers. DEPRECATED as it can create race conditions between checkers.
Use log_info instead *) Use log_info instead *)
val log_issue_from_errlog : Exceptions.err_kind -> log_issue_from_errlog val log_issue_from_errlog : Typ.Procname.t -> Exceptions.err_kind -> log_issue_from_errlog
(** Report an issue of a given kind in the given error log. *) (** Report an issue of a given kind in the given error log. *)
val log_error : Specs.summary -> log_t val log_error : Specs.summary -> log_t

@ -271,7 +271,7 @@ let mk ?(deprecated= []) ?(parse_mode= InferCommand) ?(in_help= []) ~long ?short
let closure = mk_setter variable in let closure = mk_setter variable in
let setter str = let setter str =
try closure str with exc -> try closure str with exc ->
raise (Arg.Bad ("bad value " ^ str ^ " for flag " ^ long ^ " (" ^ Exn.to_string exc ^ ")")) raise (Arg.Bad (F.sprintf "bad value %s for flag %s (%s)" str long (Exn.to_string exc)))
in in
let spec = mk_spec setter in let spec = mk_spec setter in
let doc = let doc =

@ -596,7 +596,8 @@ and ( analysis_blacklist_files_containing_options
let var = CLOpt.mk_string_list ~deprecated ~long ~meta ~f:mirror "" in let var = CLOpt.mk_string_list ~deprecated ~long ~meta ~f:mirror "" in
match source_of_truth with match source_of_truth with
| Some var -> | Some var ->
(* if the analyzer already has a variable associated to it, use it *) var (* if the analyzer already has a variable associated to it, use it *)
var
| None -> | None ->
(* record the variable associated to the analyzer if this is the first time we see this (* record the variable associated to the analyzer if this is the first time we see this
analyzer *) analyzer *)

@ -71,6 +71,30 @@ end = struct
new_id new_id
end end
type analysis_issue =
{ bug_kind: string
; bug_type: string
; exception_triggered_location: string option
; lang: string
; procedure_name: string
; source_location: Location.t }
let create_analysis_issue_row base record =
let open JsonBuilder in
base |> add_string ~key:"bug_kind" ~data:record.bug_kind
|> add_string ~key:"bug_type" ~data:record.bug_type
|> add_string_opt ~key:"exception_triggered_location" ~data:record.exception_triggered_location
|> add_string ~key:"lang" ~data:record.lang
|> add_string ~key:"procedure_name" ~data:record.procedure_name
|> add_string ~key:"source_location"
~data:
(String.concat
[ string_of_int record.source_location.line
; ":"
; string_of_int record.source_location.col ])
|> add_string ~key:"source_file" ~data:(SourceFile.to_rel_path record.source_location.file)
type analysis_stats = type analysis_stats =
{ analysis_nodes_visited: int { analysis_nodes_visited: int
; analysis_status: SymOp.failure_kind option ; analysis_status: SymOp.failure_kind option
@ -175,6 +199,7 @@ let create_procedures_translated_row base record =
type event = type event =
| AnalysisIssue of analysis_issue
| AnalysisStats of analysis_stats | AnalysisStats of analysis_stats
| CallTrace of call_trace | CallTrace of call_trace
| FrontendException of frontend_exception | FrontendException of frontend_exception
@ -183,6 +208,8 @@ type event =
let string_of_event event = let string_of_event event =
match event with match event with
| AnalysisIssue _ ->
"AnalysisIssue"
| AnalysisStats _ -> | AnalysisStats _ ->
"AnalysisStats" "AnalysisStats"
| CallTrace _ -> | CallTrace _ ->
@ -236,6 +263,8 @@ module LoggerImpl : S = struct
|> add_int ~key:"time" ~data:(int_of_float (Unix.time ())) |> add_int ~key:"time" ~data:(int_of_float (Unix.time ()))
in in
( match event with ( match event with
| AnalysisIssue record ->
create_analysis_issue_row base record
| AnalysisStats record -> | AnalysisStats record ->
create_analysis_stats_row base record create_analysis_stats_row base record
| CallTrace record -> | CallTrace record ->

@ -7,6 +7,14 @@
* of patent rights can be found in the PATENTS file in the same directory. * of patent rights can be found in the PATENTS file in the same directory.
*) *)
type analysis_issue =
{ bug_kind: string
; bug_type: string
; exception_triggered_location: string option
; lang: string
; procedure_name: string
; source_location: Location.t }
type analysis_stats = type analysis_stats =
{ analysis_nodes_visited: int { analysis_nodes_visited: int
; analysis_status: SymOp.failure_kind option ; analysis_status: SymOp.failure_kind option
@ -42,6 +50,7 @@ type procedures_translated =
; source_file: SourceFile.t } ; source_file: SourceFile.t }
type event = type event =
| AnalysisIssue of analysis_issue
| AnalysisStats of analysis_stats | AnalysisStats of analysis_stats
| CallTrace of call_trace | CallTrace of call_trace
| FrontendException of frontend_exception | FrontendException of frontend_exception

@ -433,7 +433,9 @@ let expand_checkers macro_map path_map checkers =
List.map ~f:expand_one_checker checkers List.map ~f:expand_one_checker checkers
let get_err_log translation_unit_context method_decl_opt = (** Add a frontend warning with a description desc at location loc to the errlog of a proc desc *)
let log_frontend_issue translation_unit_context method_decl_opt (node: Ctl_parser_types.ast_node)
(issue_desc: CIssue.issue_desc) linters_def_file =
let procname = let procname =
match method_decl_opt with match method_decl_opt with
| Some method_decl -> | Some method_decl ->
@ -441,13 +443,7 @@ let get_err_log translation_unit_context method_decl_opt =
| None -> | None ->
Typ.Procname.Linters_dummy_method Typ.Procname.Linters_dummy_method
in in
LintIssues.get_err_log procname let errlog = LintIssues.get_err_log procname in
(** Add a frontend warning with a description desc at location loc to the errlog of a proc desc *)
let log_frontend_issue translation_unit_context method_decl_opt (node: Ctl_parser_types.ast_node)
(issue_desc: CIssue.issue_desc) linters_def_file =
let errlog = get_err_log translation_unit_context method_decl_opt in
let err_desc = let err_desc =
Errdesc.explain_frontend_warning issue_desc.description issue_desc.suggestion issue_desc.loc Errdesc.explain_frontend_warning issue_desc.description issue_desc.suggestion issue_desc.loc
in in
@ -462,7 +458,7 @@ let log_frontend_issue translation_unit_context method_decl_opt (node: Ctl_parse
CAst_utils.generate_key_stmt st CAst_utils.generate_key_stmt st
in in
let key = Utils.better_hash key_str in let key = Utils.better_hash key_str in
Reporting.log_issue_from_errlog err_kind errlog exn ~loc:issue_desc.loc ~ltr:trace Reporting.log_issue_from_errlog procname err_kind errlog exn ~loc:issue_desc.loc ~ltr:trace
~node_id:(0, key) ?linters_def_file ?doc_url:issue_desc.doc_url ~node_id:(0, key) ?linters_def_file ?doc_url:issue_desc.doc_url

Loading…
Cancel
Save