You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
iceraven-browser/app/src/main/java/org/mozilla/fenix
MarcLeclair 990bfa7e6d
16900 make navgraph inflation asynchronous (#18889)
* For #16900: implement async navgraph inflation

For #16900: removed nav graph from xml

For #16900: inflate navGraph programatically

For #16900: Made NavGraph inflation asynchronous

For #16900: Changed to block with runBlocking

For #16900: Refactored blocking call into a function

For 16900: NavGraph inflation is now async

We now attach the nav graph (or check if its attached) on every nav call ( an extension function for NavController).
This is done by checking the value of the job stored in PerfNavController.map which keeps track of the job with the NavController as a Key.
If the job hasn't been completed, it will block the main thread until the job is done. The job itself is responsible for attaching the navgraph
to the navcontroller (and the inflation of the latter too)

For 16900: rebased upstream master

For 16900: Rebase on master

For #16900: Fixed Async Navgraph navigation per review comments.

1)The Asynchronous method is now found in NavGraphProvider.kt. It creates a job on the IO dispatcher
2)The Job is tracked through a WeakHashMap from Controller --> NavGraph
3)The Coroutine scope doesn't use MainScope() anymore
4)The Coroutine is cancelled if the Activity is destroyed
5)The tests mockk the blockForNavGraphInflation method through the FenixReoboelectricTestApplication instead of calling the mock every setup()

For #16900: inflateNavGraphAsync now takes navController

For #16900: Pass lifecycleScope to NavGraphProvider

For #16900: removed unused mock

For #16900: Added linter rules for navigate calls

We need linting rules to make sure no one calls the NavController.navigate() methods

For #16900: Added TestRule to help abstract the mocks in the code

For 16900: Fix linting problems

For #16900: Cleaned duplicated code in tests

For #16900: cleaned up NavGraphTestRule for finished test

For #16900: had to revert an accidentally edited file

For #16900: rebased master

* For #16900: Review nits for async navgraph

This is composed of squash commits, the original messages can be found below:

-> DisableNavGraphProviderAssertionRule + kdoc.

Use test rule in RobolectricApplication.

Fix failing CrashReporterControllerTest

Fix blame by -> navigate in tests.

This commit was generated by the following commands only:
```
find app/src/test -type f -exec sed -i '' "/import org.mozilla.fenix.ext.navigateBlockingForAsyncNavGraph/d" {} \;
find app/src/test -type f -exec sed -i "" "s/navigateBlockingForAsyncNavGraph/navigate/g" {} \;
git checkout app/src/test/resources/mockito-extensions/org.mockito.plugins.MockMaker
```

Fix various blame

This is expected to be squashed into the first commit so, if so, it'd
fix the blame.

Move test rule to helpers pkg.

add missing license header

Add import change I missed

fix unused imports

Replace robolectricTestrunner with test rule.

Improve navGraphProvider docs

Remove unnecessary rule as defined by robolectric.

add clarifying comment to robolectric

remove unnecessary space

* For #16900: nit fixes for MozillaNavigateCheck and lint fixes

3 squash commits:
 *Changed violation message and fixed the lint rule for MozillaNavigateCheck
 *Added suppression to NavController.kt
 *Fixed detekt violations

* For 16900: Fixed failing tests

Co-authored-by: Michael Comella <michael.l.comella@gmail.com>
3 years ago
..
addons 16900 make navgraph inflation asynchronous (#18889) 3 years ago
android For #18426: add DefaultActivityLifecycleCallbacks. 3 years ago
autofill Integrate Android Autofill support into Nightly and debug builds. 3 years ago
browser 16900 make navgraph inflation asynchronous (#18889) 3 years ago
collections Close #18931: Implement add to collections in interactor 3 years ago
components 16900 make navgraph inflation asynchronous (#18889) 3 years ago
crashes Refactor CrashReporterFragment to use browser store 3 years ago
customtabs For #18426: record cold start duration telemetry. 3 years ago
downloads For #18617 - Use the new EngineView#getInputResultDetail() 3 years ago
exceptions Update Android Components, Kotlin, Gradle plugin (#16021) 4 years ago
experiments For #18375: Add experiment for set default browser New Tab card. 3 years ago
ext 16900 make navgraph inflation asynchronous (#18889) 3 years ago
home 16900 make navgraph inflation asynchronous (#18889) 3 years ago
library 16900 make navgraph inflation asynchronous (#18889) 3 years ago
media Issue #17174: Remove usage of old media APIs. 3 years ago
migration For #14168: Fix click listener on migration button 4 years ago
nimbus 16900 make navgraph inflation asynchronous (#18889) 3 years ago
onboarding For #15372 Optimize the order and messages of onboarding cards 3 years ago
perf 16900 make navgraph inflation asynchronous (#18889) 3 years ago
push Fix breaking changes from FCM SDK update 4 years ago
search Closes #18068: Track custom fill link from clipboard clicked (#18827) 3 years ago
selection Issue #18774: Move SelectionInteractor to new package 3 years ago
session For #17190: notifications are updated when locale is changed (#18179) 3 years ago
settings 16900 make navgraph inflation asynchronous (#18889) 3 years ago
share 16900 make navgraph inflation asynchronous (#18889) 3 years ago
shortcut Closes #17473: Intermittent failues of PwaOnboardingObserver 3 years ago
sync 16900 make navgraph inflation asynchronous (#18889) 3 years ago
tabhistory Issue #17548: Remove SessionManager reference from TabHistoryDialog 3 years ago
tabstray 16900 make navgraph inflation asynchronous (#18889) 3 years ago
tabtray 16900 make navgraph inflation asynchronous (#18889) 3 years ago
telemetry Introduce process lifecycle observer to collect metrics about tabs when app goes to foreground/background. 3 years ago
theme Target Android 11 3 years ago
trackingprotection For #17724: Wait for tab to be fully created before showing ETP Onboarding if ETP is active 3 years ago
utils For #18375: Add experiment for set default browser New Tab card. 3 years ago
whatsnew For #13959: move resetAfter into StrictModeManager. 4 years ago
widget For #15430: Fix StrictMode death on opening app from widget voice search. 4 years ago
wifi For issue #16557 set autoplay block audio only 3 years ago
AppRequestInterceptor.kt 16900 make navgraph inflation asynchronous (#18889) 3 years ago
BrowserDirection.kt For #14280, #14743: Remove old search fragment (#15169) 4 years ago
Config.kt Closes #16256: Introduce build flag for "Mozilla Online" variant. 4 years ago
FeatureFlags.kt For #17870 - Enable new three-dot menu redesign on nightly builds (#18883) 3 years ago
FenixApplication.kt For #18836: replace StartupActivityStateProvider with StartupStateProvider. 3 years ago
FenixLogSink.kt For #14735: Remove debug logs from release build. (#15747) 4 years ago
GlobalDirections.kt For #8157: Redirect about:addons search (#13990) 4 years ago
HomeActivity.kt 16900 make navgraph inflation asynchronous (#18889) 3 years ago
IntentReceiverActivity.kt For #17816: add profiler marker for 2x Activity.onCreate. 3 years ago
NavHostActivity.kt Add method to test fragments in roboletric (#12261) 4 years ago
OnBackLongPressedListener.kt For #1048 - Add ability to view tab history by long-pressing the back or forward button. 4 years ago