Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

Release/v6.6.0 #2042

Closed
wants to merge 37 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
baadae6
feat(correlation): added the trace correlation property to the Event …
lemnik Apr 25, 2024
187e954
Merge pull request #2023 from bugsnag/PLAT-12049/correlation-event-model
lemnik Apr 29, 2024
b00e1b8
Merge pull request #2029 from bugsnag/master
lemnik May 16, 2024
084df8b
Add Android 14 tests
twometresteve May 15, 2024
950d5a2
Merge branch 'next' into tms/android-14
twometresteve May 18, 2024
c61bd2b
Merge pull request #2032 from bugsnag/tms/android-14
twometresteve May 21, 2024
df65b5f
refactor(ndk): added BSG_KSJSONCodec to the NDK plugin
lemnik May 1, 2024
6c59e8f
refactor(ndk): add simplified ISO 8601 time formatting to BSG_KSCrash…
lemnik May 2, 2024
7681abf
refactor(ndk): rewrote the event_writer.c to output JSON instead of a…
lemnik May 2, 2024
481b0de
refactor(ndk): removed old binary-dump event logic & added a new test…
lemnik May 9, 2024
6d74432
fix(ndk): fixed a bug where the breadcrumb metadata was double-nested
lemnik May 9, 2024
6f06a86
fix(ndk): moved the NDK JSON payloads back to their own directory so …
lemnik May 9, 2024
a1882f6
fix(ndk): BugsnagEventMapper now handles date formats in the "t{epoch…
lemnik May 13, 2024
dd2f56a
fix(ndk): added thread.type to ndk events, and removed invalid / paus…
lemnik May 13, 2024
09751aa
fix(ndk): fixed NDK thread writing behaviour
lemnik May 13, 2024
ece1825
fix(ndk): added the static usage metrics data to the native events
lemnik May 14, 2024
0abb887
test(ndk): added a basic ReportDiscardScanner test
lemnik May 15, 2024
6c17539
refactor(ndk event): replaced STRING_**_EMPTY macros with inline func…
lemnik May 21, 2024
74b6001
refactor(ndk event): copy the entire event_path instead of relying on…
lemnik May 21, 2024
3161e39
refactor(ndk event): NaN & Inf values are encoded to JSON as 'null'
lemnik May 22, 2024
308c95f
Merge pull request #2027 from bugsnag/PLAT-12009/json-event
lemnik May 22, 2024
6c29641
Update AGP and related versions for mazerunner (#2030)
YYChen01988 May 22, 2024
9f62d7a
fix(Session Tracker) fixed logic of discarding session (#2033)
YYChen01988 May 24, 2024
5bc8d99
fix(errorCallback) separating throw exception out (#2036)
YYChen01988 May 31, 2024
2201a50
refactor(ndk event): iterate directly over metadata elements in NDK i…
lemnik May 30, 2024
9a6104c
test(ndk): fixed event_serialization.json to align with the expected …
lemnik May 30, 2024
af3f5bc
test(ndk): manually cause a stack-overflow in CXXStackoverflowScenari…
lemnik May 30, 2024
2cce055
Merge pull request #2035 from bugsnag/PLAT-12075/ndk-metadata-iterator
lemnik Jun 4, 2024
d5ac07d
Reinstate instrumentation tests using MacOS test boxes as a platform …
Cawllec Jun 6, 2024
843bdb7
Merge branch 'next' into integration/error-correlation
lemnik Jun 12, 2024
5040101
feat(native): support kernels running with a 16kB page size
lemnik Jun 13, 2024
341930e
feat(event correlation): changed the casing of the `traceid`->`traceI…
lemnik Jun 13, 2024
e87cc38
Merge pull request #2040 from bugsnag/PLAT-12268/16kb-page-support
lemnik Jun 13, 2024
e7eaf36
Merge branch 'next' into integration/error-correlation
lemnik Jun 13, 2024
1f49c06
chore(changelog): fixed the CHANGELOG entry for PR#2040
lemnik Jun 13, 2024
02dfd6e
Merge pull request #2038 from bugsnag/integration/error-correlation
lemnik Jun 13, 2024
e8d6bdc
release/v6.6.0
YYChen01988 Jun 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
test(ndk): added a basic ReportDiscardScanner test
  • Loading branch information
lemnik committed May 22, 2024
commit 0abb887035ef4b664109fbd1a3d48ee35d5093e3
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
package com.bugsnag.android.ndk

import com.bugsnag.android.Client
import com.bugsnag.android.Logger
import com.bugsnag.android.NativeInterface
import org.junit.Assert.assertTrue
import org.junit.Before
import org.junit.Test
import org.junit.runner.RunWith
import org.mockito.Mock
import org.mockito.junit.MockitoJUnitRunner
import java.io.File

@RunWith(MockitoJUnitRunner::class)
class ReportDiscardScannerTest {
@Mock
lateinit var client: Client

@Before
fun setupNativeInterface() {
NativeInterface.setClient(client)
}

@Test
fun discardStaticData() {
val discardScanner = ReportDiscardScanner(object : Logger {}, emptySet())
assertTrue(discardScanner.shouldDiscard(File("/data/data/something/there_is_some.static_data.json")))
}

@Test
fun discardNonJson() {
val discardScanner = ReportDiscardScanner(object : Logger {}, emptySet())
assertTrue(discardScanner.shouldDiscard(File("/data/data/683c6b92-b325-4987-80ad-77086509ca1e.dump")))
assertTrue(discardScanner.shouldDiscard(File("/data/data/683c6b92-b325-4987-80ad-77086509ca1e.binary")))
assertTrue(discardScanner.shouldDiscard(File("/data/data/something_not_quite.static_data.binary")))
assertTrue(discardScanner.shouldDiscard(File("/data/data/data.binary")))
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,18 +2,29 @@ package com.bugsnag.android.ndk

import android.util.JsonReader
import android.util.JsonToken
import androidx.annotation.VisibleForTesting
import com.bugsnag.android.Logger
import com.bugsnag.android.NativeInterface
import java.io.File

internal class ReportDiscardScanner(private val logger: Logger) {
internal class ReportDiscardScanner(
private val logger: Logger,
private val enabledReleaseStages: Collection<String> =
NativeInterface.getEnabledReleaseStages() ?: emptySet(),
) {
/**
* Checks whether a given report file should be discarded due to its `releaseStage` or any of
* the configured `discardClasses`.
*
* @return true if the report should be discarded instead of being sent
*/
fun shouldDiscard(report: File): Boolean {
if (!report.name.endsWith(".json") ||
report.name.endsWith(".static_data.json")
) {
return true
}

return try {
report.bufferedReader().use { reader ->
JsonReader(reader).use { json -> shouldDiscard(json) }
Expand All @@ -23,7 +34,8 @@ internal class ReportDiscardScanner(private val logger: Logger) {
}
}

private fun shouldDiscard(json: JsonReader): Boolean {
@VisibleForTesting
internal fun shouldDiscard(json: JsonReader): Boolean {
json.beginObject()
var pendingAppCheck = true
var pendingExceptionsCheck = true
Expand Down Expand Up @@ -56,8 +68,7 @@ internal class ReportDiscardScanner(private val logger: Logger) {
}

private fun shouldDiscardForApp(json: JsonReader): Boolean {
val enabledReleaseStages = NativeInterface.getEnabledReleaseStages()
if (enabledReleaseStages.isNullOrEmpty()) {
if (enabledReleaseStages.isEmpty()) {
json.skipValue()
return false
}
Expand All @@ -69,7 +80,6 @@ internal class ReportDiscardScanner(private val logger: Logger) {
"releaseStage" -> {
val releaseStage = json.nextString()
if (releaseStage !in enabledReleaseStages) {
logger.d("Discarding native report due to releaseStage")
return true
}
// do not early exit, make sure the entire "app" object is consumed
Expand Down