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

Release v5.30.0 #1844

Merged
merged 43 commits into from
May 11, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
2b9f9c1
Move Android 13 to BitBar
twometresteve Mar 22, 2023
ccfccc3
Use custom emoticons
twometresteve Mar 23, 2023
90809d2
Moves Android 12 tests onto BitBar (#1824)
Cawllec Mar 24, 2023
3cd32bd
Merge branch 'next' into tms/android-13
twometresteve Mar 24, 2023
9510a40
Correction
twometresteve Mar 24, 2023
db4e27f
Add missing lines
twometresteve Mar 25, 2023
539436a
Merge pull request #1825 from bugsnag/master
lemnik Mar 27, 2023
111505a
Merge branch 'next' into tms/android-13
twometresteve Mar 27, 2023
3ce73b3
Merge pull request #1822 from bugsnag/tms/android-13
twometresteve Mar 27, 2023
b813107
Initial implementation of BitBar move
Cawllec Mar 24, 2023
1bdff7a
Fix yaml error
Cawllec Mar 27, 2023
a8b0d87
Use correct connector in file name
Cawllec Mar 27, 2023
4aeb41a
Remove superfluous smoke test
Cawllec Mar 27, 2023
3bf5252
Ensure test headers are correct for moved tests
Cawllec Mar 28, 2023
772f86b
Remove Android 10 BrowserStack tests
Cawllec Mar 29, 2023
62f20a3
Add Android 9 smoke tests to primary pipeline file
Cawllec Mar 30, 2023
c670030
Merge pull request #1826 from bugsnag/tests/android-11-9-bitbar
twometresteve Apr 4, 2023
92f1353
Add global metadata to the example app (#1827)
Apr 6, 2023
0808bc3
added note for apple silicon (#1828)
Apr 11, 2023
477499b
Use correct tag to skip Samsung
twometresteve Apr 12, 2023
87fdcb4
Use labels to distinguish device farms
twometresteve Apr 12, 2023
24caf73
Mutability of metadata in initial client with breacrumb (#1830)
Apr 13, 2023
35def43
Extract the device name correctly
twometresteve Apr 15, 2023
f801102
Merge branch 'next' into tms/correct-skip
twometresteve Apr 15, 2023
ef9f952
Remove debugging
twometresteve Apr 15, 2023
46fd900
Merge pull request #1831 from bugsnag/tms/correct-skip
twometresteve Apr 18, 2023
ddaab36
fix(log): disable ndk and anr warning message when plugins are exclud…
Apr 18, 2023
40d14de
No not run any ANR scenarios on Samsungs
twometresteve Apr 21, 2023
1cead19
Increase emulator wait timeout
twometresteve Apr 21, 2023
d51d006
Merge pull request #1834 from bugsnag/tms/skip-samsung
twometresteve Apr 21, 2023
6d27a25
Reduce BS slots to 5
twometresteve Apr 24, 2023
11eaf73
Feature flag in example app (#1835)
Apr 24, 2023
a52a95b
Merge branch 'next' into tms/bs-5
twometresteve Apr 24, 2023
18f733c
Merge pull request #1836 from bugsnag/tms/bs-5
twometresteve Apr 24, 2023
4a4650d
feature(Example app): upgrade kotlin version and add a network except…
Apr 28, 2023
b465c46
Skip flaky tests
twometresteve May 3, 2023
9b72d98
Correct ticket number (10003 was a dupe)
twometresteve May 3, 2023
d883e15
fix(session tracker): Optimised session tracker to spend less time an…
May 3, 2023
6069e59
Merge branch 'next' into tms/skip-flake
twometresteve May 4, 2023
201e91e
Move Android 7 steps to BitBar
twometresteve May 4, 2023
2a5c308
Merge pull request #1837 from bugsnag/tms/skip-flake
twometresteve May 5, 2023
53ad30b
Merge pull request #1841 from bugsnag/tms/android-7
twometresteve May 5, 2023
eff2037
v5.30.0
lemnik May 11, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix(session tracker): Optimised session tracker to spend less time an…
…d memory for getting content activity. Also added synchronise block to avoid the issue casing by potential multi threads. (#1838)
  • Loading branch information
SmartbearYing authored May 3, 2023
commit d883e1599659d3cb484aa253e463167958847a3b
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@

### Enhancements

* Optimise SessionTracer to reduce the overhead in calculating the current context Activity.
[#1838](https://github.com/bugsnag/bugsnag-android/pull/1838)

* ANR or NDK detection warnings can be suppressed (using `enabledErrorTypes`) when plugin is excluded.
[#1832](https://github.com/bugsnag/bugsnag-android/pull/1832)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,21 +12,21 @@
import androidx.annotation.VisibleForTesting;

import java.io.File;
import java.util.Collection;
import java.util.ArrayDeque;
import java.util.Collections;
import java.util.Date;
import java.util.Deque;
import java.util.List;
import java.util.UUID;
import java.util.concurrent.ConcurrentLinkedQueue;
import java.util.concurrent.RejectedExecutionException;
import java.util.concurrent.atomic.AtomicLong;

class SessionTracker extends BaseObservable {

private static final int DEFAULT_TIMEOUT_MS = 30000;

private final Collection<String>
foregroundActivities = new ConcurrentLinkedQueue<>();
private final Deque<String>
foregroundActivities = new ArrayDeque<>();
private final long timeoutMs;

private final ImmutableConfig configuration;
Expand Down Expand Up @@ -133,7 +133,7 @@ boolean resumeSession() {
private void notifySessionStartObserver(final Session session) {
final String startedAt = DateUtils.toIso8601(session.getStartedAt());
updateState(new StateEvent.StartSession(session.getId(), startedAt,
session.getHandledCount(), session.getUnhandledCount()));
session.getHandledCount(), session.getUnhandledCount()));
}

/**
Expand Down Expand Up @@ -359,22 +359,23 @@ void onActivityStopped(String activityName) {
void updateForegroundTracker(String activityName, boolean activityStarting, long nowMs) {
if (activityStarting) {
long noActivityRunningForMs = nowMs - lastExitedForegroundMs.get();

//FUTURE:SM Race condition between isEmpty and put
if (foregroundActivities.isEmpty()) {
lastEnteredForegroundMs.set(nowMs);

if (noActivityRunningForMs >= timeoutMs
&& configuration.getAutoTrackSessions()) {
startNewSession(new Date(), client.getUser(), true);
synchronized (foregroundActivities) {
if (foregroundActivities.isEmpty()) {
lastEnteredForegroundMs.set(nowMs);

if (noActivityRunningForMs >= timeoutMs
&& configuration.getAutoTrackSessions()) {
startNewSession(new Date(), client.getUser(), true);
}
}
foregroundActivities.add(activityName);
}
foregroundActivities.add(activityName);
} else {
foregroundActivities.remove(activityName);

if (foregroundActivities.isEmpty()) {
lastExitedForegroundMs.set(nowMs);
synchronized (foregroundActivities) {
foregroundActivities.removeLastOccurrence(activityName);
if (foregroundActivities.isEmpty()) {
lastExitedForegroundMs.set(nowMs);
}
}
}
client.getContextState().setAutomaticContext(getContextActivity());
Expand All @@ -398,14 +399,8 @@ long getLastEnteredForegroundMs() {

@Nullable
String getContextActivity() {
if (foregroundActivities.isEmpty()) {
return null;
} else {
// linked hash set retains order of added activity and ensures uniqueness
// therefore obtain the most recently added
int size = foregroundActivities.size();
String[] activities = foregroundActivities.toArray(new String[size]);
return activities[size - 1];
synchronized (foregroundActivities) {
return foregroundActivities.peekLast();
}
}
}