Hide GPU problems from Slack (#18087)

Release Notes:

- N/A

---------

Co-authored-by: Marshall <marshall@zed.dev>
Co-authored-by: Marshall Bowers <elliott.codes@gmail.com>
This commit is contained in:
Conrad Irwin 2024-09-19 15:28:30 -06:00 committed by GitHub
parent 82e6b1e0e5
commit edf2c19250
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -18,8 +18,8 @@ use sha2::{Digest, Sha256};
use std::sync::{Arc, OnceLock}; use std::sync::{Arc, OnceLock};
use telemetry_events::{ use telemetry_events::{
ActionEvent, AppEvent, AssistantEvent, CallEvent, CpuEvent, EditEvent, EditorEvent, Event, ActionEvent, AppEvent, AssistantEvent, CallEvent, CpuEvent, EditEvent, EditorEvent, Event,
EventRequestBody, EventWrapper, ExtensionEvent, InlineCompletionEvent, MemoryEvent, ReplEvent, EventRequestBody, EventWrapper, ExtensionEvent, InlineCompletionEvent, MemoryEvent, Panic,
SettingEvent, ReplEvent, SettingEvent,
}; };
use uuid::Uuid; use uuid::Uuid;
@ -296,10 +296,11 @@ pub async fn post_panic(
version = %panic.app_version, version = %panic.app_version,
os_name = %panic.os_name, os_name = %panic.os_name,
os_version = %panic.os_version.clone().unwrap_or_default(), os_version = %panic.os_version.clone().unwrap_or_default(),
installation_id = %panic.installation_id.unwrap_or_default(), installation_id = %panic.installation_id.clone().unwrap_or_default(),
description = %panic.payload, description = %panic.payload,
backtrace = %panic.backtrace.join("\n"), backtrace = %panic.backtrace.join("\n"),
"panic report"); "panic report"
);
let backtrace = if panic.backtrace.len() > 25 { let backtrace = if panic.backtrace.len() > 25 {
let total = panic.backtrace.len(); let total = panic.backtrace.len();
@ -317,6 +318,11 @@ pub async fn post_panic(
} else { } else {
panic.backtrace.join("\n") panic.backtrace.join("\n")
}; };
if !report_to_slack(&panic) {
return Ok(());
}
let backtrace_with_summary = panic.payload + "\n" + &backtrace; let backtrace_with_summary = panic.payload + "\n" + &backtrace;
if let Some(slack_panics_webhook) = app.config.slack_panics_webhook.clone() { if let Some(slack_panics_webhook) = app.config.slack_panics_webhook.clone() {
@ -357,6 +363,23 @@ pub async fn post_panic(
Ok(()) Ok(())
} }
fn report_to_slack(panic: &Panic) -> bool {
if panic.os_name == "Linux" {
if panic.payload.contains("ERROR_SURFACE_LOST_KHR") {
return false;
}
if panic
.payload
.contains("GPU has crashed, and no debug information is available")
{
return false;
}
}
true
}
pub async fn post_events( pub async fn post_events(
Extension(app): Extension<Arc<AppState>>, Extension(app): Extension<Arc<AppState>>,
TypedHeader(ZedChecksumHeader(checksum)): TypedHeader<ZedChecksumHeader>, TypedHeader(ZedChecksumHeader(checksum)): TypedHeader<ZedChecksumHeader>,