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

Changes in the Session Test App to verify Fireperf #no-changelog #6809

Merged
merged 15 commits into from
Mar 31, 2025

Conversation

tejasd
Copy link
Contributor

@tejasd tejasd commented Mar 25, 2025

This change adds a way to repeatedly log identical performance traces in different processes.

  • Currently traces on different activities are logged on different Fireperf Sessions by default.
  • Adds additional logging to help identify different Firebase instances in different processes.
  • Adds Fireperf custom attributes to identify processes.

I used this change to verify the behavior of duplicate traces in a single session. I've also used a manual UUID to simulate an identical session ID across two different processes.

no-changelog

Copy link
Contributor

github-actions bot commented Mar 25, 2025

📝 PRs merging into main branch

Our main branch should always be in a releasable state. If you are working on a larger change, or if you don't want this change to see the light of the day just yet, consider using a feature branch first, and only merge into the main branch when the code complete and ready to be released.

@google-oss-bot
Copy link
Contributor

1 Warning
⚠️ Did you forget to add a changelog entry? (Add the 'no-changelog' label to the PR to silence this warning.)

Generated by 🚫 Danger

@google-oss-bot
Copy link
Contributor

google-oss-bot commented Mar 25, 2025

Coverage Report 1

Affected Products

  • firebase-sessions

    Overall coverage changed from 66.52% (d2e72df) to 66.67% (8933e07) by +0.14%.

    FilenameBase (d2e72df)Merge (8933e07)Diff
    RemoteSettings.kt87.32%88.73%+1.41%
    SessionLifecycleService.kt78.41%78.65%+0.24%

Test Logs

  1. https://storage.googleapis.com/firebase-sdk-metric-reports/c4I1151bfH.html

Copy link
Contributor

github-actions bot commented Mar 25, 2025

Test Results

 38 files   -    981   38 suites   - 981   52s ⏱️ - 33m 14s
 94 tests  -  5 778   94 ✅  -  5 755  0 💤  - 22  0 ❌  - 1 
188 runs   - 11 466  188 ✅  - 11 421  0 💤  - 44  0 ❌  - 1 

Results for commit 4c5fe51. ± Comparison against base commit d2e72df.

This pull request removes 5778 tests.
com.google.android.datatransport.cct.CctBackendFactoryTest ‑ create_returnCCTBackend_WhenBackendNameIsCCT
com.google.android.datatransport.cct.CctDestinationTest ‑ cctDestination_shouldOnlySupportProtoAndJson
com.google.android.datatransport.cct.CctDestinationTest ‑ cctDestination_shouldSupportProtoAndJson
com.google.android.datatransport.cct.CctTransportBackendTest ‑ decorate_whenOffline_shouldProperlyPopulateNetworkInfo
com.google.android.datatransport.cct.CctTransportBackendTest ‑ decorate_whenOnline_shouldProperlyPopulateNetworkInfo
com.google.android.datatransport.cct.CctTransportBackendTest ‑ schedule_shouldAddCookieOnPseudonymousIds
com.google.android.datatransport.cct.CctTransportBackendTest ‑ schedule_shouldDropCookieOnMixedPseudonymousIds
com.google.android.datatransport.cct.CctTransportBackendTest ‑ send_CompressedResponseIsUncompressed
com.google.android.datatransport.cct.CctTransportBackendTest ‑ send_whenBackendRedirectsMoreThan5Times_shouldOnlyRedirect4Times
com.google.android.datatransport.cct.CctTransportBackendTest ‑ send_whenBackendRedirects_shouldCorrectlyFollowTheRedirectViaPost
…

♻️ This comment has been updated with latest results.

@google-oss-bot
Copy link
Contributor

google-oss-bot commented Mar 25, 2025

Size Report 1

Affected Products

  • firebase-sessions

    TypeBase (d2e72df)Merge (8933e07)Diff
    aar203 kB203 kB+59 B (+0.0%)
    apk (aggressive)644 kB645 kB+80 B (+0.0%)
    apk (release)6.31 MB6.31 MB+88 B (+0.0%)

Test Logs

  1. https://storage.googleapis.com/firebase-sdk-metric-reports/u8JhG5LOCw.html

@tejasd tejasd changed the title Add buttons to log an identical performance trace across processes Changes in the Session Test App to verify Fireperf #no-changelog Mar 27, 2025
@tejasd tejasd requested review from mrober and themiswang March 28, 2025 19:30
@tejasd
Copy link
Contributor Author

tejasd commented Mar 31, 2025

The failing integration test seems to be flaky but it passed locally. Ignoring it for now.

expected: acd7861618564bb38e7fd3e81ea8891e
but was : No Session Id
	at com.google.firebase.testing.sessions.FirebaseSessionsIntegrationTest.sameSessionIdAfterQuickForegroundBackground(FirebaseSessionsIntegrationTest.kt:74)

@google-oss-bot
Copy link
Contributor

Startup Time Report 1

Note: Layout is sometimes suboptimal due to limited formatting support on GitHub. Please check this report on GCS.

Notes

Startup Times

  • fire-cls

    DeviceStatisticsDistributions
    oriole-32
    Percentiled2e72df8933e07DiffSignificant (?)
    p109.39 ±2 ms9.68 ±2 ms+285 μs (+3.0%)NO
    p259.85 ±2 ms10.3 ±2 ms+421 μs (+4.3%)NO
    p5010.6 ±2 ms11.1 ±2 ms+442 μs (+4.2%)NO
    p7511.6 ±2 ms12.2 ±2 ms+546 μs (+4.7%)NO
    p9012.9 ±3 ms13.5 ±2 ms+539 μs (+4.2%)NO

    20 test runs in comparison
    CommitTest Runs
    d2e72df
    • 2025-03-28_23:42:10.593191_Zsds
    • 2025-03-28_23:42:10.593228_Uifg
    • 2025-03-28_23:42:10.593240_AVtD
    • 2025-03-28_23:42:10.593248_uZHI
    • 2025-03-28_23:42:10.593255_FjOS
    • 2025-03-28_23:42:10.593263_yUWG
    • 2025-03-28_23:42:10.593270_EfIs
    • 2025-03-28_23:42:10.593276_eEzV
    • 2025-03-28_23:42:10.593282_BeHp
    • 2025-03-28_23:42:10.593289_KpOp
    8933e07
    • 2025-03-31_15:49:33.615467_cPhC
    • 2025-03-31_15:49:33.615507_BdYh
    • 2025-03-31_15:49:33.615524_fqax
    • 2025-03-31_15:49:33.615533_pkRd
    • 2025-03-31_15:49:33.615540_dLhc
    • 2025-03-31_15:49:33.615547_TyDu
    • 2025-03-31_15:49:33.615555_PzcS
    • 2025-03-31_15:49:33.615561_PxlZ
    • 2025-03-31_15:49:33.615567_QRBL
    • 2025-03-31_15:49:33.615573_IQVG
    redfin-30
    Percentiled2e72df8933e07DiffSignificant (?)
    p1012.2 ±4 ms10.9 ±3 ms-1.32 ms (-10.8%)NO
    p2512.7 ±4 ms11.6 ±4 ms-1.14 ms (-8.9%)NO
    p5013.7 ±5 ms12.4 ±4 ms-1.25 ms (-9.2%)NO
    p7515.0 ±6 ms13.6 ±5 ms-1.41 ms (-9.4%)NO
    p9017.3 ±7 ms15.6 ±6 ms-1.70 ms (-9.8%)NO

    20 test runs in comparison
    CommitTest Runs
    d2e72df
    • 2025-03-28_23:42:10.593191_Zsds
    • 2025-03-28_23:42:10.593228_Uifg
    • 2025-03-28_23:42:10.593240_AVtD
    • 2025-03-28_23:42:10.593248_uZHI
    • 2025-03-28_23:42:10.593255_FjOS
    • 2025-03-28_23:42:10.593263_yUWG
    • 2025-03-28_23:42:10.593270_EfIs
    • 2025-03-28_23:42:10.593276_eEzV
    • 2025-03-28_23:42:10.593282_BeHp
    • 2025-03-28_23:42:10.593289_KpOp
    8933e07
    • 2025-03-31_15:49:33.615467_cPhC
    • 2025-03-31_15:49:33.615507_BdYh
    • 2025-03-31_15:49:33.615524_fqax
    • 2025-03-31_15:49:33.615533_pkRd
    • 2025-03-31_15:49:33.615540_dLhc
    • 2025-03-31_15:49:33.615547_TyDu
    • 2025-03-31_15:49:33.615555_PzcS
    • 2025-03-31_15:49:33.615561_PxlZ
    • 2025-03-31_15:49:33.615567_QRBL
    • 2025-03-31_15:49:33.615573_IQVG
  • fire-sessions

    DeviceStatisticsDistributions
    oriole-32
    Percentiled2e72df8933e07DiffSignificant (?)
    p102.20 ±0.4 ms2.34 ±0.6 ms+137 μs (+6.2%)NO
    p252.43 ±0.5 ms2.55 ±0.7 ms+112 μs (+4.6%)NO
    p502.74 ±0.6 ms2.86 ±0.7 ms+126 μs (+4.6%)NO
    p753.27 ±0.7 ms3.41 ±0.7 ms+145 μs (+4.4%)NO
    p904.38 ±1 ms4.11 ±0.8 ms-264 μs (-6.0%)NO

    20 test runs in comparison
    CommitTest Runs
    d2e72df
    • 2025-03-28_23:42:10.593191_Zsds
    • 2025-03-28_23:42:10.593228_Uifg
    • 2025-03-28_23:42:10.593240_AVtD
    • 2025-03-28_23:42:10.593248_uZHI
    • 2025-03-28_23:42:10.593255_FjOS
    • 2025-03-28_23:42:10.593263_yUWG
    • 2025-03-28_23:42:10.593270_EfIs
    • 2025-03-28_23:42:10.593276_eEzV
    • 2025-03-28_23:42:10.593282_BeHp
    • 2025-03-28_23:42:10.593289_KpOp
    8933e07
    • 2025-03-31_15:49:33.615467_cPhC
    • 2025-03-31_15:49:33.615507_BdYh
    • 2025-03-31_15:49:33.615524_fqax
    • 2025-03-31_15:49:33.615533_pkRd
    • 2025-03-31_15:49:33.615540_dLhc
    • 2025-03-31_15:49:33.615547_TyDu
    • 2025-03-31_15:49:33.615555_PzcS
    • 2025-03-31_15:49:33.615561_PxlZ
    • 2025-03-31_15:49:33.615567_QRBL
    • 2025-03-31_15:49:33.615573_IQVG
    redfin-30
    Percentiled2e72df8933e07DiffSignificant (?)
    p105.04 ±1 ms4.19 ±0.7 ms-846 μs (-16.8%)NO
    p255.64 ±2 ms4.52 ±0.9 ms-1.12 ms (-19.9%)NO
    p506.69 ±3 ms4.96 ±1 ms-1.73 ms (-25.9%)NO
    p757.87 ±4 ms5.60 ±2 ms-2.27 ms (-28.8%)NO
    p909.22 ±4 ms6.65 ±3 ms-2.57 ms (-27.8%)NO

    20 test runs in comparison
    CommitTest Runs
    d2e72df
    • 2025-03-28_23:42:10.593191_Zsds
    • 2025-03-28_23:42:10.593228_Uifg
    • 2025-03-28_23:42:10.593240_AVtD
    • 2025-03-28_23:42:10.593248_uZHI
    • 2025-03-28_23:42:10.593255_FjOS
    • 2025-03-28_23:42:10.593263_yUWG
    • 2025-03-28_23:42:10.593270_EfIs
    • 2025-03-28_23:42:10.593276_eEzV
    • 2025-03-28_23:42:10.593282_BeHp
    • 2025-03-28_23:42:10.593289_KpOp
    8933e07
    • 2025-03-31_15:49:33.615467_cPhC
    • 2025-03-31_15:49:33.615507_BdYh
    • 2025-03-31_15:49:33.615524_fqax
    • 2025-03-31_15:49:33.615533_pkRd
    • 2025-03-31_15:49:33.615540_dLhc
    • 2025-03-31_15:49:33.615547_TyDu
    • 2025-03-31_15:49:33.615555_PzcS
    • 2025-03-31_15:49:33.615561_PxlZ
    • 2025-03-31_15:49:33.615567_QRBL
    • 2025-03-31_15:49:33.615573_IQVG
  • timeToInitialDisplay

    DeviceStatisticsDistributions
    oriole-32
    Percentiled2e72df8933e07DiffSignificant (?)
    p10197 ±5 ms199 ±4 ms+2.19 ms (+1.1%)NO
    p25202 ±5 ms205 ±4 ms+3.48 ms (+1.7%)NO
    p50209 ±5 ms213 ±4 ms+4.22 ms (+2.0%)NO
    p75217 ±6 ms221 ±4 ms+4.04 ms (+1.9%)NO
    p90225 ±6 ms231 ±5 ms+5.75 ms (+2.6%)NO

    20 test runs in comparison
    CommitTest Runs
    d2e72df
    • 2025-03-28_23:42:10.593191_Zsds
    • 2025-03-28_23:42:10.593228_Uifg
    • 2025-03-28_23:42:10.593240_AVtD
    • 2025-03-28_23:42:10.593248_uZHI
    • 2025-03-28_23:42:10.593255_FjOS
    • 2025-03-28_23:42:10.593263_yUWG
    • 2025-03-28_23:42:10.593270_EfIs
    • 2025-03-28_23:42:10.593276_eEzV
    • 2025-03-28_23:42:10.593282_BeHp
    • 2025-03-28_23:42:10.593289_KpOp
    8933e07
    • 2025-03-31_15:49:33.615467_cPhC
    • 2025-03-31_15:49:33.615507_BdYh
    • 2025-03-31_15:49:33.615524_fqax
    • 2025-03-31_15:49:33.615533_pkRd
    • 2025-03-31_15:49:33.615540_dLhc
    • 2025-03-31_15:49:33.615547_TyDu
    • 2025-03-31_15:49:33.615555_PzcS
    • 2025-03-31_15:49:33.615561_PxlZ
    • 2025-03-31_15:49:33.615567_QRBL
    • 2025-03-31_15:49:33.615573_IQVG
    redfin-30
    Percentiled2e72df8933e07DiffSignificant (?)
    p10232 ±10 ms247 ±4 ms+15.6 ms (+6.7%)NO
    p25238 ±10 ms254 ±4 ms+15.4 ms (+6.5%)NO
    p50246 ±11 ms261 ±4 ms+14.6 ms (+5.9%)NO
    p75259 ±20 ms269 ±5 ms+10.0 ms (+3.9%)NO
    p90273 ±26 ms281 ±8 ms+8.44 ms (+3.1%)NO

    20 test runs in comparison
    CommitTest Runs
    d2e72df
    • 2025-03-28_23:42:10.593191_Zsds
    • 2025-03-28_23:42:10.593228_Uifg
    • 2025-03-28_23:42:10.593240_AVtD
    • 2025-03-28_23:42:10.593248_uZHI
    • 2025-03-28_23:42:10.593255_FjOS
    • 2025-03-28_23:42:10.593263_yUWG
    • 2025-03-28_23:42:10.593270_EfIs
    • 2025-03-28_23:42:10.593276_eEzV
    • 2025-03-28_23:42:10.593282_BeHp
    • 2025-03-28_23:42:10.593289_KpOp
    8933e07
    • 2025-03-31_15:49:33.615467_cPhC
    • 2025-03-31_15:49:33.615507_BdYh
    • 2025-03-31_15:49:33.615524_fqax
    • 2025-03-31_15:49:33.615533_pkRd
    • 2025-03-31_15:49:33.615540_dLhc
    • 2025-03-31_15:49:33.615547_TyDu
    • 2025-03-31_15:49:33.615555_PzcS
    • 2025-03-31_15:49:33.615561_PxlZ
    • 2025-03-31_15:49:33.615567_QRBL
    • 2025-03-31_15:49:33.615573_IQVG

  1. https://storage.googleapis.com/firebase-sdk-metric-reports/aQtmWbasAq/index.html

@tejasd tejasd merged commit 278e437 into main Mar 31, 2025
36 checks passed
@tejasd tejasd deleted the td/duplicate-trace-names-session branch March 31, 2025 16:32
tejasd added a commit that referenced this pull request Apr 1, 2025
…-changelog (#6809)

This change adds a way to repeatedly log identical performance traces in
different processes.
- Currently traces on different activities are logged on different
Fireperf Sessions.
- Adds additional logging to help identify different Firebase instances
in different processes.
- Adds Fireperf custom attributes to identify processes.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants