Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support chunk uploading Proguard files #2196

Closed
szokeasaurusrex opened this issue Oct 23, 2024 · 1 comment
Closed

Support chunk uploading Proguard files #2196

szokeasaurusrex opened this issue Oct 23, 2024 · 1 comment

Comments

@szokeasaurusrex
Copy link
Member

szokeasaurusrex commented Oct 23, 2024

Sentry CLI currently does not support chunk uploading Proguard mappings via the sentry-cli upload-proguard subcommand. However, it appears that the Sentry backend might already support these uploads via the assemble DIF endpoint. So, we should attempt to add support for chunk uploading Proguard mappings via the DIF chunk upload code path.

Depends on #2195

szokeasaurusrex added a commit to getsentry/sentry that referenced this issue Nov 21, 2024
The `detect_dif_from_path` function does not correctly identify Proguard files which are chunk uploaded because these files have a randomly-assigned temporary path, and the logic tries to guess whether the file is a Proguard file based on its path. However, the `detect_dif_from_path` function also takes an optional `name` option, which for chunk-uploaded files, is the file name that is specified by the client making the assemble call. This has not been a problem yet, since Sentry CLI does not support chunk uploading Proguard files, but we are adding support in getsentry/sentry-cli#2196, and so we need to fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for potentially matching a Proguard file.
szokeasaurusrex added a commit to getsentry/sentry that referenced this issue Nov 21, 2024
The `detect_dif_from_path` function does not correctly identify Proguard files which are chunk uploaded because these files have a randomly-assigned temporary path, and the logic tries to guess whether the file is a Proguard file based on its path. However, the `detect_dif_from_path` function also takes an optional `name` option, which for chunk-uploaded files, is the file name that is specified by the client making the assemble call. This has not been a problem yet, since Sentry CLI does not support chunk uploading Proguard files, but we are adding support in getsentry/sentry-cli#2196, and so we need to fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for potentially matching a Proguard file.
szokeasaurusrex added a commit to getsentry/sentry that referenced this issue Nov 21, 2024
The `detect_dif_from_path` function does not correctly identify Proguard files which are chunk uploaded because these files have a randomly-assigned temporary path, and the logic tries to guess whether the file is a Proguard file based on its path. However, the `detect_dif_from_path` function also takes an optional `name` option, which for chunk-uploaded files, is the file name that is specified by the client making the assemble call. This has not been a problem yet, since Sentry CLI does not support chunk uploading Proguard files, but we are adding support in getsentry/sentry-cli#2196, and so we need to fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for potentially matching a Proguard file.
szokeasaurusrex added a commit to getsentry/sentry that referenced this issue Nov 21, 2024
The `detect_dif_from_path` function does not correctly identify Proguard files which are chunk uploaded because these files have a randomly-assigned temporary path, and the logic tries to guess whether the file is a Proguard file based on its path. However, the `detect_dif_from_path` function also takes an optional `name` option, which for chunk-uploaded files, is the file name that is specified by the client making the assemble call. This has not been a problem yet, since Sentry CLI does not support chunk uploading Proguard files, but we are adding support in getsentry/sentry-cli#2196, and so we need to fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for potentially matching a Proguard file.
szokeasaurusrex added a commit to getsentry/sentry that referenced this issue Nov 21, 2024
The `detect_dif_from_path` function does not correctly identify Proguard files which are chunk uploaded because these files have a randomly-assigned temporary path, and the logic tries to guess whether the file is a Proguard file based on its path. However, the `detect_dif_from_path` function also takes an optional `name` option, which for chunk-uploaded files, is the file name that is specified by the client making the assemble call. This has not been a problem yet, since Sentry CLI does not support chunk uploading Proguard files, but we are adding support in getsentry/sentry-cli#2196, and so we need to fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for potentially matching a Proguard file.
szokeasaurusrex added a commit that referenced this issue Nov 21, 2024
Introduce an experimental chunk uploading feature for the `sentry-cli upload-proguard` command. The feature can be activated by setting the `SENTRY_EXPERIMENTAL_PROGUARD_CHUNK_UPLOAD` environment variable to `1`. The feature is only activated when users opt in via this environment variable.

The experimental chunk uploading feature is not backwards compatible. We attempt the upload regardless of whether the server supports receiving chunk-uploaded Proguard files. Server-side support will only be available once getsentry/sentry#81131 is released. The goal here was to create something that works, so some optimizations that we use for other chunk uploaded file types (e.g. first checking whether any chunks are present on the server, and only uploading the missing ones), are not implemented for Proguard.

Ref #2196
szokeasaurusrex added a commit that referenced this issue Nov 21, 2024
Introduce an experimental chunk uploading feature for the `sentry-cli upload-proguard` command. The feature can be activated by setting the `SENTRY_EXPERIMENTAL_PROGUARD_CHUNK_UPLOAD` environment variable to `1`. The feature is only activated when users opt in via this environment variable.

The experimental chunk uploading feature is not backwards compatible. We attempt the upload regardless of whether the server supports receiving chunk-uploaded Proguard files. Server-side support will only be available once getsentry/sentry#81131 is released. The goal here was to create something that works, so some optimizations that we use for other chunk uploaded file types (e.g. first checking whether any chunks are present on the server, and only uploading the missing ones), are not implemented for Proguard.

Ref #2196
szokeasaurusrex added a commit that referenced this issue Nov 21, 2024
Introduce an experimental chunk uploading feature for the `sentry-cli upload-proguard` command. The feature can be activated by setting the `SENTRY_EXPERIMENTAL_PROGUARD_CHUNK_UPLOAD` environment variable to `1`. The feature is only activated when users opt in via this environment variable.

The experimental chunk uploading feature is not backwards compatible. We attempt the upload regardless of whether the server supports receiving chunk-uploaded Proguard files. Server-side support will only be available once getsentry/sentry#81131 is released. The goal here was to create something that works, so some optimizations that we use for other chunk uploaded file types (e.g. first checking whether any chunks are present on the server, and only uploading the missing ones), are not implemented for Proguard.

Ref #2196
szokeasaurusrex added a commit to getsentry/sentry that referenced this issue Nov 22, 2024
The `detect_dif_from_path` function does not correctly identify Proguard
files which are chunk uploaded because these files have a
randomly-assigned temporary path, and the logic tries to guess whether
the file is a Proguard file based on its path. However, the
`detect_dif_from_path` function also takes an optional `name` option,
which for chunk-uploaded files, is the file name that is specified by
the client making the assemble call. This has not been a problem yet,
since Sentry CLI does not support chunk uploading Proguard files, but we
are adding support in
getsentry/sentry-cli#2196, and so we need to
fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for
potentially matching a Proguard file.
szokeasaurusrex added a commit that referenced this issue Nov 22, 2024
Introduce an experimental chunk uploading feature for the `sentry-cli upload-proguard` command. The feature can be activated by setting the `SENTRY_EXPERIMENTAL_PROGUARD_CHUNK_UPLOAD` environment variable to `1`. The feature is only activated when users opt in via this environment variable.

The experimental chunk uploading feature is not backwards compatible. We attempt the upload regardless of whether the server supports receiving chunk-uploaded Proguard files. Server-side support will only be available once getsentry/sentry#81131 is released. The goal here was to create something that works, so some optimizations that we use for other chunk uploaded file types (e.g. first checking whether any chunks are present on the server, and only uploading the missing ones), are not implemented for Proguard.

Ref #2196
szokeasaurusrex added a commit that referenced this issue Nov 22, 2024
Introduce an experimental chunk uploading feature for the `sentry-cli
upload-proguard` command. The feature can be activated by setting the
`SENTRY_EXPERIMENTAL_PROGUARD_CHUNK_UPLOAD` environment variable to `1`.
The feature is only activated when users opt in via this environment
variable.

The experimental chunk uploading feature is not backwards compatible. We
attempt the upload regardless of whether the server supports receiving
chunk-uploaded Proguard files. Server-side support will only be
available once getsentry/sentry#81131 is
released. The goal here was to create something that works, so some
optimizations that we use for other chunk uploaded file types (e.g.
first checking whether any chunks are present on the server, and only
uploading the missing ones), are not implemented for Proguard.

Ref #2196
iamrajjoshi pushed a commit to getsentry/sentry that referenced this issue Nov 24, 2024
The `detect_dif_from_path` function does not correctly identify Proguard
files which are chunk uploaded because these files have a
randomly-assigned temporary path, and the logic tries to guess whether
the file is a Proguard file based on its path. However, the
`detect_dif_from_path` function also takes an optional `name` option,
which for chunk-uploaded files, is the file name that is specified by
the client making the assemble call. This has not been a problem yet,
since Sentry CLI does not support chunk uploading Proguard files, but we
are adding support in
getsentry/sentry-cli#2196, and so we need to
fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for
potentially matching a Proguard file.
harshithadurai pushed a commit to getsentry/sentry that referenced this issue Nov 25, 2024
The `detect_dif_from_path` function does not correctly identify Proguard
files which are chunk uploaded because these files have a
randomly-assigned temporary path, and the logic tries to guess whether
the file is a Proguard file based on its path. However, the
`detect_dif_from_path` function also takes an optional `name` option,
which for chunk-uploaded files, is the file name that is specified by
the client making the assemble call. This has not been a problem yet,
since Sentry CLI does not support chunk uploading Proguard files, but we
are adding support in
getsentry/sentry-cli#2196, and so we need to
fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for
potentially matching a Proguard file.
evanh pushed a commit to getsentry/sentry that referenced this issue Nov 25, 2024
The `detect_dif_from_path` function does not correctly identify Proguard
files which are chunk uploaded because these files have a
randomly-assigned temporary path, and the logic tries to guess whether
the file is a Proguard file based on its path. However, the
`detect_dif_from_path` function also takes an optional `name` option,
which for chunk-uploaded files, is the file name that is specified by
the client making the assemble call. This has not been a problem yet,
since Sentry CLI does not support chunk uploading Proguard files, but we
are adding support in
getsentry/sentry-cli#2196, and so we need to
fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for
potentially matching a Proguard file.
andrewshie-sentry pushed a commit to getsentry/sentry that referenced this issue Dec 2, 2024
The `detect_dif_from_path` function does not correctly identify Proguard
files which are chunk uploaded because these files have a
randomly-assigned temporary path, and the logic tries to guess whether
the file is a Proguard file based on its path. However, the
`detect_dif_from_path` function also takes an optional `name` option,
which for chunk-uploaded files, is the file name that is specified by
the client making the assemble call. This has not been a problem yet,
since Sentry CLI does not support chunk uploading Proguard files, but we
are adding support in
getsentry/sentry-cli#2196, and so we need to
fix the backend to allow chunk uploads of Proguard files.

Here, we update the logic to check both the `path` and the `name` for
potentially matching a Proguard file.
szokeasaurusrex added a commit that referenced this issue Dec 4, 2024
The new `ProguardMapping` type directly references the `ByteView` of the Proguard file, rather than simply storing the path to the file. This change will enable us to replace `ChunkedMapping` with `Chunked<ProguardMapping>`.

ref #2196
szokeasaurusrex added a commit that referenced this issue Dec 4, 2024
The new `ProguardMapping` type directly references the `ByteView` of the Proguard file, rather than simply storing the path to the file. This change will enable us to replace `ChunkedMapping` with `Chunked<ProguardMapping>`.

ref #2196
szokeasaurusrex added a commit that referenced this issue Dec 16, 2024
Use the existing chunked upload logic (already used for DIFs) when chunked-uploading Proguard mappings.

Closes #2195, #2196
szokeasaurusrex added a commit that referenced this issue Dec 16, 2024
Use the existing chunked upload logic (already used for DIFs) when chunked-uploading Proguard mappings.

Closes #2195, #2196
szokeasaurusrex added a commit that referenced this issue Dec 18, 2024
Use the existing chunked upload logic (already used for DIFs) when chunked-uploading Proguard mappings.

Closes #2195, #2196
szokeasaurusrex added a commit that referenced this issue Dec 18, 2024
Use the existing chunked upload logic (already used for DIFs) when chunked-uploading Proguard mappings.

Closes #2195, #2196
szokeasaurusrex added a commit that referenced this issue Dec 18, 2024
Use the existing chunked upload logic (already used for DIFs) when chunked-uploading Proguard mappings.

Closes #2195, #2196
@szokeasaurusrex
Copy link
Member Author

Technically, this was already completed in #2264

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant