diff --git a/CHANGELOG.md b/CHANGELOG.md index ad8f394513..627b668e12 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,18 @@ # Changelog +## 4.18.0 (2019-08-15) + +* Migrate dependencies to androidx + [#554](https://github.com/bugsnag/bugsnag-android/pull/554) + +* Improve ANR error message information + [#553](https://github.com/bugsnag/bugsnag-android/pull/553) + +## 4.18.0-beta01 (2019-08-09) + +* Improve ANR error message information + [#553](https://github.com/bugsnag/bugsnag-android/pull/553) + ## 4.17.2 (2019-08-01) ### Bug fixes diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 717d5afa8f..10555d9dba 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -127,101 +127,4 @@ this version when you next run the app. # Releasing a New Version -If you are a project maintainer, you can build and release a new version of -`bugsnag-android` as follows: - -## One-time setup - -- Create a [Bintray](https://bintray.com/signup/oss) account, and ask a Bugsnag admin to add you to the organisation -- Create a [Sonatype JIRA](https://issues.sonatype.org) account -- Ask in the [Bugsnag Sonatype JIRA ticket](https://issues.sonatype.org/browse/OSSRH-5533) to become a contributor -- Ask an existing contributor (likely Simon) to confirm in the ticket -- Wait for Sonatype them to confirm the approval -- Create a file `~/.gradle/gradle.properties` with the following contents: - - ```ini - # Your credentials for https://oss.sonatype.org/ - # NOTE: An equals sign (`=`) in any of these fields will break the parser - # NOTE: Do not wrap any field in quotes - - NEXUS_USERNAME=your-nexus-username - NEXUS_PASSWORD=your-nexus-password - nexusUsername=your-nexus-username - nexusPassword=your-nexus-password - - # Your credentials for Bintray - # From https://bintray.com/profile - bintray_user=your-bintray-username - # Get your Bintray API key from https://bintray.com/profile/edit > API Key - bintray_api_key=your-api-key - - # GPG key details - # Your key must be added to a public key server, such as http://keys.gnupg.net: - # 1. Get your key id by running `gpg --list-keys --keyid-format=short`. It - # should be 8-character hexadecimal. - # 2. Export your key using `gpg --armor --export ` - # 3. Upload to a server using `gpg --keyserver hkp://keys.gnupg.net --send-keys ` - signing.keyId= - signing.password=your-gpg-key-passphrase - signing.secretKeyRingFile=/Users/{username}/.gnupg/secring.gpg - ``` - -## Every time - -### Pre-release Checklist - -- [ ] Does the build pass on the CI server? -- [ ] Are all Docs PRs ready to go? -- [ ] Do the installation instructions work when creating an example app from scratch? -- [ ] Has all new functionality been manually tested on a release build? - - [ ] Ensure the example app sends an unhandled error - - [ ] Ensure the example app sends a handled error - - [ ] If a response is not received from the server, is the report queued for later? - - [ ] If no network connection is available, is the report queued for later? - - [ ] On a throttled network, is the request timeout reasonable, and the main thread not blocked by any visible UI freeze? (Throttling can be achieved by setting both endpoints to "https://httpstat.us/200?sleep=5000") - - [ ] Are queued reports sent asynchronously? -- Native functionality checks: - - [ ] Rotate the device before notifying. Is the orientation at the time - persisted in the report on the dashboard? - - [ ] Rotate the device before causing a native crash. Is the orientation at - the time of the crash persisted in the report on the dashboard? - - [ ] Wait a few seconds before a native crash. Does the reported duration in - foreground match your expectation? Is the value for "inForeground" correct? - - [ ] Do the function names demangle correctly when using notify? -- [ ] Have the installation instructions been updated on the [dashboard](https://github.com/bugsnag/dashboard-js/tree/master/js/dashboard/components/integration_instructions) as well as the [docs site](https://github.com/bugsnag/docs.bugsnag.com)? -- [ ] Do the installation instructions work for a manual integration? - -### Making the release - -- Make a PR to release the following changes to master, creating a release - branch from the "next" branch if this is a feature release: - - [ ] Update the version number and dex count badge by running `make VERSION=[number] bump` - - [ ] Inspect the updated CHANGELOG, README, and version files to ensure they are correct -- Once merged: - - Pull the latest changes (checking out master if necessary) and build by running `./gradlew assembleRelease` - - Release to GitHub: - - [ ] Run `git tag vX.X.X && git push origin --tags` - - [ ] Create a release from your new tag on [GitHub Releases](https://github.com/bugsnag/bugsnag-android/releases) - - [ ] Release to Maven Central and Bintray by running `./gradlew assembleRelease publish bintrayUpload` - - [ ] "Promote" the release build on Maven Central: - - Go to the [sonatype open source dashboard](https://oss.sonatype.org/index.html#stagingRepositories) - - Click the search box at the top right, and type “com.bugsnag” - - Select the com.bugsnag staging repository - - Click the “close” button in the toolbar, no message - - Click the “refresh” button - - Select the com.bugsnag closed repository - - Click the “release” button in the toolbar - - Open the Bintray repositories and publish the new artifacts: - - [ ] [SDK repo](https://bintray.com/bugsnag/maven/bugsnag-android/_latestVersion) - - [ ] [NDK repo](https://bintray.com/bugsnag/maven/bugsnag-android-ndk/_latestVersion) -- Merge outstanding docs PRs related to this release - - -### Post-release Checklist - -_(May take some time to propagate to maven central and bintray)_ - -- [ ] Have all Docs PRs been merged? -- [ ] Can a freshly created example app send an error report from a release build using the released artefact? -- [ ] Do the existing example apps send an error report using the released artifact? -- [ ] Make releases to downstream libraries, if appropriate (generally for bug fixes) +Full details of how to release can be found in [the release guide](`RELEASING.md`) diff --git a/RELEASING.md b/RELEASING.md new file mode 100644 index 0000000000..5e94c7bb5b --- /dev/null +++ b/RELEASING.md @@ -0,0 +1,101 @@ +# Releasing a New Version + +If you are a project maintainer, you can build and release a new version of +`bugsnag-android` as follows: + +## One-time setup + +- Create a [Bintray](https://bintray.com/signup/oss) account, and ask a Bugsnag admin to add you to the organisation +- Create a [Sonatype JIRA](https://issues.sonatype.org) account +- Ask in the [Bugsnag Sonatype JIRA ticket](https://issues.sonatype.org/browse/OSSRH-5533) to become a contributor +- Ask an existing contributor (likely Simon) to confirm in the ticket +- Wait for Sonatype them to confirm the approval +- Create a file `~/.gradle/gradle.properties` with the following contents: + + ```ini + # Your credentials for https://oss.sonatype.org/ + # NOTE: An equals sign (`=`) in any of these fields will break the parser + # NOTE: Do not wrap any field in quotes + + NEXUS_USERNAME=your-nexus-username + NEXUS_PASSWORD=your-nexus-password + nexusUsername=your-nexus-username + nexusPassword=your-nexus-password + + # Your credentials for Bintray + # From https://bintray.com/profile + bintray_user=your-bintray-username + # Get your Bintray API key from https://bintray.com/profile/edit > API Key + bintray_api_key=your-api-key + + # GPG key details + # Your key must be added to a public key server, such as http://keys.gnupg.net: + # 1. Get your key id by running `gpg --list-keys --keyid-format=short`. It + # should be 8-character hexadecimal. + # 2. Export your key using `gpg --armor --export ` + # 3. Upload to a server using `gpg --keyserver hkp://keys.gnupg.net --send-keys ` + signing.keyId= + signing.password=your-gpg-key-passphrase + signing.secretKeyRingFile=/Users/{username}/.gnupg/secring.gpg + ``` + +## Every time + +### Pre-release Checklist + +- [ ] Has the full test suite been triggered on Buildkite and does it pass? +- [ ] Does the build pass on the CI server? +- [ ] Are all Docs PRs ready to go? +- [ ] Do the installation instructions work when creating an example app from scratch? +- [ ] Has all new functionality been manually tested on a release build? + - [ ] Ensure the example app sends an unhandled error + - [ ] Ensure the example app sends a handled error + - [ ] If a response is not received from the server, is the report queued for later? + - [ ] If no network connection is available, is the report queued for later? + - [ ] On a throttled network, is the request timeout reasonable, and the main thread not blocked by any visible UI freeze? (Throttling can be achieved by setting both endpoints to "https://httpstat.us/200?sleep=5000") + - [ ] Are queued reports sent asynchronously? +- Native functionality checks: + - [ ] Rotate the device before notifying. Is the orientation at the time + persisted in the report on the dashboard? + - [ ] Rotate the device before causing a native crash. Is the orientation at + the time of the crash persisted in the report on the dashboard? + - [ ] Wait a few seconds before a native crash. Does the reported duration in + foreground match your expectation? Is the value for "inForeground" correct? + - [ ] Do the function names demangle correctly when using notify? +- [ ] Have the installation instructions been updated on the [dashboard](https://github.com/bugsnag/dashboard-js/tree/master/js/dashboard/components/integration_instructions) as well as the [docs site](https://github.com/bugsnag/docs.bugsnag.com)? +- [ ] Do the installation instructions work for a manual integration? + +### Making the release + +- Make a PR to release the following changes to master, creating a release + branch from the "next" branch if this is a feature release: + - [ ] Update the version number and dex count badge by running `make VERSION=[number] bump` + - [ ] Inspect the updated CHANGELOG, README, and version files to ensure they are correct +- Once merged: + - Pull the latest changes (checking out master if necessary) and build by running `./gradlew assembleRelease` + - Release to GitHub: + - [ ] Run `git tag vX.X.X && git push origin --tags` + - [ ] Create a release from your new tag on [GitHub Releases](https://github.com/bugsnag/bugsnag-android/releases) + - [ ] Release to Maven Central and Bintray by running `./gradlew assembleRelease publish bintrayUpload` + - [ ] "Promote" the release build on Maven Central: + - Go to the [sonatype open source dashboard](https://oss.sonatype.org/index.html#stagingRepositories) + - Click the search box at the top right, and type “com.bugsnag” + - Select the com.bugsnag staging repository + - Click the “close” button in the toolbar, no message + - Click the “refresh” button + - Select the com.bugsnag closed repository + - Click the “release” button in the toolbar + - Open the Bintray repositories and publish the new artifacts: + - [ ] [SDK repo](https://bintray.com/bugsnag/maven/bugsnag-android/_latestVersion) + - [ ] [NDK repo](https://bintray.com/bugsnag/maven/bugsnag-android-ndk/_latestVersion) +- Merge outstanding docs PRs related to this release + + +### Post-release Checklist + +_(May take some time to propagate to maven central and bintray)_ + +- [ ] Have all Docs PRs been merged? +- [ ] Can a freshly created example app send an error report from a release build using the released artefact? +- [ ] Do the existing example apps send an error report using the released artifact? +- [ ] Make releases to downstream libraries, if appropriate (generally for bug fixes) diff --git a/bugsnag-android-core/src/androidTest/AndroidManifest.xml b/bugsnag-android-core/src/androidTest/AndroidManifest.xml index 2debc46153..f339ce8c08 100644 --- a/bugsnag-android-core/src/androidTest/AndroidManifest.xml +++ b/bugsnag-android-core/src/androidTest/AndroidManifest.xml @@ -10,7 +10,7 @@ () val packageManager = context.packageManager val obj = AppData(context, packageManager, config, sessionTracker) this.appData = obj.appData diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/AppDataSummaryTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/AppDataSummaryTest.java index d1ed6d008e..ac4cb25aea 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/AppDataSummaryTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/AppDataSummaryTest.java @@ -6,7 +6,7 @@ import android.content.Context; import android.content.pm.PackageManager; -import android.support.test.InstrumentationRegistry; +import androidx.test.core.app.ApplicationProvider; import org.json.JSONException; import org.json.JSONObject; @@ -34,7 +34,7 @@ public class AppDataSummaryTest { */ @Before public void setUp() throws Exception { - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); PackageManager packageManager = context.getPackageManager(); Configuration config = new Configuration("api-key"); AppData obj = new AppData(context, packageManager, config, sessionTracker); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/AppDataTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/AppDataTest.java index e3170db2f6..58d05e529a 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/AppDataTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/AppDataTest.java @@ -10,7 +10,8 @@ import android.content.Context; import android.content.pm.PackageManager; -import android.support.test.InstrumentationRegistry; + +import androidx.test.core.app.ApplicationProvider; import org.json.JSONException; import org.json.JSONObject; @@ -43,7 +44,7 @@ public void setUp() throws Exception { when(sessionTracker.isInForeground()).thenReturn(true); when(sessionTracker.getDurationInForegroundMs(anyLong())).thenReturn(500L); - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); PackageManager packageManager = context.getPackageManager(); Configuration config = new Configuration("api-key"); AppData obj = new AppData(context, packageManager, config, sessionTracker); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeNotifyTest.kt b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeNotifyTest.kt index a302008c66..38a371fd24 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeNotifyTest.kt +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeNotifyTest.kt @@ -2,14 +2,11 @@ package com.bugsnag.android import org.junit.Assert.assertEquals -import android.support.test.filters.SmallTest -import android.support.test.runner.AndroidJUnit4 +import androidx.test.filters.SmallTest import com.bugsnag.android.BugsnagTestUtils.generateSessionTracker import org.junit.Test -import org.junit.runner.RunWith -@RunWith(AndroidJUnit4::class) @SmallTest class BeforeNotifyTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeRecordBreadcrumbsTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeRecordBreadcrumbsTest.java index 6e95ba780c..1c1fca4b51 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeRecordBreadcrumbsTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeRecordBreadcrumbsTest.java @@ -4,19 +4,15 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; -import android.support.annotation.NonNull; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.annotation.NonNull; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.util.HashMap; -@RunWith(AndroidJUnit4.class) @SmallTest public class BeforeRecordBreadcrumbsTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeSendTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeSendTest.java index 4598161908..8a66aad418 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeSendTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BeforeSendTest.java @@ -4,16 +4,13 @@ import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNull; -import android.support.annotation.NonNull; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.annotation.NonNull; +import androidx.test.core.app.ApplicationProvider; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; -@RunWith(AndroidJUnit4.class) @SmallTest public class BeforeSendTest { @@ -42,7 +39,7 @@ public void deliver(@NonNull Report report, lastReport = report; } }); - client = new Client(InstrumentationRegistry.getContext(), config); + client = new Client(ApplicationProvider.getApplicationContext(), config); } @After diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BreadcrumbsTest.kt b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BreadcrumbsTest.kt index 5ffc05837d..0c8bb80154 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BreadcrumbsTest.kt +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BreadcrumbsTest.kt @@ -3,21 +3,18 @@ package com.bugsnag.android import com.bugsnag.android.BreadcrumbType.MANUAL import org.junit.Assert.assertEquals -import android.support.test.filters.SmallTest -import android.support.test.runner.AndroidJUnit4 +import androidx.test.filters.SmallTest import com.bugsnag.android.BugsnagTestUtils.* import org.json.JSONException import org.junit.After import org.junit.Before import org.junit.Test -import org.junit.runner.RunWith import java.io.IOException import java.util.HashMap import java.util.Locale -@RunWith(AndroidJUnit4::class) @SmallTest class BreadcrumbsTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BugsnagExceptionTest.kt b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BugsnagExceptionTest.kt new file mode 100644 index 0000000000..0e3d83ef92 --- /dev/null +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BugsnagExceptionTest.kt @@ -0,0 +1,80 @@ +package com.bugsnag.android + +import com.bugsnag.android.BugsnagTestUtils.generateConfiguration +import com.bugsnag.android.BugsnagTestUtils.streamableToJsonArray +import org.json.JSONArray +import org.json.JSONObject +import org.junit.Assert.assertEquals +import org.junit.Assert.assertTrue +import org.junit.Test + +class BugsnagExceptionTest { + + private val config = generateConfiguration() + + @Test + fun stacktraceConstructorSerialisation() { + val trace = arrayOf(StackTraceElement("Foo", "bar", "Foo.kt", 1)) + val exc = jsonObjectFromException(BugsnagException("MyClass", "Custom message", trace)) + assertEquals("MyClass", exc.get("errorClass")) + assertEquals("Custom message", exc.get("message")) + assertEquals("android", exc.get("type")) + + val stacktrace = exc.get("stacktrace") as JSONArray + assertTrue(stacktrace.length() > 0) + } + + @Test + fun throwableConstructorSerialisation() { + val exc = jsonObjectFromException(BugsnagException(RuntimeException("oops"))) + assertEquals("java.lang.RuntimeException", exc.get("errorClass")) + assertEquals("oops", exc.get("message")) + assertEquals("android", exc.get("type")) + + val stacktrace = exc.get("stacktrace") as JSONArray + assertTrue(stacktrace.length() > 0) + } + + @Test + fun overrideName() { + val bugsnagException = BugsnagException(RuntimeException("oops")) + bugsnagException.name = "FatalNetworkError" + val exc = jsonObjectFromException(bugsnagException) + assertEquals("FatalNetworkError", exc.get("errorClass")) + } + + @Test + fun overrideMessage() { + val bugsnagException = BugsnagException(RuntimeException("oops")) + bugsnagException.setMessage("User not found") + val exc = jsonObjectFromException(bugsnagException) + assertEquals("User not found", exc.get("message")) + } + + @Test + fun overrideType() { + val bugsnagException = BugsnagException(RuntimeException("oops")) + bugsnagException.type = "browserjs" + val exc = jsonObjectFromException(bugsnagException) + assertEquals("browserjs", exc.get("type")) + } + + @Test + fun nestedBugsnagException() { + val nestedThrowable = BugsnagException(BugsnagException(RuntimeException("oops"))) + val exc = jsonObjectFromException(nestedThrowable) + assertEquals("java.lang.RuntimeException", exc.get("errorClass")) + assertEquals("oops", exc.get("message")) + assertEquals("android", exc.get("type")) + + val stacktrace = exc.get("stacktrace") as JSONArray + assertTrue(stacktrace.length() > 0) + } + + private fun jsonObjectFromException(bugsnagException: BugsnagException): JSONObject { + val exceptions = Exceptions(config, bugsnagException) + val json = streamableToJsonArray(exceptions) + val exc = json.get(0) as JSONObject + return exc + } +} diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BugsnagTestUtils.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BugsnagTestUtils.java index 0bdae64fe9..9f2f88470a 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BugsnagTestUtils.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/BugsnagTestUtils.java @@ -2,8 +2,8 @@ import android.content.Context; import android.content.SharedPreferences; -import android.support.annotation.NonNull; -import android.support.test.InstrumentationRegistry; +import androidx.annotation.NonNull; +import androidx.test.core.app.ApplicationProvider; import org.json.JSONArray; import org.json.JSONException; @@ -46,7 +46,7 @@ static SharedPreferences getSharedPrefs(Context context) { static Client generateClient(Configuration config) { config.setDelivery(generateDelivery()); - return new Client(InstrumentationRegistry.getTargetContext(), config); + return new Client(ApplicationProvider.getApplicationContext(), config); } static Client generateClient() { @@ -69,12 +69,13 @@ static SessionTracker generateSessionTracker() { } static Connectivity generateConnectivity() { - return new ConnectivityCompat(InstrumentationRegistry.getContext(), null); + return new ConnectivityCompat(ApplicationProvider.getApplicationContext(), null); } @NonNull static SessionStore generateSessionStore() { - return new SessionStore(generateConfiguration(), InstrumentationRegistry.getContext()); + Context applicationContext = ApplicationProvider.getApplicationContext(); + return new SessionStore(generateConfiguration(), applicationContext); } @SuppressWarnings("deprecation") diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/CachedThreadTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/CachedThreadTest.java index 6cb9dd5ae8..64f60e10c6 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/CachedThreadTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/CachedThreadTest.java @@ -5,17 +5,14 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.SmallTest; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.IOException; -@RunWith(AndroidJUnit4.class) @SmallTest public class CachedThreadTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientConfigTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientConfigTest.java index e799072ad7..c77565532e 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientConfigTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientConfigTest.java @@ -5,17 +5,14 @@ import static org.junit.Assert.assertFalse; import android.content.Context; -import android.support.annotation.NonNull; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.annotation.NonNull; +import androidx.test.core.app.ApplicationProvider; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; -@RunWith(AndroidJUnit4.class) @SmallTest public class ClientConfigTest { @@ -28,7 +25,7 @@ public class ClientConfigTest { */ @Before public void setUp() throws Exception { - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); config = new Configuration("api-key"); client = new Client(context, config); } @@ -101,7 +98,7 @@ public void testDefaultClientDelivery() { @Test public void testCustomDeliveryOverride() { - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); config = BugsnagTestUtils.generateConfiguration(); Delivery customDelivery = new Delivery() { @Override diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientNotifyTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientNotifyTest.java index c05167358f..70f35a9d25 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientNotifyTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientNotifyTest.java @@ -2,20 +2,17 @@ import static org.junit.Assert.assertEquals; -import android.support.annotation.NonNull; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.annotation.NonNull; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.util.Map; import java.util.concurrent.CountDownLatch; import java.util.concurrent.TimeUnit; -@RunWith(AndroidJUnit4.class) @SmallTest public class ClientNotifyTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientTest.java index a4aba8e64d..eb685a62ab 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ClientTest.java @@ -11,20 +11,17 @@ import android.content.Context; import android.content.SharedPreferences; import android.os.Bundle; -import android.support.annotation.NonNull; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.annotation.NonNull; +import androidx.test.core.app.ApplicationProvider; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.util.Collection; import java.util.Map; -@RunWith(AndroidJUnit4.class) @SmallTest public class ClientTest { @@ -42,7 +39,7 @@ public class ClientTest { */ @Before public void setUp() throws Exception { - context = InstrumentationRegistry.getContext(); + context = ApplicationProvider.getApplicationContext(); clearSharedPrefs(); config = new Configuration("api-key"); } diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ConcurrentCallbackTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ConcurrentCallbackTest.java index 598df9264f..6be4a2a4d4 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ConcurrentCallbackTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ConcurrentCallbackTest.java @@ -1,13 +1,11 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.annotation.NonNull; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.util.Collection; @@ -15,7 +13,6 @@ * Ensures that if a callback is added or removed during iteration, a * {@link java.util.ConcurrentModificationException} is not thrown */ -@RunWith(AndroidJUnit4.class) @SmallTest public class ConcurrentCallbackTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ConfigurationTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ConfigurationTest.java index fded2e493c..4b21834f13 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ConfigurationTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ConfigurationTest.java @@ -7,17 +7,13 @@ import static org.junit.Assert.assertNull; import static org.junit.Assert.assertTrue; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.SmallTest; -import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.util.Map; -@RunWith(AndroidJUnit4.class) @SmallTest public class ConfigurationTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/CustomException.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/CustomException.java index bfb0767286..32d0b02aa4 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/CustomException.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/CustomException.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeliveryCompatTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeliveryCompatTest.java index a8064c809f..304ca994e7 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeliveryCompatTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeliveryCompatTest.java @@ -5,7 +5,7 @@ import static org.junit.Assert.assertNull; import static org.junit.Assert.assertTrue; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import org.junit.After; import org.junit.Before; diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeviceDataSummaryTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeviceDataSummaryTest.java index 8098239c5a..d7ec008ac0 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeviceDataSummaryTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeviceDataSummaryTest.java @@ -8,7 +8,8 @@ import android.content.Context; import android.content.SharedPreferences; import android.content.res.Resources; -import android.support.test.InstrumentationRegistry; + +import androidx.test.core.app.ApplicationProvider; import org.json.JSONException; import org.json.JSONObject; @@ -27,7 +28,7 @@ public class DeviceDataSummaryTest { @Before public void setUp() throws Exception { Connectivity connectivity = BugsnagTestUtils.generateConnectivity(); - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); Resources resources = context.getResources(); SharedPreferences prefs = context.getSharedPreferences("", Context.MODE_PRIVATE); DeviceData deviceData = new DeviceData(connectivity, context, resources, prefs); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeviceDataTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeviceDataTest.java index b57db6e736..c4e620dd08 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeviceDataTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/DeviceDataTest.java @@ -7,7 +7,7 @@ import android.content.Context; import android.content.SharedPreferences; import android.content.res.Resources; -import android.support.test.InstrumentationRegistry; +import androidx.test.core.app.ApplicationProvider; import org.json.JSONException; import org.json.JSONObject; @@ -28,7 +28,7 @@ public class DeviceDataTest { @Before public void setUp() throws Exception { Connectivity connectivity = BugsnagTestUtils.generateConnectivity(); - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); Resources resources = context.getResources(); SharedPreferences prefs = context.getSharedPreferences("", Context.MODE_PRIVATE); DeviceData deviceData = new DeviceData(connectivity, context, resources, prefs); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorFilenameTest.kt b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorFilenameTest.kt index 4aebb51616..7b8d0b1a24 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorFilenameTest.kt +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorFilenameTest.kt @@ -1,6 +1,7 @@ package com.bugsnag.android -import android.support.test.InstrumentationRegistry +import android.content.Context +import androidx.test.core.app.ApplicationProvider import com.bugsnag.android.ErrorStore.ERROR_REPORT_COMPARATOR import org.junit.Assert.assertEquals import org.junit.Assert.assertFalse @@ -26,7 +27,7 @@ class ErrorFilenameTest { @Before @Throws(Exception::class) fun setUp() { - val context = InstrumentationRegistry.getContext() + val context = ApplicationProvider.getApplicationContext() errorStore = ErrorStore(config, context, null) } diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorNameTest.kt b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorNameTest.kt new file mode 100644 index 0000000000..fb33ad73f5 --- /dev/null +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorNameTest.kt @@ -0,0 +1,48 @@ +package com.bugsnag.android + +import org.junit.Assert.assertEquals +import org.junit.Assert.assertTrue +import org.junit.Before +import org.junit.Test + +class ErrorNameTest { + + private lateinit var error: Error + + @Before + fun setUp() { + val config = Configuration("api-key") + val exception = RuntimeException("Example message", RuntimeException("Another")) + error = Error.Builder(config, exception, null, Thread.currentThread(), false).build() + } + + @Test + fun exceptionTypeConverted() { + assertTrue(error.exception is BugsnagException) + assertTrue(error.exceptions.exception is BugsnagException) + assertTrue(error.exceptions.exception.cause is RuntimeException) + } + + @Test + fun defaultExceptionName() { + assertEquals("java.lang.RuntimeException", error.exceptionName) + } + + @Test + fun defaultExceptionMessage() { + assertEquals("Example message", error.exceptionMessage) + } + + @Test + fun overrideExceptionName() { + error.exceptionName = "Foo" + assertEquals("Foo", error.exceptionName) + } + + @Test + fun overrideExceptionMessage() { + error.exceptionMessage = "Some custom message" + assertEquals("Some custom message", error.exceptionMessage) + } + +} diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorReaderTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorReaderTest.java index 30398be794..b16dd91bb6 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorReaderTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorReaderTest.java @@ -9,15 +9,13 @@ import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertTrue; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.SmallTest; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import org.junit.BeforeClass; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.File; import java.io.FileOutputStream; @@ -30,8 +28,6 @@ import java.util.Map; import java.util.TimeZone; - -@RunWith(AndroidJUnit4.class) @SmallTest public class ErrorReaderTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorReportApiClientTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorReportApiClientTest.java index 055564fd61..33721222ae 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorReportApiClientTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorReportApiClientTest.java @@ -4,19 +4,15 @@ import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNull; -import android.support.annotation.NonNull; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.annotation.NonNull; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.util.Map; -@RunWith(AndroidJUnit4.class) @SmallTest public class ErrorReportApiClientTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorTest.java index 3629157593..18589bdcd9 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ErrorTest.java @@ -13,9 +13,9 @@ import android.content.Context; import android.content.SharedPreferences; import android.content.res.Resources; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; + +import androidx.test.core.app.ApplicationProvider; +import androidx.test.filters.SmallTest; import org.json.JSONException; import org.json.JSONObject; @@ -23,13 +23,11 @@ import org.junit.Assert; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.IOException; import java.util.Date; import java.util.Map; -@RunWith(AndroidJUnit4.class) @SmallTest public class ErrorTest { @@ -78,16 +76,6 @@ public void testShouldIgnoreClass() { assertTrue(error.shouldIgnoreClass()); } - @Test - public void testGetExceptionName() { - assertEquals("java.lang.RuntimeException", error.getExceptionName()); - } - - @Test - public void testGetExceptionMessage() { - assertEquals("Example message", error.getExceptionMessage()); - } - @Test public void testBasicSerialization() throws JSONException, IOException { error.setAppData(client.getAppData().getAppData()); @@ -394,7 +382,7 @@ public void testErrorMetaData() { @Test public void testSetDeviceId() throws Throwable { Connectivity connectivity = BugsnagTestUtils.generateConnectivity(); - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); Resources resources = context.getResources(); SharedPreferences prefs = context.getSharedPreferences("", Context.MODE_PRIVATE); DeviceData data = new DeviceData(connectivity, context, resources, prefs); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/EventReceiverTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/EventReceiverTest.java index d38bea1147..a10c45ec19 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/EventReceiverTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/EventReceiverTest.java @@ -3,7 +3,7 @@ import static com.bugsnag.android.EventReceiver.shortenActionNameIfNeeded; import static org.junit.Assert.assertEquals; -import android.support.test.filters.SmallTest; +import androidx.test.filters.SmallTest; import org.junit.Test; diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionHandlerTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionHandlerTest.java index b6ea5bc71b..8e3826d0ee 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionHandlerTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionHandlerTest.java @@ -5,16 +5,14 @@ import static org.junit.Assert.assertTrue; import android.content.Context; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; + +import androidx.test.core.app.ApplicationProvider; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; -@RunWith(AndroidJUnit4.class) @SmallTest public class ExceptionHandlerTest { @@ -29,7 +27,7 @@ public class ExceptionHandlerTest { */ @Before public void setUp() throws Exception { - context = InstrumentationRegistry.getContext(); + context = ApplicationProvider.getApplicationContext(); // Start in a clean state, since we've created clients before in tests Thread.setDefaultUncaughtExceptionHandler(null); client = new Client(context, "api-key"); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionsTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionsTest.java deleted file mode 100644 index 1bb281e41f..0000000000 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionsTest.java +++ /dev/null @@ -1,97 +0,0 @@ -package com.bugsnag.android; - -import static com.bugsnag.android.BugsnagTestUtils.streamableToJsonArray; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; - -import android.support.annotation.NonNull; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; - -import org.json.JSONArray; -import org.json.JSONException; -import org.json.JSONObject; -import org.junit.After; -import org.junit.Before; -import org.junit.Test; -import org.junit.runner.RunWith; - -import java.io.IOException; - -@RunWith(AndroidJUnit4.class) -@SmallTest -public class ExceptionsTest { - - private Configuration config; - - @Before - public void setUp() throws Exception { - config = new Configuration("api-key"); - } - - @Test - public void testBasicException() throws JSONException, IOException { - Exceptions exceptions = new Exceptions(config, new RuntimeException("oops")); - JSONArray exceptionsJson = streamableToJsonArray(exceptions); - - assertEquals(1, exceptionsJson.length()); - - JSONObject firstException = (JSONObject) exceptionsJson.get(0); - assertEquals("java.lang.RuntimeException", firstException.get("errorClass")); - assertEquals("oops", firstException.get("message")); - assertNotNull(firstException.get("stacktrace")); - } - - @Test - public void testCauseException() throws JSONException, IOException { - Throwable ex = new RuntimeException("oops", new Exception("cause")); - Exceptions exceptions = new Exceptions(config, ex); - JSONArray exceptionsJson = streamableToJsonArray(exceptions); - - assertEquals(2, exceptionsJson.length()); - - JSONObject firstException = (JSONObject) exceptionsJson.get(0); - assertEquals("java.lang.RuntimeException", firstException.get("errorClass")); - assertEquals("oops", firstException.get("message")); - assertNotNull(firstException.get("stacktrace")); - - JSONObject causeException = (JSONObject) exceptionsJson.get(1); - assertEquals("java.lang.Exception", causeException.get("errorClass")); - assertEquals("cause", causeException.get("message")); - assertNotNull(causeException.get("stacktrace")); - } - - @Test - public void testNamedException() throws JSONException, IOException { - StackTraceElement element = new StackTraceElement("Class", "method", "Class.java", 123); - StackTraceElement[] frames = new StackTraceElement[]{element}; - Error error = new Error.Builder(config, "RuntimeException", - "Example message", frames, BugsnagTestUtils.generateSessionTracker(), - Thread.currentThread()).build(); - Exceptions exceptions = new Exceptions(config, error.getException()); - - JSONObject exceptionJson = streamableToJsonArray(exceptions).getJSONObject(0); - assertEquals("RuntimeException", exceptionJson.get("errorClass")); - assertEquals("Example message", exceptionJson.get("message")); - - JSONObject stackframeJson = exceptionJson.getJSONArray("stacktrace").getJSONObject(0); - assertEquals("Class.method", stackframeJson.get("method")); - assertEquals("Class.java", stackframeJson.get("file")); - assertEquals(123, stackframeJson.get("lineNumber")); - } - - @Test - public void testCustomExceptionSerialization() throws JSONException, IOException { - Exceptions exceptions = new Exceptions(config, new CustomException("Failed serialization")); - - JSONObject exceptionJson = streamableToJsonArray(exceptions).getJSONObject(0); - assertEquals("CustomizedException", exceptionJson.get("errorClass")); - assertEquals("Failed serialization", exceptionJson.get("message")); - - JSONObject stackframeJson = exceptionJson.getJSONArray("stacktrace").getJSONObject(0); - assertEquals("MyFile.run", stackframeJson.get("method")); - assertEquals("MyFile.java", stackframeJson.get("file")); - assertEquals(408, stackframeJson.get("lineNumber")); - assertEquals(18, stackframeJson.get("offset")); - } -} diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionsTest.kt b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionsTest.kt new file mode 100644 index 0000000000..18ae311c8c --- /dev/null +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ExceptionsTest.kt @@ -0,0 +1,73 @@ +package com.bugsnag.android + +import com.bugsnag.android.BugsnagTestUtils.generateConfiguration +import com.bugsnag.android.BugsnagTestUtils.streamableToJsonArray +import org.json.JSONObject +import org.junit.Assert.assertEquals +import org.junit.Assert.assertNotNull +import org.junit.Before +import org.junit.Test + +class ExceptionsTest { + + private lateinit var config: Configuration + + @Before + fun setUp() { + config = generateConfiguration() + } + + @Test + fun testBasicException() { + val oops = RuntimeException("oops") + val exceptions = Exceptions(config, BugsnagException(oops)) + val exceptionsJson = streamableToJsonArray(exceptions) + + assertEquals(1, exceptionsJson.length().toLong()) + + val firstException = exceptionsJson.get(0) as JSONObject + assertEquals("java.lang.RuntimeException", firstException.get("errorClass")) + assertEquals("oops", firstException.get("message")) + assertNotNull(firstException.get("stacktrace")) + } + + @Test + fun testCauseException() { + val ex = RuntimeException("oops", Exception("cause")) + val exceptions = Exceptions(config, BugsnagException(ex)) + val exceptionsJson = streamableToJsonArray(exceptions) + + assertEquals(2, exceptionsJson.length().toLong()) + + val firstException = exceptionsJson.get(0) as JSONObject + assertEquals("java.lang.RuntimeException", firstException.get("errorClass")) + assertEquals("oops", firstException.get("message")) + assertNotNull(firstException.get("stacktrace")) + + val causeException = exceptionsJson.get(1) as JSONObject + assertEquals("java.lang.Exception", causeException.get("errorClass")) + assertEquals("cause", causeException.get("message")) + assertNotNull(causeException.get("stacktrace")) + } + + @Test + fun testNamedException() { + val element = StackTraceElement("Class", "method", "Class.java", 123) + val frames = arrayOf(element) + val error = Error.Builder( + config, "RuntimeException", + "Example message", frames, BugsnagTestUtils.generateSessionTracker(), + Thread.currentThread() + ).build() + val exceptions = Exceptions(config, BugsnagException(error.exception)) + + val exceptionJson = streamableToJsonArray(exceptions).getJSONObject(0) + assertEquals("RuntimeException", exceptionJson.get("errorClass")) + assertEquals("Example message", exceptionJson.get("message")) + + val stackframeJson = exceptionJson.getJSONArray("stacktrace").getJSONObject(0) + assertEquals("Class.method", stackframeJson.get("method")) + assertEquals("Class.java", stackframeJson.get("file")) + assertEquals(123, stackframeJson.get("lineNumber")) + } +} diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonStreamTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonStreamTest.java index 168cba4ecb..fca3e94462 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonStreamTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonStreamTest.java @@ -1,27 +1,20 @@ package com.bugsnag.android; import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertTrue; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.core.app.ApplicationProvider; +import androidx.test.filters.SmallTest; -import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; -import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.File; -import java.io.FileWriter; import java.io.IOException; import java.io.StringWriter; -@RunWith(AndroidJUnit4.class) @SmallTest public class JsonStreamTest { @@ -38,7 +31,7 @@ public class JsonStreamTest { public void setUp() throws Exception { writer = new StringWriter(); stream = new JsonStream(writer); - File cacheDir = InstrumentationRegistry.getContext().getCacheDir(); + File cacheDir = ApplicationProvider.getApplicationContext().getCacheDir(); file = new File(cacheDir, "whoops"); file.delete(); } diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonWriterBugsnagTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonWriterBugsnagTest.java index 9866644d08..c07460fcc3 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonWriterBugsnagTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonWriterBugsnagTest.java @@ -2,17 +2,14 @@ import static org.junit.Assert.assertEquals; -import android.support.test.filters.MediumTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.MediumTest; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.OutputStreamWriter; -@RunWith(AndroidJUnit4.class) @MediumTest public class JsonWriterBugsnagTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonWriterTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonWriterTest.java index 4ffb643e20..f0bb1ba00b 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonWriterTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/JsonWriterTest.java @@ -3,11 +3,9 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.fail; -import android.support.test.filters.MediumTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.MediumTest; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.IOException; import java.io.StringWriter; @@ -30,7 +28,6 @@ * limitations under the License. */ -@RunWith(AndroidJUnit4.class) @MediumTest public final class JsonWriterTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/MetaDataTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/MetaDataTest.java index 96f39fb7ed..d0daa4ec32 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/MetaDataTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/MetaDataTest.java @@ -6,8 +6,7 @@ import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.SmallTest; import org.json.JSONArray; import org.json.JSONException; @@ -15,7 +14,6 @@ import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.IOException; import java.util.Arrays; @@ -25,7 +23,6 @@ import java.util.List; import java.util.Map; -@RunWith(AndroidJUnit4.class) @SmallTest public class MetaDataTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/NotifierTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/NotifierTest.java index 09c32e7e58..be42ff6ce4 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/NotifierTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/NotifierTest.java @@ -4,18 +4,15 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.SmallTest; import org.json.JSONException; import org.json.JSONObject; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.IOException; -@RunWith(AndroidJUnit4.class) @SmallTest public class NotifierTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/NullMetadataTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/NullMetadataTest.java index ba27a418dd..eaabf1afbd 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/NullMetadataTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/NullMetadataTest.java @@ -5,15 +5,12 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; -import android.support.annotation.NonNull; -import android.support.test.InstrumentationRegistry; +import androidx.annotation.NonNull; import org.junit.After; import org.junit.Before; import org.junit.Test; -import java.util.Map; - /** * Ensures that setting metadata to null doesn't result in NPEs *

diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ObserverInterfaceTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ObserverInterfaceTest.java index d66a250508..0100b330a6 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ObserverInterfaceTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ObserverInterfaceTest.java @@ -1,18 +1,15 @@ package com.bugsnag.android; import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertNull; import static org.junit.Assert.assertTrue; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.core.app.ApplicationProvider; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.util.ArrayList; import java.util.HashMap; @@ -21,8 +18,6 @@ import java.util.Observable; import java.util.Observer; - -@RunWith(AndroidJUnit4.class) @SmallTest @SuppressWarnings("unchecked") public class ObserverInterfaceTest { @@ -40,7 +35,7 @@ public class ObserverInterfaceTest { public void setUp() throws Exception { config = new Configuration("some-api-key"); config.setDelivery(BugsnagTestUtils.generateDelivery()); - client = new Client(InstrumentationRegistry.getContext(), config); + client = new Client(ApplicationProvider.getApplicationContext(), config); client.disableExceptionHandler(); observer = new BugsnagTestObserver(); client.addObserver(observer); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ProjectPackagesTest.kt b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ProjectPackagesTest.kt index d653e946a2..cc881fe98d 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ProjectPackagesTest.kt +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ProjectPackagesTest.kt @@ -1,6 +1,7 @@ package com.bugsnag.android -import android.support.test.InstrumentationRegistry +import android.content.Context +import androidx.test.core.app.ApplicationProvider import org.junit.Assert.assertArrayEquals import org.junit.Assert.assertNull import org.junit.Test @@ -12,7 +13,7 @@ class ProjectPackagesTest { val configuration = Configuration("api-key") assertNull(configuration.projectPackages) - val client = Client(InstrumentationRegistry.getContext(), configuration) + val client = Client(ApplicationProvider.getApplicationContext(), configuration) assertArrayEquals(arrayOf("com.bugsnag.android.core.test"), client.config.projectPackages) client.close() } @@ -21,7 +22,7 @@ class ProjectPackagesTest { fun testProjectPackagesOverride() { val configuration = Configuration("api-key") configuration.projectPackages = arrayOf("com.foo.example") - val client = Client(InstrumentationRegistry.getContext(), configuration) + val client = Client(ApplicationProvider.getApplicationContext(), configuration) assertArrayEquals(arrayOf("com.foo.example"), client.config.projectPackages) client.close() } diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ReportTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ReportTest.java index 4ececa0e9e..0ebd18ed03 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ReportTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ReportTest.java @@ -3,20 +3,16 @@ import static com.bugsnag.android.BugsnagTestUtils.streamableToJson; import static org.junit.Assert.assertEquals; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.SmallTest; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; -import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.IOException; -@RunWith(AndroidJUnit4.class) @SmallTest public class ReportTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/SessionStoreTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/SessionStoreTest.java index c3d1880ac1..5865f9969f 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/SessionStoreTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/SessionStoreTest.java @@ -6,18 +6,16 @@ import static org.junit.Assert.assertTrue; import android.content.Context; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; + +import androidx.test.core.app.ApplicationProvider; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.File; -@RunWith(AndroidJUnit4.class) @SmallTest public class SessionStoreTest { @@ -31,7 +29,7 @@ public class SessionStoreTest { @Before public void setUp() throws Exception { Configuration config = new Configuration("api-key"); - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); SessionStore sessionStore = new SessionStore(config, context); assertNotNull(sessionStore.storeDirectory); storageDir = new File(sessionStore.storeDirectory); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/SessionTrackingPayloadTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/SessionTrackingPayloadTest.java index 0e00cd6b1d..c194b80281 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/SessionTrackingPayloadTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/SessionTrackingPayloadTest.java @@ -9,7 +9,8 @@ import static org.junit.Assert.assertTrue; import android.content.Context; -import android.support.test.InstrumentationRegistry; + +import androidx.test.core.app.ApplicationProvider; import org.json.JSONArray; import org.json.JSONObject; @@ -41,7 +42,7 @@ public class SessionTrackingPayloadTest { */ @Before public void setUp() throws Exception { - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); Configuration config = new Configuration("api-key"); sessionStore = new SessionStore(config, context); @@ -111,7 +112,7 @@ public void testMultipleSessionFiles() throws Exception { @Test public void testAutoCapturedOverride() throws Exception { session = new Session("id", new Date(), null, false); - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); payload = generatePayloadFromSession(context, session); assertFalse(session.isAutoCaptured()); session.setAutoCaptured(true); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/StacktraceTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/StacktraceTest.java index 2ac5b3c79c..6db823d1ac 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/StacktraceTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/StacktraceTest.java @@ -5,23 +5,20 @@ import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; -import android.support.test.filters.FlakyTest; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.FlakyTest; +import androidx.test.filters.SmallTest; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.IOException; import java.util.ArrayList; import java.util.List; @FlakyTest(detail = "Checks a stacktrace's line number, so fails when lines are added/deleted.") -@RunWith(AndroidJUnit4.class) @SmallTest public class StacktraceTest { @@ -44,7 +41,7 @@ public void testBasicException() throws JSONException, IOException { JSONArray stacktraceJson = streamableToJsonArray(stacktrace); JSONObject firstFrame = (JSONObject) stacktraceJson.get(0); - assertEquals(37, firstFrame.get("lineNumber")); + assertEquals(34, firstFrame.get("lineNumber")); assertEquals("com.bugsnag.android.StacktraceTest.setUp", firstFrame.get("method")); assertEquals("StacktraceTest.java", firstFrame.get("file")); assertFalse(firstFrame.has("inProject")); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/StrictModeTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/StrictModeTest.java index bdf59b0bb7..df2fc500e4 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/StrictModeTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/StrictModeTest.java @@ -8,8 +8,9 @@ import android.content.Context; import android.os.Build; -import android.support.test.InstrumentationRegistry; -import android.support.test.filters.SmallTest; + +import androidx.test.core.app.ApplicationProvider; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Assert; @@ -127,7 +128,7 @@ private Exception generateStrictModeException() { */ private void violateStrictModePolicy() { try { - Context context = InstrumentationRegistry.getContext(); + Context context = ApplicationProvider.getApplicationContext(); new FileWriter(new File(context.getCacheDir(), "test")).write("test"); } catch (IOException exception) { exception.printStackTrace(); diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ThreadStateTest.kt b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ThreadStateTest.kt index 65ebf9d193..2a2152fa4b 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ThreadStateTest.kt +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/ThreadStateTest.kt @@ -1,16 +1,12 @@ package com.bugsnag.android -import android.support.test.filters.SmallTest -import android.support.test.runner.AndroidJUnit4 +import androidx.test.filters.SmallTest import com.bugsnag.android.BugsnagTestUtils.streamableToJsonArray import org.json.JSONArray import org.json.JSONObject import org.junit.Assert.* import org.junit.Test -import org.junit.runner.RunWith - -@RunWith(AndroidJUnit4::class) @SmallTest class ThreadStateTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/UniqueBeforeNotifyTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/UniqueBeforeNotifyTest.java index 0de63d2984..1f512a466a 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/UniqueBeforeNotifyTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/UniqueBeforeNotifyTest.java @@ -2,20 +2,17 @@ import static org.junit.Assert.assertEquals; -import android.support.annotation.NonNull; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.annotation.NonNull; +import androidx.test.filters.SmallTest; import org.junit.After; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; /** * Ensures that BeforeNotify is only called once, * and that the callbacks are called in insertion order. */ -@RunWith(AndroidJUnit4.class) @SmallTest public class UniqueBeforeNotifyTest { diff --git a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/UserTest.java b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/UserTest.java index 044896f814..f732e4d09d 100644 --- a/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/UserTest.java +++ b/bugsnag-android-core/src/androidTest/java/com/bugsnag/android/UserTest.java @@ -3,18 +3,15 @@ import static com.bugsnag.android.BugsnagTestUtils.streamableToJson; import static org.junit.Assert.assertEquals; -import android.support.test.filters.SmallTest; -import android.support.test.runner.AndroidJUnit4; +import androidx.test.filters.SmallTest; import org.json.JSONException; import org.json.JSONObject; import org.junit.Before; import org.junit.Test; -import org.junit.runner.RunWith; import java.io.IOException; -@RunWith(AndroidJUnit4.class) @SmallTest public class UserTest { diff --git a/bugsnag-android-core/src/main/AndroidManifest.xml b/bugsnag-android-core/src/main/AndroidManifest.xml index 15e2e4fac7..d3957bd187 100644 --- a/bugsnag-android-core/src/main/AndroidManifest.xml +++ b/bugsnag-android-core/src/main/AndroidManifest.xml @@ -1,9 +1,14 @@ + package="com.bugsnag.android.core"> - - - + + + + + + diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/AppData.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/AppData.java index c00eb4312d..59bffba05c 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/AppData.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/AppData.java @@ -6,8 +6,8 @@ import android.content.pm.PackageInfo; import android.content.pm.PackageManager; import android.os.SystemClock; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.util.HashMap; import java.util.Map; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Async.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Async.java index fdc334df0b..d75b61f636 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Async.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Async.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.util.concurrent.BlockingQueue; import java.util.concurrent.LinkedBlockingQueue; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/BadResponseException.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/BadResponseException.java index 81b7642764..2ef60c9ee9 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/BadResponseException.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/BadResponseException.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.util.Locale; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeNotify.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeNotify.java index a67eb3a359..8477c7f622 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeNotify.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeNotify.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * A callback to be run before reports are sent to Bugsnag. diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeRecordBreadcrumb.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeRecordBreadcrumb.java index bf9ff23e47..77753151b5 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeRecordBreadcrumb.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeRecordBreadcrumb.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * Add a "before breadcrumb" callback, to execute code before every diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeSend.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeSend.java index 41babd2b52..35a7ecb0fb 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeSend.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/BeforeSend.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * A callback to be run before every report sent to Bugsnag. diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Breadcrumb.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Breadcrumb.java index f695536866..cc39d612bf 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Breadcrumb.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Breadcrumb.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; import java.io.StringWriter; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/BreadcrumbType.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/BreadcrumbType.java index b9408a1f4e..1d69ab66c3 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/BreadcrumbType.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/BreadcrumbType.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * Recognized types of breadcrumbs diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Breadcrumbs.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Breadcrumbs.java index 5d74547b6d..18c3ddadf8 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Breadcrumbs.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Breadcrumbs.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; import java.util.Observable; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Bugsnag.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Bugsnag.java index 9c5d05f478..36cbc9af28 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Bugsnag.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Bugsnag.java @@ -2,8 +2,8 @@ import android.annotation.SuppressLint; import android.content.Context; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.util.Map; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/BugsnagException.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/BugsnagException.java index bc1cd51241..f93522f491 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/BugsnagException.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/BugsnagException.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * Used to store information about an exception that was not provided with an exception object @@ -12,9 +12,10 @@ public class BugsnagException extends Throwable { /** * The name of the exception (used instead of the exception class) */ - private final String name; + private String name; + private String message; - private String type; + private String type = Configuration.DEFAULT_EXCEPTION_TYPE; /** * Constructor @@ -27,11 +28,24 @@ public BugsnagException(@NonNull String name, @NonNull String message, @NonNull StackTraceElement[] frames) { super(message); - - super.setStackTrace(frames); + setStackTrace(frames); this.name = name; } + BugsnagException(@NonNull Throwable exc) { + super(exc.getMessage()); + + if (exc instanceof BugsnagException) { + this.message = ((BugsnagException) exc).getMessage(); + this.name = ((BugsnagException) exc).getName(); + this.type = ((BugsnagException) exc).getType(); + } else { + this.name = exc.getClass().getName(); + } + setStackTrace(exc.getStackTrace()); + initCause(exc.getCause()); + } + /** * @return The name of the exception (used instead of the exception class) */ @@ -40,11 +54,38 @@ public String getName() { return name; } + /** + * Sets the name of the error displayed in the bugsnag dashboard + * + * @param name the new name + */ + public void setName(@NonNull String name) { + this.name = name; + } + + /** + * @return The error message, which is the exception message by default + */ + @NonNull + public String getMessage() { + return message != null ? message : super.getMessage(); + } + + /** + * Sets the message of the error displayed in the bugsnag dashboard + * + * @param message the new message + */ + public void setMessage(@NonNull String message) { + this.message = message; + } + + @NonNull String getType() { return type; } - void setType(String type) { + void setType(@NonNull String type) { this.type = type; } } diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/CachedThread.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/CachedThread.java index 8c8048b5d8..9abbb69faf 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/CachedThread.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/CachedThread.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Callback.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Callback.java index bfc7f53198..d7b4ac9b12 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Callback.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Callback.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * A callback to be run before an individual report is sent to Bugsnag. diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Client.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Client.java index 67b6b8f94c..6d17d47736 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Client.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Client.java @@ -12,10 +12,10 @@ import android.content.pm.ApplicationInfo; import android.content.pm.PackageManager; import android.content.res.Resources; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; import android.text.TextUtils; import android.view.OrientationEventListener; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import kotlin.Unit; import kotlin.jvm.functions.Function1; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/ConfigFactory.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/ConfigFactory.java index a69e994ed2..60b52ee3b8 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/ConfigFactory.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/ConfigFactory.java @@ -4,8 +4,8 @@ import android.content.pm.ApplicationInfo; import android.content.pm.PackageManager; import android.os.Bundle; -import android.support.annotation.NonNull; import android.text.TextUtils; +import androidx.annotation.NonNull; class ConfigFactory { diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Configuration.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Configuration.java index a1b1d36da7..c09fd5a0c7 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Configuration.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Configuration.java @@ -1,9 +1,9 @@ package com.bugsnag.android; import android.content.Context; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; import android.text.TextUtils; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.lang.reflect.Field; import java.util.Arrays; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/ConnectivityCompat.kt b/bugsnag-android-core/src/main/java/com/bugsnag/android/ConnectivityCompat.kt index 685ace0652..94fa503e37 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/ConnectivityCompat.kt +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/ConnectivityCompat.kt @@ -8,7 +8,7 @@ import android.net.ConnectivityManager import android.net.Network import android.net.NetworkCapabilities import android.os.Build -import android.support.annotation.RequiresApi +import androidx.annotation.RequiresApi typealias NetworkChangeCallback = (connected: Boolean) -> Unit diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/DateUtils.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/DateUtils.java index 1a224debcd..8aa50b47b5 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/DateUtils.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/DateUtils.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.text.DateFormat; import java.text.ParseException; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/DefaultDelivery.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/DefaultDelivery.java index 544e987180..4c62a39072 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/DefaultDelivery.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/DefaultDelivery.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.BufferedWriter; import java.io.IOException; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Delivery.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Delivery.java index d453409b34..5aae5c394c 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Delivery.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Delivery.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * Implementations of this interface deliver Error Reports and Sessions captured to the Bugsnag API. diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/DeliveryCompat.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/DeliveryCompat.java index b711c7aa65..8b0c96b80e 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/DeliveryCompat.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/DeliveryCompat.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * A compatibility implementation of {@link Delivery} which wraps {@link ErrorReportApiClient} and diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/DeliveryFailureException.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/DeliveryFailureException.java index 8b33e257e9..4a679d2d5d 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/DeliveryFailureException.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/DeliveryFailureException.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; /** * This should be thrown if delivery of a request was not successful and you wish to try again diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/DeviceData.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/DeviceData.java index 0b2f5167e8..bef1b2a708 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/DeviceData.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/DeviceData.java @@ -11,10 +11,10 @@ import android.os.Environment; import android.os.StatFs; import android.provider.Settings; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; -import android.support.annotation.RequiresApi; import android.util.DisplayMetrics; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; +import androidx.annotation.RequiresApi; import java.io.File; import java.util.Date; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Error.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Error.java index 622a688efe..b604233f79 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Error.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Error.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.IOException; import java.util.HashMap; @@ -44,18 +44,23 @@ public class Error implements JsonStream.Streamable { private String[] projectPackages; private final Exceptions exceptions; private Breadcrumbs breadcrumbs; - private final Throwable exception; + private final BugsnagException exception; private final HandledState handledState; private final Session session; private final ThreadState threadState; private boolean incomplete = false; - Error(@NonNull Configuration config, @NonNull Throwable exception, + Error(@NonNull Configuration config, @NonNull Throwable exc, HandledState handledState, @NonNull Severity severity, Session session, ThreadState threadState) { this.threadState = threadState; this.config = config; - this.exception = exception; + + if (exc instanceof BugsnagException) { + this.exception = (BugsnagException) exc; + } else { + this.exception = new BugsnagException(exc); + } this.handledState = handledState; this.severity = severity; this.session = session; @@ -311,11 +316,14 @@ public void setMetaData(@NonNull MetaData metaData) { */ @NonNull public String getExceptionName() { - if (exception instanceof BugsnagException) { - return ((BugsnagException) exception).getName(); - } else { - return exception.getClass().getName(); - } + return exception.getName(); + } + + /** + * Sets the class name from the exception contained in this Error report. + */ + public void setExceptionName(@NonNull String exceptionName) { + exception.setName(exceptionName); } /** @@ -323,8 +331,15 @@ public String getExceptionName() { */ @NonNull public String getExceptionMessage() { - String localizedMessage = exception.getLocalizedMessage(); - return localizedMessage != null ? localizedMessage : ""; + String msg = exception.getMessage(); + return msg != null ? msg : ""; + } + + /** + * Sets the message from the exception contained in this Error report. + */ + public void setExceptionMessage(@NonNull String exceptionMessage) { + exception.setMessage(exceptionMessage); } /** diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorReader.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorReader.java index 44e030dc1d..1b75bd04e8 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorReader.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorReader.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; import android.util.JsonReader; +import androidx.annotation.NonNull; import java.io.File; import java.io.FileReader; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorReportApiClient.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorReportApiClient.java index 9efd125bb2..a346bd149e 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorReportApiClient.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorReportApiClient.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.util.Map; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorStore.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorStore.java index 9cbda2bbc1..4b8939467e 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorStore.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/ErrorStore.java @@ -1,7 +1,7 @@ package com.bugsnag.android; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.File; import java.util.ArrayList; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/EventReceiver.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/EventReceiver.java index e1747545dc..3c61786c92 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/EventReceiver.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/EventReceiver.java @@ -5,7 +5,7 @@ import android.content.Intent; import android.content.IntentFilter; import android.os.Bundle; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.util.HashMap; import java.util.Map; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/ExceptionHandler.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/ExceptionHandler.java index 79e2f79b34..c5cac823c3 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/ExceptionHandler.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/ExceptionHandler.java @@ -1,7 +1,7 @@ package com.bugsnag.android; import android.os.StrictMode; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.lang.Thread.UncaughtExceptionHandler; import java.util.Map; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Exceptions.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Exceptions.java index 692f51bc20..80fb5b1d4a 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Exceptions.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Exceptions.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; @@ -8,13 +8,13 @@ * Unwrap and serialize exception information and any "cause" exceptions. */ class Exceptions implements JsonStream.Streamable { - private final Throwable exception; + private final BugsnagException exception; private String exceptionType; private String[] projectPackages; - Exceptions(Configuration config, Throwable exception) { + Exceptions(Configuration config, BugsnagException exception) { this.exception = exception; - exceptionType = Configuration.DEFAULT_EXCEPTION_TYPE; + exceptionType = exception.getType(); projectPackages = config.getProjectPackages(); } @@ -39,7 +39,7 @@ public void toStream(@NonNull JsonStream writer) throws IOException { writer.endArray(); } - Throwable getException() { + BugsnagException getException() { return exception; } diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/FileStore.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/FileStore.java index 03e25c972b..9d084284ff 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/FileStore.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/FileStore.java @@ -1,8 +1,8 @@ package com.bugsnag.android; import android.content.Context; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.BufferedWriter; import java.io.File; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/ForegroundDetector.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/ForegroundDetector.java index a5d07c0399..9302fdf7cc 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/ForegroundDetector.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/ForegroundDetector.java @@ -4,7 +4,7 @@ import android.content.Context; import android.os.Build; import android.os.Process; -import android.support.annotation.Nullable; +import androidx.annotation.Nullable; import java.util.List; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/HandledState.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/HandledState.java index b871db49c6..75ebf8dc03 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/HandledState.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/HandledState.java @@ -1,9 +1,9 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; -import android.support.annotation.StringDef; import android.text.TextUtils; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; +import androidx.annotation.StringDef; import java.io.IOException; import java.lang.annotation.Retention; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/IOUtils.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/IOUtils.java index 766ba289e7..1bdec64cda 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/IOUtils.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/IOUtils.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.Closeable; import java.io.IOException; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/JsonStream.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/JsonStream.java index 3ecaad0f6e..0969f114be 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/JsonStream.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/JsonStream.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.BufferedReader; import java.io.File; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/MapUtils.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/MapUtils.java index cba231ffb0..14b60c1421 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/MapUtils.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/MapUtils.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.Nullable; +import androidx.annotation.Nullable; import java.util.Map; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/MetaData.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/MetaData.java index 94d81cd5fb..3fc8be9c29 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/MetaData.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/MetaData.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.IOException; import java.util.ArrayList; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/NativeInterface.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/NativeInterface.java index cc251255ad..3d5cd49203 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/NativeInterface.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/NativeInterface.java @@ -1,8 +1,8 @@ package com.bugsnag.android; import android.annotation.SuppressLint; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.util.ArrayList; import java.util.Date; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/NetworkException.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/NetworkException.java index d8d06ba493..e9d5d9d396 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/NetworkException.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/NetworkException.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.IOException; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Notifier.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Notifier.java index db414ba779..ba7d9c2bab 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Notifier.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Notifier.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; @@ -10,7 +10,7 @@ public class Notifier implements JsonStream.Streamable { private static final String NOTIFIER_NAME = "Android Bugsnag Notifier"; - private static final String NOTIFIER_VERSION = "4.17.2"; + private static final String NOTIFIER_VERSION = "4.18.0"; private static final String NOTIFIER_URL = "https://bugsnag.com"; @NonNull diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/NotifyType.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/NotifyType.java index f1f19e06ac..7d1cdcb727 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/NotifyType.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/NotifyType.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; /** * Used to inform the NDK library which type of data needs to be updated diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/ObjectJsonStreamer.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/ObjectJsonStreamer.java index d809a9190d..0fd1ae8862 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/ObjectJsonStreamer.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/ObjectJsonStreamer.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.IOException; import java.lang.reflect.Array; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Report.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Report.java index 7099f4df34..398c377aa5 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Report.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Report.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Session.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Session.java index 8eb88b204c..1992b11197 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Session.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Session.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; import java.util.Date; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionStore.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionStore.java index 1c4ac54398..a6a182b898 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionStore.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionStore.java @@ -1,7 +1,7 @@ package com.bugsnag.android; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.File; import java.util.Comparator; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTracker.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTracker.java index 6983d91e1d..f4866f41f8 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTracker.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTracker.java @@ -5,9 +5,9 @@ import android.app.Activity; import android.app.Application; import android.os.Bundle; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; -import android.support.annotation.VisibleForTesting; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; +import androidx.annotation.VisibleForTesting; import java.io.File; import java.util.Arrays; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTrackingApiClient.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTrackingApiClient.java index d270df90a6..6ea78bd6c4 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTrackingApiClient.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTrackingApiClient.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.util.Map; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTrackingPayload.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTrackingPayload.java index 55f6efe8dd..4e274052b1 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTrackingPayload.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/SessionTrackingPayload.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.File; import java.io.IOException; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Severity.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Severity.java index f788d9a172..fc26a5706f 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Severity.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Severity.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/Stacktrace.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/Stacktrace.java index ff136c274b..fc38760d93 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/Stacktrace.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/Stacktrace.java @@ -1,6 +1,6 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.io.IOException; import java.util.Arrays; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/StrictModeHandler.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/StrictModeHandler.java index f2afc3fe5e..d8b3f9dd19 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/StrictModeHandler.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/StrictModeHandler.java @@ -1,8 +1,8 @@ package com.bugsnag.android; import android.annotation.SuppressLint; -import android.support.annotation.Nullable; import android.text.TextUtils; +import androidx.annotation.Nullable; import java.util.HashMap; import java.util.Locale; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/ThreadState.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/ThreadState.java index 9f4c57c8ae..7468137e30 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/ThreadState.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/ThreadState.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.IOException; import java.util.Arrays; diff --git a/bugsnag-android-core/src/main/java/com/bugsnag/android/User.java b/bugsnag-android-core/src/main/java/com/bugsnag/android/User.java index eb9f5c5487..d88414deaf 100644 --- a/bugsnag-android-core/src/main/java/com/bugsnag/android/User.java +++ b/bugsnag-android-core/src/main/java/com/bugsnag/android/User.java @@ -1,7 +1,7 @@ package com.bugsnag.android; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.IOException; import java.util.Observable; diff --git a/bugsnag-plugin-android-anr/src/androidTest/java/com/bugsnag/android/AnrDetailsCollectorTest.kt b/bugsnag-plugin-android-anr/src/androidTest/java/com/bugsnag/android/AnrDetailsCollectorTest.kt new file mode 100644 index 0000000000..dac5b34873 --- /dev/null +++ b/bugsnag-plugin-android-anr/src/androidTest/java/com/bugsnag/android/AnrDetailsCollectorTest.kt @@ -0,0 +1,75 @@ +package com.bugsnag.android + +import android.app.ActivityManager +import org.junit.Assert.assertEquals +import org.junit.Assert.assertNull +import org.junit.Before +import org.junit.Test +import org.junit.runner.RunWith +import org.mockito.Mock +import org.mockito.Mockito +import org.mockito.junit.MockitoJUnitRunner + +@RunWith(MockitoJUnitRunner::class) +class AnrDetailsCollectorTest { + + private companion object { + private const val PID_EXAMPLE = 5902 + } + + private val collector = AnrDetailsCollector() + private val stateInfo = ActivityManager.ProcessErrorStateInfo() + private lateinit var error: Error + + @Mock + lateinit var am: ActivityManager + + @Before + fun setUp() { + stateInfo.pid = PID_EXAMPLE + stateInfo.tag = "com.bugsnag.android.example/.ExampleActivity" + stateInfo.shortMsg = "ANR Input dispatching timed out" + stateInfo.longMsg = "ANR in com.bugsnag.android.example" + + error = Error.Builder( + Configuration("f"), + RuntimeException(), + null, + Thread.currentThread(), + true + ).build() + } + + @Test + fun exceptionReturnsNull() { + Mockito.`when`(am.processesInErrorState).thenThrow(RuntimeException()) + assertNull(collector.captureProcessErrorState(am, 0)) + } + + @Test + fun emptyListReturnsNull() { + Mockito.`when`(am.processesInErrorState).thenReturn(listOf()) + assertNull(collector.captureProcessErrorState(am, 0)) + } + + @Test + fun differentPidReturnsNull() { + Mockito.`when`(am.processesInErrorState).thenReturn(listOf(stateInfo)) + val captureProcessErrorState = collector.captureProcessErrorState(am, 0) + assertNull(captureProcessErrorState) + } + + @Test + fun samePidReturnsObj() { + val second = ActivityManager.ProcessErrorStateInfo() + Mockito.`when`(am.processesInErrorState).thenReturn(listOf(stateInfo, second)) + val captureProcessErrorState = collector.captureProcessErrorState(am, PID_EXAMPLE) + assertEquals(stateInfo, captureProcessErrorState) + } + + @Test + fun anrDetailsAltered() { + collector.addErrorStateInfo(error, stateInfo) + assertEquals(stateInfo.shortMsg, error.exceptionMessage) + } +} diff --git a/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AnrDetailsCollector.kt b/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AnrDetailsCollector.kt new file mode 100644 index 0000000000..dc85f8c0ec --- /dev/null +++ b/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AnrDetailsCollector.kt @@ -0,0 +1,73 @@ +package com.bugsnag.android + +import android.app.ActivityManager +import android.app.ActivityManager.ProcessErrorStateInfo +import android.content.Context +import android.os.Handler +import android.os.HandlerThread +import android.os.Process +import androidx.annotation.VisibleForTesting +import java.util.concurrent.atomic.AtomicInteger + +internal class AnrDetailsCollector { + + companion object { + private const val INFO_POLL_THRESHOLD_MS: Long = 100 + private const val MAX_ATTEMPTS: Int = 300 + } + + private val handlerThread = HandlerThread("bugsnag-anr-collector") + + init { + handlerThread.start() + } + + fun collectAnrDetails(ctx: Context): ProcessErrorStateInfo? { + val am = ctx.getSystemService(Context.ACTIVITY_SERVICE) as ActivityManager + return captureProcessErrorState(am, Process.myPid()) + } + + /** + * Collects information about an ANR, by querying an activity manager for information about + * any proceses which are currently in an error condition. + * + * See https://developer.android.com/reference/android/app/ActivityManager.html#getProcessesInErrorState() + */ + @VisibleForTesting + internal fun captureProcessErrorState(am: ActivityManager, pid: Int): ProcessErrorStateInfo? { + return try { + val processes = am.processesInErrorState ?: emptyList() + processes.firstOrNull { it.pid == pid } + } catch (exc: RuntimeException) { + null + } + } + + internal fun addErrorStateInfo(error: Error, anrState: ProcessErrorStateInfo) { + val msg = anrState.shortMsg + error.exceptionMessage = when { + msg.startsWith("ANR") -> msg.replaceFirst("ANR", "") + else -> msg + } + } + + internal fun collectAnrErrorDetails(client: Client, error: Error) { + val handler = Handler(handlerThread.looper) + val attempts = AtomicInteger() + + handler.post(object : Runnable { + override fun run() { + val anrDetails = collectAnrDetails(client.appContext) + + if (anrDetails == null) { + if (attempts.getAndIncrement() < MAX_ATTEMPTS) { + handler.postDelayed(this, INFO_POLL_THRESHOLD_MS) + } + } else { + addErrorStateInfo(error, anrDetails) + client.notify(error, DeliveryStyle.ASYNC_WITH_CACHE, null) + } + } + }) + } +} diff --git a/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AnrPlugin.kt b/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AnrPlugin.kt index ef20bb1963..e19034da24 100644 --- a/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AnrPlugin.kt +++ b/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AnrPlugin.kt @@ -6,6 +6,8 @@ internal class AnrPlugin : BugsnagPlugin { private external fun installAnrDetection(sentinelBuffer: ByteBuffer) + private val collector = AnrDetailsCollector() + override fun initialisePlugin(client: Client) { System.loadLibrary("bugsnag-plugin-android-anr") val delegate: (Thread) -> Unit = { handleAnr(it, client) } @@ -16,12 +18,16 @@ internal class AnrPlugin : BugsnagPlugin { } private fun handleAnr(thread: Thread, client: Client) { + // generate a full report as soon as possible, then wait for extra process error info val errMsg = "Application did not respond to UI input" val exc = BugsnagException("ANR", errMsg, thread.stackTrace) + val error = Error.Builder(client.config, exc, client.sessionTracker, thread, true) + .severity(Severity.ERROR) + .severityReasonType(HandledState.REASON_ANR) + .build() - client.cacheAndNotify( - exc, Severity.ERROR, MetaData(), - HandledState.REASON_ANR, null, thread - ) + // wait and poll for error info to be collected. this occurs just before the ANR dialog + // is displayed + collector.collectAnrErrorDetails(client, error) } } diff --git a/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AppNotRespondingMonitor.java b/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AppNotRespondingMonitor.java index 49221d3919..d881d4cfa2 100644 --- a/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AppNotRespondingMonitor.java +++ b/bugsnag-plugin-android-anr/src/main/java/com/bugsnag/android/AppNotRespondingMonitor.java @@ -3,7 +3,7 @@ import android.os.Handler; import android.os.HandlerThread; import android.os.Looper; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.nio.ByteBuffer; import java.nio.ByteOrder; diff --git a/bugsnag-plugin-android-ndk/src/main/java/com/bugsnag/android/ndk/NativeBridge.java b/bugsnag-plugin-android-ndk/src/main/java/com/bugsnag/android/ndk/NativeBridge.java index 3699e11782..7b73398448 100644 --- a/bugsnag-plugin-android-ndk/src/main/java/com/bugsnag/android/ndk/NativeBridge.java +++ b/bugsnag-plugin-android-ndk/src/main/java/com/bugsnag/android/ndk/NativeBridge.java @@ -6,9 +6,9 @@ import com.bugsnag.android.NativeInterface; import android.os.Build; -import android.support.annotation.NonNull; -import android.support.annotation.Nullable; import android.util.Log; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import java.io.File; import java.util.List; diff --git a/build.gradle b/build.gradle index b08cbbe9cd..253fc85fa8 100644 --- a/build.gradle +++ b/build.gradle @@ -54,7 +54,7 @@ private void configureAndroidProject(Project proj) { lintOptions.checkAllWarnings = true def defaultConfig = proj.android.defaultConfig - defaultConfig.testInstrumentationRunner = "android.support.test.runner.AndroidJUnitRunner" + defaultConfig.testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner" defaultConfig.consumerProguardFiles = ["proguard-rules.pro"] proj.android.testOptions.unitTests.all { @@ -71,9 +71,9 @@ ext { // Note minSdkVersion must be >=21 for 64 bit architectures compileSdkVersion = 28 minSdkVersion = 14 - supportLibVersion = "28.0.0" - supportTestVersion = "0.5" - espressoVersion = "2.2.2" + supportLibVersion = "1.1.0" + supportTestVersion = "1.2.0" + espressoVersion = "3.1.0" junitVersion = "4.12" mockitoVersion = "2.28.2" bugsnagPluginVersion = "3.3.0" diff --git a/examples/sdk-app-example/build.gradle b/examples/sdk-app-example/build.gradle index 3939fc18c6..4f8b475dee 100644 --- a/examples/sdk-app-example/build.gradle +++ b/examples/sdk-app-example/build.gradle @@ -22,7 +22,7 @@ android { defaultConfig { minSdkVersion rootProject.ext.minSdkVersion targetSdkVersion rootProject.ext.compileSdkVersion - testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" + testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" signingConfig signingConfigs.config ndk { abiFilters "armeabi-v7a", "x86", "arm64-v8a", "x86_64" @@ -45,8 +45,7 @@ project.afterEvaluate { dependencies { implementation "com.bugsnag:bugsnag-android:+" - implementation "com.android.support:appcompat-v7:$supportLibVersion" - implementation "com.android.support:support-v4:$supportLibVersion" + implementation "androidx.appcompat:appcompat:1.0.2" implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/examples/sdk-app-example/src/main/java/com.bugsnag.android/example/ExampleActivity.kt b/examples/sdk-app-example/src/main/java/com.bugsnag.android/example/ExampleActivity.kt index 3d71a20ac0..371c953855 100644 --- a/examples/sdk-app-example/src/main/java/com.bugsnag.android/example/ExampleActivity.kt +++ b/examples/sdk-app-example/src/main/java/com.bugsnag.android/example/ExampleActivity.kt @@ -3,7 +3,7 @@ package com.bugsnag.android.example import android.content.Intent import android.net.Uri import android.os.Bundle -import android.support.v7.app.AppCompatActivity +import androidx.appcompat.app.AppCompatActivity import android.view.View import android.widget.Toast import android.widget.Toast.LENGTH_SHORT diff --git a/features/fixtures/mazerunner/build.gradle b/features/fixtures/mazerunner/build.gradle index 497746ed00..3773a56e2a 100644 --- a/features/fixtures/mazerunner/build.gradle +++ b/features/fixtures/mazerunner/build.gradle @@ -74,7 +74,7 @@ android { dependencies { implementation "com.bugsnag:bugsnag-android:+" implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" - api "com.android.support:support-annotations:28.0.0" + implementation "androidx.annotation:annotation:1.1.0" } apply plugin: 'com.bugsnag.android.gradle' diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/BeforeSendScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/BeforeSendScenario.java index b28535b981..ddfd4c19ee 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/BeforeSendScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/BeforeSendScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Report; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class BeforeSendScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAbortScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAbortScenario.java index 0b39f2be35..8e461d26dc 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAbortScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAbortScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXAbortScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAutoContextScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAutoContextScenario.java index 1053e73db1..acf2365421 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAutoContextScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAutoContextScenario.java @@ -8,7 +8,7 @@ import com.bugsnag.android.Configuration; import com.bugsnag.android.mazerunner.SecondActivity; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXAutoContextScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXBreadcrumbScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXBreadcrumbScenario.java index c9175b08d4..b0023e8495 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXBreadcrumbScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXBreadcrumbScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXBreadcrumbScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeCrashScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeCrashScenario.java index 14123468ce..55ebef6502 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeCrashScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeCrashScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; import com.bugsnag.android.Bugsnag; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.lang.reflect.Array; diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeNotifyScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeNotifyScenario.java index fa6cb42137..4a9773ac73 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeNotifyScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeNotifyScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; import com.bugsnag.android.Bugsnag; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.lang.reflect.Array; diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedCrashScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedCrashScenario.java index 2a5a49367b..08e70b5b54 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedCrashScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedCrashScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import android.content.Intent; import android.os.Handler; diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedNotifyScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedNotifyScenario.java index 231c4a415a..19a31e165d 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedNotifyScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedNotifyScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXDelayedNotifyScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDivideByZeroScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDivideByZeroScenario.java index 67d280adb9..6ccc0d9170 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDivideByZeroScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDivideByZeroScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXDivideByZeroScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDoubleFreeScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDoubleFreeScenario.java index 6a376a6219..8e5696a630 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDoubleFreeScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDoubleFreeScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXDoubleFreeScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExceptionScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExceptionScenario.java index 46263a1c5c..84f923095d 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExceptionScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExceptionScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXExceptionScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExternalStackElementScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExternalStackElementScenario.java index a3edd0ac0e..a24efeae95 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExternalStackElementScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExternalStackElementScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXExternalStackElementScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExtraordinaryLongStringScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExtraordinaryLongStringScenario.java index fa29a566f0..5744fb86bc 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExtraordinaryLongStringScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExtraordinaryLongStringScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXExtraordinaryLongStringScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXImproperTypecastScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXImproperTypecastScenario.java index 4dc3d0eb66..8192f41cb4 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXImproperTypecastScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXImproperTypecastScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXImproperTypecastScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeBreadcrumbScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeBreadcrumbScenario.java index 95a7adff9d..2a0062b817 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeBreadcrumbScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeBreadcrumbScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXJavaBreadcrumbNativeBreadcrumbScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeCrashScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeCrashScenario.java index 1225f512b3..7f00aa636e 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeCrashScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeCrashScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXJavaBreadcrumbNativeCrashScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeNotifyScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeNotifyScenario.java index be92e7735c..38542a7b01 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeNotifyScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeNotifyScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXJavaBreadcrumbNativeNotifyScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaUserInfoNativeCrashScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaUserInfoNativeCrashScenario.java index 868ffe73c0..8f832914cb 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaUserInfoNativeCrashScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaUserInfoNativeCrashScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXJavaUserInfoNativeCrashScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaCrashScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaCrashScenario.java index a63cb8a7f4..0efd513dd3 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaCrashScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaCrashScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.lang.reflect.Array; diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaNotifyScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaNotifyScenario.java index 7a20ceed00..39185726ee 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaNotifyScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaNotifyScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXNativeBreadcrumbJavaNotifyScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbNativeCrashScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbNativeCrashScenario.java index 1d4774a07e..9a3ac5da13 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbNativeCrashScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbNativeCrashScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXNativeBreadcrumbNativeCrashScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNotifyScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNotifyScenario.java index 7f099b96ac..f83ba68686 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNotifyScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNotifyScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXNotifyScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNullPointerScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNullPointerScenario.java index ac8de95c55..f3fb2feeaf 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNullPointerScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNullPointerScenario.java @@ -2,7 +2,7 @@ import android.content.Context; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXNullPointerScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSessionInfoCrashScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSessionInfoCrashScenario.java index 827ab49ec7..0f46fa3e34 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSessionInfoCrashScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSessionInfoCrashScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSessionInfoCrashScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigabrtScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigabrtScenario.java index fac9fa8440..ace9a4a849 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigabrtScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigabrtScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigabrtScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigbusScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigbusScenario.java index 8ef2a8792e..d6aab4d690 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigbusScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigbusScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigbusScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigfpeScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigfpeScenario.java index c2914c56bd..79730c7e41 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigfpeScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigfpeScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigfpeScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigillScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigillScenario.java index ebf9e3facc..1ef909352f 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigillScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigillScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigillScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigsegvScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigsegvScenario.java index 7c0f42d091..d2786c5898 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigsegvScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigsegvScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigsegvScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigtrapScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigtrapScenario.java index 3db6c0e2d2..69d94424b5 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigtrapScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigtrapScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigtrapScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStackoverflowScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStackoverflowScenario.java index b9c2f2144c..c0cc8376eb 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStackoverflowScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStackoverflowScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXStackoverflowScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStartSessionScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStartSessionScenario.java index b53e885303..a351f853ee 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStartSessionScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStartSessionScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXStartSessionScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStopSessionScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStopSessionScenario.java index f1089c74b3..d34c2ea95f 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStopSessionScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStopSessionScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXStopSessionScenario extends Scenario { static { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXThrowSomethingScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXThrowSomethingScenario.java index 546a0ffd87..b031acf39e 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXThrowSomethingScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXThrowSomethingScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXThrowSomethingScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXTrapScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXTrapScenario.java index 285eea1b8f..86dc94d3aa 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXTrapScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXTrapScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXTrapScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUpdateContextCrashScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUpdateContextCrashScenario.java index df18f61903..3cec985952 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUpdateContextCrashScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUpdateContextCrashScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Configuration; import android.content.Intent; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import com.bugsnag.android.mazerunner.SecondActivity; diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUserInfoScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUserInfoScenario.java index 3442813885..9e7208331a 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUserInfoScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUserInfoScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXUserInfoScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXWriteReadOnlyMemoryScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXWriteReadOnlyMemoryScenario.java index 4501b54304..2a406fc734 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXWriteReadOnlyMemoryScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXWriteReadOnlyMemoryScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXWriteReadOnlyMemoryScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkDisabledScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkDisabledScenario.java index fa445d4d10..7e2ab0ae6f 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkDisabledScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkDisabledScenario.java @@ -2,7 +2,7 @@ import android.content.Context; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class DetectNdkDisabledScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkEnabledScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkEnabledScenario.java index 10e6896bd8..f4ecc0f25a 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkEnabledScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkEnabledScenario.java @@ -2,7 +2,7 @@ import android.content.Context; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class DetectNdkEnabledScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/HandledExceptionJavaScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/HandledExceptionJavaScenario.java index aa0659a2d4..af43f37735 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/HandledExceptionJavaScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/HandledExceptionJavaScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * Sends a handled exception to Bugsnag, which does not include session data. diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeBeforeSendScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeBeforeSendScenario.java index 9370637e7e..222c592f60 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeBeforeSendScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeBeforeSendScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Report; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class NativeBeforeSendScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeNotifyBeforeSendScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeNotifyBeforeSendScenario.java index 22c9e1fe58..8676a0294d 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeNotifyBeforeSendScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeNotifyBeforeSendScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Report; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class NativeNotifyBeforeSendScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendScenario.java index 8d1bb800f6..7af3ee42ab 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Severity; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class NotifyBeforeSendScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendUnsetContextScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendUnsetContextScenario.java index 92b27b093b..0b15811fdb 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendUnsetContextScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendUnsetContextScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Severity; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class NotifyBeforeSendUnsetContextScenario extends Scenario { diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnhandledExceptionJavaScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnhandledExceptionJavaScenario.java index 775161cc37..e7202f6659 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnhandledExceptionJavaScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnhandledExceptionJavaScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * Sends an unhandled exception to Bugsnag. diff --git a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnsatisfiedLinkErrorScenario.java b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnsatisfiedLinkErrorScenario.java index 6d27d151e3..bef9746229 100644 --- a/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnsatisfiedLinkErrorScenario.java +++ b/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnsatisfiedLinkErrorScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class UnsatisfiedLinkErrorScenario extends Scenario { diff --git a/gradle.properties b/gradle.properties index 6837afdb8d..3982630a92 100644 --- a/gradle.properties +++ b/gradle.properties @@ -11,7 +11,7 @@ org.gradle.jvmargs=-Xmx1536m # This option should only be used with decoupled projects. More details, visit # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects # org.gradle.parallel=true -VERSION_NAME=4.17.2 +VERSION_NAME=4.18.0 GROUP=com.bugsnag POM_SCM_URL=https://github.com/bugsnag/bugsnag-android POM_SCM_CONNECTION=scm:git@github.com:bugsnag/bugsnag-android.git @@ -28,3 +28,5 @@ POM_PACKAGING=aar ANDROID_MIN_SDK_VERSION=14 ANDROID_TARGET_SDK_VERSION=28 ANDROID_COMPILE_SDK_VERSION=28 +android.useAndroidX=true +android.enableJetifier=true diff --git a/gradle/dependencies.gradle b/gradle/dependencies.gradle index 4712acef26..40b8e4ed99 100644 --- a/gradle/dependencies.gradle +++ b/gradle/dependencies.gradle @@ -1,5 +1,5 @@ dependencies { - api "com.android.support:support-annotations:$supportLibVersion" + api "androidx.annotation:annotation:$supportLibVersion" api "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" @@ -8,15 +8,10 @@ dependencies { androidTestImplementation "org.mockito:mockito-android:$mockitoVersion" - androidTestImplementation "com.android.support.test:runner:$supportTestVersion", { - exclude group: "com.android.support", module: "support-annotations" - } - androidTestImplementation "com.android.support.test:rules:$supportTestVersion", { - exclude group: "com.android.support", module: "support-annotations" - } - androidTestImplementation "com.android.support.test.espresso:espresso-core:$espressoVersion", { - exclude group: "com.android.support", module: "support-annotations" - } + androidTestImplementation "androidx.test:core:$supportTestVersion" + androidTestImplementation "androidx.test:runner:$supportTestVersion" + androidTestImplementation "androidx.test:rules:$supportTestVersion" + androidTestImplementation "androidx.test.espresso:espresso-core:$espressoVersion" if (project.hasProperty("infer")) { implementation "com.facebook.infer.annotation:infer-annotation:0.11.2" diff --git a/tests/features/fixtures/mazerunner/build.gradle b/tests/features/fixtures/mazerunner/build.gradle index 497746ed00..3773a56e2a 100644 --- a/tests/features/fixtures/mazerunner/build.gradle +++ b/tests/features/fixtures/mazerunner/build.gradle @@ -74,7 +74,7 @@ android { dependencies { implementation "com.bugsnag:bugsnag-android:+" implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" - api "com.android.support:support-annotations:28.0.0" + implementation "androidx.annotation:annotation:1.1.0" } apply plugin: 'com.bugsnag.android.gradle' diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/BeforeSendScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/BeforeSendScenario.java index f4bf4483a5..a3101841c7 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/BeforeSendScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/BeforeSendScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Report; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class BeforeSendScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAbortScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAbortScenario.java index b9ac3900a5..3c86c3ca09 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAbortScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAbortScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXAbortScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAutoContextScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAutoContextScenario.java index 1053e73db1..acf2365421 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAutoContextScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXAutoContextScenario.java @@ -8,7 +8,7 @@ import com.bugsnag.android.Configuration; import com.bugsnag.android.mazerunner.SecondActivity; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXAutoContextScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXBreadcrumbScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXBreadcrumbScenario.java index b874f71b11..eedb8d94ba 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXBreadcrumbScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXBreadcrumbScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXBreadcrumbScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeCrashScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeCrashScenario.java index eadb381977..2528033f57 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeCrashScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeCrashScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; import com.bugsnag.android.Bugsnag; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.lang.reflect.Array; diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeNotifyScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeNotifyScenario.java index 25e0805a03..f749f353d4 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeNotifyScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXCustomMetadataNativeNotifyScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; import com.bugsnag.android.Bugsnag; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.lang.reflect.Array; diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedCrashScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedCrashScenario.java index 7018856534..b87f2ce809 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedCrashScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedCrashScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import android.content.Intent; import android.os.Handler; diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedNotifyScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedNotifyScenario.java index c7a7f1277f..d1554d87df 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedNotifyScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDelayedNotifyScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXDelayedNotifyScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDoubleFreeScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDoubleFreeScenario.java index 772a57152a..da0605e8d0 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDoubleFreeScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXDoubleFreeScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXDoubleFreeScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExceptionScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExceptionScenario.java index 88586e12f6..0e169f3848 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExceptionScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExceptionScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXExceptionScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExternalStackElementScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExternalStackElementScenario.java index 5ded6b740f..900dfd3b0b 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExternalStackElementScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExternalStackElementScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXExternalStackElementScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExtraordinaryLongStringScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExtraordinaryLongStringScenario.java index ed4b17531a..1672c04fb6 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExtraordinaryLongStringScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXExtraordinaryLongStringScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXExtraordinaryLongStringScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXImproperTypecastScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXImproperTypecastScenario.java index 7a8f0025db..f72fe62de1 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXImproperTypecastScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXImproperTypecastScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXImproperTypecastScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeBreadcrumbScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeBreadcrumbScenario.java index d79786641c..22a2c1ee91 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeBreadcrumbScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeBreadcrumbScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXJavaBreadcrumbNativeBreadcrumbScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeCrashScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeCrashScenario.java index aab321af25..50305ed6d5 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeCrashScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeCrashScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXJavaBreadcrumbNativeCrashScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeNotifyScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeNotifyScenario.java index c30012d67b..af496ad945 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeNotifyScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaBreadcrumbNativeNotifyScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXJavaBreadcrumbNativeNotifyScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaUserInfoNativeCrashScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaUserInfoNativeCrashScenario.java index 193b5c3b08..2a123ff1c4 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaUserInfoNativeCrashScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXJavaUserInfoNativeCrashScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXJavaUserInfoNativeCrashScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaCrashScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaCrashScenario.java index 5cde81bbf5..f2786aa30e 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaCrashScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaCrashScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import java.lang.reflect.Array; diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaNotifyScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaNotifyScenario.java index 6e278c9366..440095be22 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaNotifyScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbJavaNotifyScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXNativeBreadcrumbJavaNotifyScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbNativeCrashScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbNativeCrashScenario.java index b38b5c4b99..f34099b361 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbNativeCrashScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNativeBreadcrumbNativeCrashScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXNativeBreadcrumbNativeCrashScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNotifyScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNotifyScenario.java index aca7b24200..95851150c5 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNotifyScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNotifyScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXNotifyScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNullPointerScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNullPointerScenario.java index c5a59af2a6..d42638b8c8 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNullPointerScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXNullPointerScenario.java @@ -2,7 +2,7 @@ import android.content.Context; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXNullPointerScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSessionInfoCrashScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSessionInfoCrashScenario.java index a5d5d1040c..677c2fbfd6 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSessionInfoCrashScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSessionInfoCrashScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Configuration; import com.bugsnag.android.TestHarnessHooksKt; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSessionInfoCrashScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigabrtScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigabrtScenario.java index 8584be0493..74acb3ea58 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigabrtScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigabrtScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigabrtScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigbusScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigbusScenario.java index 8904774054..0f042dd099 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigbusScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigbusScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigbusScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigfpeScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigfpeScenario.java index c897e8c924..f37e94f49f 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigfpeScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigfpeScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigfpeScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigillScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigillScenario.java index 7765275a63..7ef349aeae 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigillScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigillScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigillScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigsegvScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigsegvScenario.java index 463325d691..b8f75288d8 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigsegvScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigsegvScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigsegvScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigtrapScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigtrapScenario.java index cc618a469d..e14c52cb6e 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigtrapScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXSigtrapScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXSigtrapScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStackoverflowScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStackoverflowScenario.java index 537d294b49..82e4fd6814 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStackoverflowScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStackoverflowScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXStackoverflowScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStartSessionScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStartSessionScenario.java index 1a9dc86521..42395e70cf 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStartSessionScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStartSessionScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Configuration; import com.bugsnag.android.TestHarnessHooksKt; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXStartSessionScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStopSessionScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStopSessionScenario.java index d146cf7c81..0ff24a9476 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStopSessionScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXStopSessionScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Configuration; import com.bugsnag.android.TestHarnessHooksKt; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXStopSessionScenario extends Scenario { static { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXThrowSomethingScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXThrowSomethingScenario.java index c11e3cd710..581d4dfa74 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXThrowSomethingScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXThrowSomethingScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXThrowSomethingScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXTrapScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXTrapScenario.java index 43e31a52b6..b3e14c4055 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXTrapScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXTrapScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXTrapScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUpdateContextCrashScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUpdateContextCrashScenario.java index ee19714775..6901be151a 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUpdateContextCrashScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUpdateContextCrashScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Configuration; import android.content.Intent; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; import com.bugsnag.android.mazerunner.SecondActivity; diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUserInfoScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUserInfoScenario.java index 5efae7ffaa..29e28bd9e8 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUserInfoScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXUserInfoScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXUserInfoScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXWriteReadOnlyMemoryScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXWriteReadOnlyMemoryScenario.java index 043db0782b..7302e9f206 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXWriteReadOnlyMemoryScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/CXXWriteReadOnlyMemoryScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class CXXWriteReadOnlyMemoryScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkDisabledScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkDisabledScenario.java index 6dce99c120..972d4b73b7 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkDisabledScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkDisabledScenario.java @@ -2,7 +2,7 @@ import android.content.Context; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class DetectNdkDisabledScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkEnabledScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkEnabledScenario.java index 31d8d04397..126a313aa0 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkEnabledScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/DetectNdkEnabledScenario.java @@ -2,7 +2,7 @@ import android.content.Context; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class DetectNdkEnabledScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/HandledExceptionJavaScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/HandledExceptionJavaScenario.java index 18fe3a5f95..1aa507dddf 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/HandledExceptionJavaScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/HandledExceptionJavaScenario.java @@ -5,7 +5,7 @@ import com.bugsnag.android.Bugsnag; import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * Sends a handled exception to Bugsnag, which does not include session data. diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeBeforeSendScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeBeforeSendScenario.java index 6b2e03e279..abd6259b0e 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeBeforeSendScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeBeforeSendScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Report; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class NativeBeforeSendScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeNotifyBeforeSendScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeNotifyBeforeSendScenario.java index 88f1107f9d..6af38feb02 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeNotifyBeforeSendScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NativeNotifyBeforeSendScenario.java @@ -6,7 +6,7 @@ import com.bugsnag.android.Report; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class NativeNotifyBeforeSendScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendScenario.java index 976bb85fcb..89440e870f 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Severity; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class NotifyBeforeSendScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendUnsetContextScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendUnsetContextScenario.java index 844c68fe3f..3f777ffbdc 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendUnsetContextScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NotifyBeforeSendUnsetContextScenario.java @@ -7,7 +7,7 @@ import com.bugsnag.android.Severity; import android.content.Context; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class NotifyBeforeSendUnsetContextScenario extends Scenario { diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnhandledExceptionJavaScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnhandledExceptionJavaScenario.java index 962fa0febf..fad9d53875 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnhandledExceptionJavaScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnhandledExceptionJavaScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; /** * Sends an unhandled exception to Bugsnag. diff --git a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnsatisfiedLinkErrorScenario.java b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnsatisfiedLinkErrorScenario.java index f59b32de0a..0a7679eeac 100644 --- a/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnsatisfiedLinkErrorScenario.java +++ b/tests/features/fixtures/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/UnsatisfiedLinkErrorScenario.java @@ -4,7 +4,7 @@ import com.bugsnag.android.Configuration; -import android.support.annotation.NonNull; +import androidx.annotation.NonNull; public class UnsatisfiedLinkErrorScenario extends Scenario {