Fix uploading mac dsyms (#35904)
I'm not sure we actually want to be using `debug-info=unpacked` and then running `dsymutil` with `--flat`, but for now the minimal change to get this working is to manually specify the flattened, uncompressed debug info file for upload, which in turn will cause `sentry-cli` to pick up on source-info for the zed binary. I think in the future we should switch to `packed` debug info, both for the zed binary _and_ the remote server, and then we can tar up the better supported `dSYM` folder format rather than the flat dwarf version. Release Notes: - N/A
This commit is contained in:
parent
4e97968bcb
commit
4c5058c077
1 changed files with 14 additions and 8 deletions
|
@ -207,7 +207,7 @@ function prepare_binaries() {
|
|||
rm -f target/${architecture}/${target_dir}/Zed.dwarf.gz
|
||||
|
||||
echo "Gzipping dSYMs for $architecture"
|
||||
gzip -f target/${architecture}/${target_dir}/Zed.dwarf
|
||||
gzip -kf target/${architecture}/${target_dir}/Zed.dwarf
|
||||
|
||||
echo "Uploading dSYMs${architecture} for $architecture to by-uuid/${uuid}.dwarf.gz"
|
||||
upload_to_blob_store_public \
|
||||
|
@ -367,19 +367,25 @@ else
|
|||
gzip -f --stdout --best target/aarch64-apple-darwin/release/remote_server > target/zed-remote-server-macos-aarch64.gz
|
||||
fi
|
||||
|
||||
# Upload debug info to sentry.io
|
||||
if ! command -v sentry-cli >/dev/null 2>&1; then
|
||||
echo "sentry-cli not found. skipping sentry upload."
|
||||
echo "install with: 'curl -sL https://sentry.io/get-cli | bash'"
|
||||
else
|
||||
function upload_debug_info() {
|
||||
architecture=$1
|
||||
if [[ -n "${SENTRY_AUTH_TOKEN:-}" ]]; then
|
||||
echo "Uploading zed debug symbols to sentry..."
|
||||
# note: this uploads the unstripped binary which is needed because it contains
|
||||
# .eh_frame data for stack unwinindg. see https://github.com/getsentry/symbolic/issues/783
|
||||
sentry-cli debug-files upload --include-sources --wait -p zed -o zed-dev \
|
||||
"target/x86_64-apple-darwin/${target_dir}/" \
|
||||
"target/aarch64-apple-darwin/${target_dir}/"
|
||||
"target/${architecture}/${target_dir}/zed" \
|
||||
"target/${architecture}/${target_dir}/remote_server" \
|
||||
"target/${architecture}/${target_dir}/zed.dwarf"
|
||||
else
|
||||
echo "missing SENTRY_AUTH_TOKEN. skipping sentry upload."
|
||||
fi
|
||||
}
|
||||
|
||||
if command -v sentry-cli >/dev/null 2>&1; then
|
||||
upload_debug_info "aarch64-apple-darwin"
|
||||
upload_debug_info "x86_64-apple-darwin"
|
||||
else
|
||||
echo "sentry-cli not found. skipping sentry upload."
|
||||
echo "install with: 'curl -sL https://sentry.io/get-cli | bash'"
|
||||
fi
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue