static void spdk_rpc_clear_trace_flag(struct spdk_jsonrpc_server_conn *conn, const struct spdk_json_val *params, const struct spdk_json_val *id) { struct rpc_trace_flag req = {}; struct spdk_json_write_ctx *w; if (spdk_json_decode_object(params, rpc_trace_flag_decoders, sizeof(rpc_trace_flag_decoders) / sizeof(*rpc_trace_flag_decoders), &req)) { SPDK_TRACELOG(SPDK_TRACE_DEBUG, "spdk_json_decode_object failed\n"); goto invalid; } if (req.flag == 0) { SPDK_TRACELOG(SPDK_TRACE_DEBUG, "flag was 0\n"); goto invalid; } spdk_log_clear_trace_flag(req.flag); free_rpc_trace_flag(&req); if (id == NULL) { return; } w = spdk_jsonrpc_begin_result(conn, id); spdk_json_write_bool(w, true); spdk_jsonrpc_end_result(conn, w); return; invalid: spdk_jsonrpc_send_error_response(conn, id, SPDK_JSONRPC_ERROR_INVALID_PARAMS, "Invalid parameters"); free_rpc_trace_flag(&req); }
static void log_test(void) { int rc = 0; rc = spdk_set_log_facility("test"); CU_ASSERT(rc == -1); rc = spdk_set_log_facility("local7"); CU_ASSERT(rc == 0); rc = spdk_set_log_priority("test"); CU_ASSERT(rc == -1); rc = spdk_set_log_priority("debug"); CU_ASSERT(rc == 0); #ifdef DEBUG CU_ASSERT(spdk_log_get_trace_flag("debug") == false); spdk_log_set_trace_flag("debug"); CU_ASSERT(spdk_log_get_trace_flag("debug") == true); spdk_log_clear_trace_flag("debug"); CU_ASSERT(spdk_log_get_trace_flag("debug") == false); #endif spdk_open_log(); spdk_log_set_trace_flag("debug"); SPDK_WARNLOG("log warning unit test\n"); SPDK_TRACELOG(SPDK_TRACE_DEBUG, "log trace test\n"); SPDK_TRACEDUMP(SPDK_TRACE_DEBUG, "log trace dump test:", "trace dump", 10); spdk_trace_dump("spdk dump test:", "spdk dump", 9); spdk_close_log(); }