-
-
Notifications
You must be signed in to change notification settings - Fork 443
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
POTEL 40 - Init Priority settings #3674
Merged
Merged
Changes from 6 commits
Commits
Show all changes
9 commits
Select commit
Hold shift + click to select a range
57c1b97
Support spans across batches
adinauer 2a3d0eb
changelog
adinauer 0f180c4
POC use correct options for multi init
adinauer bec16db
Merge branch '8.x.x' into feat/poc-multi-init-options
adinauer 1787942
Merge branch '8.x.x' into feat/poc-multi-init-options
adinauer 1169294
Add settings for controlling init priority
adinauer 94aa1cd
Merge branch '8.x.x' into feat/potel-40-init-priorty-settings
adinauer f9b17d8
changelog
adinauer d63db29
code review changes
adinauer File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
package io.sentry; | ||
|
||
import org.jetbrains.annotations.ApiStatus; | ||
|
||
@ApiStatus.Internal | ||
public enum InitPriority { | ||
LOWEST, | ||
LOW, | ||
MEDIUM, | ||
HIGH, | ||
HIGHEST; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -489,6 +489,9 @@ public class SentryOptions { | |
|
||
private @NotNull ScopeType defaultScopeType = ScopeType.ISOLATION; | ||
|
||
private @NotNull InitPriority initPriority = InitPriority.MEDIUM; | ||
private boolean forceInit = false; | ||
|
||
/** | ||
* Adds an event processor | ||
* | ||
|
@@ -2440,6 +2443,33 @@ public void setDefaultScopeType(final @NotNull ScopeType scopeType) { | |
return defaultScopeType; | ||
} | ||
|
||
@ApiStatus.Internal | ||
public void setInitPriority(final @NotNull InitPriority initPriority) { | ||
this.initPriority = initPriority; | ||
} | ||
|
||
@ApiStatus.Internal | ||
public @NotNull InitPriority getInitPriority() { | ||
return initPriority; | ||
} | ||
|
||
/** | ||
* If set to true a call to Sentry.init (or SentryAndroid.init) will go through and replace | ||
* previous options if there are any. | ||
* | ||
* <p>By default the SDK will check whether a previous call to Sentry.init has higher priority | ||
* than the current one and decide whether to actually perform the init and replace options. | ||
* | ||
* @param forceInit true = replace previous init and options | ||
*/ | ||
public void setForceInit(final boolean forceInit) { | ||
this.forceInit = forceInit; | ||
} | ||
|
||
public boolean isForceInit() { | ||
return forceInit; | ||
} | ||
|
||
/** The BeforeSend callback */ | ||
public interface BeforeSendCallback { | ||
|
||
|
@@ -2562,6 +2592,7 @@ public SentryOptions() { | |
*/ | ||
private SentryOptions(final boolean empty) { | ||
if (!empty) { | ||
setInitPriority(InitPriority.LOWEST); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Shouldn't we keep the default when creating new There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Was intended differently, let's remove this. |
||
setSpanFactory(new DefaultSpanFactory()); | ||
// SentryExecutorService should be initialized before any | ||
// SendCachedEventFireAndForgetIntegration | ||
|
@@ -2636,6 +2667,9 @@ public void merge(final @NotNull ExternalOptions options) { | |
if (options.getSendClientReports() != null) { | ||
setSendClientReports(options.getSendClientReports()); | ||
} | ||
if (options.isForceInit() != null) { | ||
setForceInit(options.isForceInit()); | ||
} | ||
final Map<String, String> tags = new HashMap<>(options.getTags()); | ||
for (final Map.Entry<String, String> tag : tags.entrySet()) { | ||
this.tags.put(tag.getKey(), tag.getValue()); | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
package io.sentry.util; | ||
|
||
import io.sentry.SentryOptions; | ||
import org.jetbrains.annotations.ApiStatus; | ||
import org.jetbrains.annotations.NotNull; | ||
import org.jetbrains.annotations.Nullable; | ||
|
||
@ApiStatus.Internal | ||
public final class InitUtil { | ||
public static boolean shouldInit( | ||
final @Nullable SentryOptions previousOptions, | ||
final @NotNull SentryOptions newOptions, | ||
final boolean isEnabled) { | ||
if (!isEnabled) { | ||
return true; | ||
} | ||
|
||
if (previousOptions == null) { | ||
return true; | ||
} | ||
|
||
if (newOptions.isForceInit()) { | ||
return true; | ||
} | ||
|
||
return previousOptions.getInitPriority().ordinal() <= newOptions.getInitPriority().ordinal(); | ||
} | ||
} |
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To be consistent with the other fields in
SentryOptions
maybe add a new line in between.Also these might warrant a JavaDoc description with a short explainer what they're used for