From 642d866ccfe9cbcded8f62b215a6cbdccf79f6e8 Mon Sep 17 00:00:00 2001 From: Kenzie Davisson Date: Tue, 10 Sep 2024 09:30:39 -0700 Subject: [PATCH 1/2] Some clean up and refactoring for query parameter logic --- .../extensions/embedded/_controller_web.dart | 3 ++- .../src/screens/app_size/app_size_screen.dart | 8 +++--- .../deep_links_controller.dart | 2 +- .../inspector/inspector_controller.dart | 9 ++----- .../inspector_v2/inspector_controller.dart | 9 ++----- .../src/shared/analytics/_analytics_web.dart | 10 ++++--- .../lib/src/shared/query_parameters.dart | 27 ++++++++++++++++++- .../devtools_app/lib/src/shared/utils.dart | 12 ++------- packages/devtools_app_shared/CHANGELOG.md | 3 +++ .../lib/src/utils/url/_url_stub.dart | 6 +++++ .../lib/src/utils/url/_url_web.dart | 20 ++++++++++++++ packages/devtools_app_shared/pubspec.yaml | 2 +- packages/devtools_extensions/CHANGELOG.md | 3 +++ .../lib/src/template/extension_manager.dart | 26 ++++-------------- packages/devtools_extensions/pubspec.yaml | 4 +-- .../devtools_shared/test/helpers/helpers.dart | 2 +- 16 files changed, 86 insertions(+), 60 deletions(-) diff --git a/packages/devtools_app/lib/src/extensions/embedded/_controller_web.dart b/packages/devtools_app/lib/src/extensions/embedded/_controller_web.dart index c08222cb7b9..3c74841ce93 100644 --- a/packages/devtools_app/lib/src/extensions/embedded/_controller_web.dart +++ b/packages/devtools_app/lib/src/extensions/embedded/_controller_web.dart @@ -14,6 +14,7 @@ import 'package:web/web.dart'; import '../../shared/development_helpers.dart'; import '../../shared/globals.dart'; import '../../shared/primitives/utils.dart'; +import '../../shared/query_parameters.dart'; import '../../shared/server/server.dart'; import '../../shared/utils.dart'; import 'controller.dart'; @@ -55,7 +56,7 @@ class EmbeddedExtensionControllerImpl extends EmbeddedExtensionController 'index.html', ); final queryParams = { - ...loadQueryParams(), + ...DevToolsQueryParams.load().params, ExtensionEventParameters.theme: isDarkThemeEnabled() ? ExtensionEventParameters.themeValueDark : ExtensionEventParameters.themeValueLight, diff --git a/packages/devtools_app/lib/src/screens/app_size/app_size_screen.dart b/packages/devtools_app/lib/src/screens/app_size/app_size_screen.dart index 2b38ee562e3..d0c3cf71e5f 100644 --- a/packages/devtools_app/lib/src/screens/app_size/app_size_screen.dart +++ b/packages/devtools_app/lib/src/screens/app_size/app_size_screen.dart @@ -6,7 +6,6 @@ import 'dart:async'; import 'package:devtools_app_shared/ui.dart'; import 'package:devtools_app_shared/utils.dart'; -import 'package:devtools_shared/devtools_shared.dart'; import 'package:flutter/material.dart'; import 'package:vm_snapshot_analysis/precompiler_trace.dart'; @@ -18,6 +17,7 @@ import '../../shared/config_specific/drag_and_drop/drag_and_drop.dart'; import '../../shared/file_import.dart'; import '../../shared/globals.dart'; import '../../shared/primitives/utils.dart'; +import '../../shared/query_parameters.dart'; import '../../shared/screen.dart'; import '../../shared/server/server.dart' as server; import '../../shared/ui/tab.dart'; @@ -103,14 +103,14 @@ class _AppSizeBodyState extends State } Future maybeLoadAppSizeFiles() async { - final queryParams = loadQueryParams(); - final baseFilePath = queryParams[AppSizeApi.baseAppSizeFilePropertyName]; + final queryParams = DevToolsQueryParams.load(); + final baseFilePath = queryParams.appSizeBaseFilePath; if (baseFilePath != null) { // TODO(kenz): does this have to be in a setState()? _preLoadingData = true; final baseAppSizeFile = await server.requestBaseAppSizeFile(baseFilePath); DevToolsJsonFile? testAppSizeFile; - final testFilePath = queryParams[AppSizeApi.testAppSizeFilePropertyName]; + final testFilePath = queryParams.appSizeTestFilePath; if (testFilePath != null) { testAppSizeFile = await server.requestTestAppSizeFile(testFilePath); } diff --git a/packages/devtools_app/lib/src/screens/deep_link_validation/deep_links_controller.dart b/packages/devtools_app/lib/src/screens/deep_link_validation/deep_links_controller.dart index c41e61d92b9..ae26f049bd5 100644 --- a/packages/devtools_app/lib/src/screens/deep_link_validation/deep_links_controller.dart +++ b/packages/devtools_app/lib/src/screens/deep_link_validation/deep_links_controller.dart @@ -552,7 +552,7 @@ class DeepLinksController extends DisposableController false); if (linkdata.os.contains(PlatformOS.ios)) { - final List iosPaths = iosDomainPaths[linkdata.domain] ?? []; + final iosPaths = iosDomainPaths[linkdata.domain] ?? []; // If no path is provided, we will still show the domain just with domain errors. if (iosPaths.isEmpty) { diff --git a/packages/devtools_app/lib/src/screens/inspector/inspector_controller.dart b/packages/devtools_app/lib/src/screens/inspector/inspector_controller.dart index 55dc2ffb113..164f702a06c 100644 --- a/packages/devtools_app/lib/src/screens/inspector/inspector_controller.dart +++ b/packages/devtools_app/lib/src/screens/inspector/inspector_controller.dart @@ -30,13 +30,12 @@ import '../../shared/diagnostics/inspector_service.dart'; import '../../shared/diagnostics/primitives/instance_ref.dart'; import '../../shared/globals.dart'; import '../../shared/primitives/utils.dart'; +import '../../shared/query_parameters.dart'; import 'inspector_screen.dart'; import 'inspector_tree_controller.dart'; final _log = Logger('inspector_controller'); -const inspectorRefQueryParam = 'inspectorRef'; - /// This class is based on the InspectorPanel class from the Flutter IntelliJ /// plugin with some refactors to make it more of a true controller than a view. class InspectorController extends DisposableController @@ -415,11 +414,7 @@ class InspectorController extends DisposableController if (_disposed) return; // We need to start by querying the inspector service to find out the // current state of the UI. - - final queryParams = loadQueryParams(); - final inspectorRef = queryParams.containsKey(inspectorRefQueryParam) - ? queryParams[inspectorRefQueryParam] - : null; + final inspectorRef = DevToolsQueryParams.load().inspectorRef; await updateSelectionFromService( firstFrame: true, inspectorRef: inspectorRef, diff --git a/packages/devtools_app/lib/src/screens/inspector_v2/inspector_controller.dart b/packages/devtools_app/lib/src/screens/inspector_v2/inspector_controller.dart index 3af59ec586c..7eda2a02e95 100644 --- a/packages/devtools_app/lib/src/screens/inspector_v2/inspector_controller.dart +++ b/packages/devtools_app/lib/src/screens/inspector_v2/inspector_controller.dart @@ -30,14 +30,13 @@ import '../../shared/diagnostics/inspector_service.dart'; import '../../shared/diagnostics/primitives/instance_ref.dart'; import '../../shared/globals.dart'; import '../../shared/primitives/utils.dart'; +import '../../shared/query_parameters.dart'; import 'inspector_data_models.dart'; import 'inspector_screen.dart'; import 'inspector_tree_controller.dart'; final _log = Logger('inspector_controller'); -const inspectorRefQueryParam = 'inspectorRef'; - /// Data pattern containing the properties and render properties for a widget /// tree node. typedef WidgetTreeNodeProperties = ({ @@ -401,11 +400,7 @@ class InspectorController extends DisposableController if (_disposed) return; // We need to start by querying the inspector service to find out the // current state of the UI. - - final queryParams = loadQueryParams(); - final inspectorRef = queryParams.containsKey(inspectorRefQueryParam) - ? queryParams[inspectorRefQueryParam] - : null; + final inspectorRef = DevToolsQueryParams.load().inspectorRef; await updateSelectionFromService( inspectorRef: inspectorRef, ); diff --git a/packages/devtools_app/lib/src/shared/analytics/_analytics_web.dart b/packages/devtools_app/lib/src/shared/analytics/_analytics_web.dart index 4dba24e3488..de042e87f4f 100644 --- a/packages/devtools_app/lib/src/shared/analytics/_analytics_web.dart +++ b/packages/devtools_app/lib/src/shared/analytics/_analytics_web.dart @@ -18,6 +18,7 @@ import 'package:web/web.dart'; import '../dtd_manager_extensions.dart'; import '../globals.dart'; +import '../query_parameters.dart'; import '../server/server.dart' as server; import '../utils.dart'; import 'analytics_common.dart'; @@ -767,12 +768,13 @@ void computeDevToolsCustomGTagsData() { void computeDevToolsQueryParams() { _ideLaunched = ideLaunchedCLI; // Default is Command Line launch. - final ideValue = ideFromUrl(); - if (ideValue != null) { - _ideLaunched = ideValue; + final queryParams = DevToolsQueryParams.load(); + final ide = queryParams.ide; + if (ide != null) { + _ideLaunched = ide; } - final ideFeature = lookupFromQueryParams('ideFeature'); + final ideFeature = queryParams.ideFeature; if (ideFeature != null) { ideLaunchedFeature = ideFeature; } diff --git a/packages/devtools_app/lib/src/shared/query_parameters.dart b/packages/devtools_app/lib/src/shared/query_parameters.dart index 67d2975362e..2021a2acc3f 100644 --- a/packages/devtools_app/lib/src/shared/query_parameters.dart +++ b/packages/devtools_app/lib/src/shared/query_parameters.dart @@ -5,6 +5,7 @@ import 'package:devtools_app_shared/shared.dart'; import 'package:devtools_app_shared/ui.dart'; import 'package:devtools_app_shared/utils.dart'; +import 'package:devtools_shared/devtools_shared.dart'; extension type DevToolsQueryParams(Map params) { static DevToolsQueryParams empty() => DevToolsQueryParams({}); @@ -21,30 +22,54 @@ extension type DevToolsQueryParams(Map params) { return DevToolsQueryParams({...params, ...?updates}); } + /// The URI for the VM Service that DevTools is connected to. String? get vmServiceUri => params[vmServiceUriKey]; + /// The current [EmbedMode] of DevTools based on the query parameters. EmbedMode get embedMode => ideThemeParams.embedMode; + /// The set of screens that are hidden based on the query parameters. Set get hiddenScreens => {...?params[hideScreensKey]?.split(',')}; + /// Whether DevTools extensions should be hidden. bool get hideExtensions => hiddenScreens.contains(hideExtensionsValue); + /// Whether all screens except DevTools extension screens should be hidden. bool get hideAllExceptExtensions => hiddenScreens.contains(hideAllExceptExtensionsValue); + /// The screen that should be visible for viewing offline data. String? get offlineScreenId => params[offlineScreenIdKey]; + /// The Inspector object reference that should be automatically selected when + /// opening the Flutter Inspector. String? get inspectorRef => params[inspectorRefKey]; - // Keys for theming values that an IDE may pass in the embedded DevTools URI. + /// Keys for theming values that an IDE may pass in the embedded DevTools URI. IdeThemeQueryParams get ideThemeParams => IdeThemeQueryParams(params); + /// The IDE that DevTools is embedded in or was launched from. + String? get ide => params[ideKey]; + + /// The feature of the IDE that DevTools was opened from. + String? get ideFeature => params[ideFeatureKey]; + + /// The file path for the base file to load on the App Size screen. + String? get appSizeBaseFilePath => + params[AppSizeApi.baseAppSizeFilePropertyName]; + + /// The file path for the test file to load on the App Size screen. + String? get appSizeTestFilePath => + params[AppSizeApi.testAppSizeFilePropertyName]; + static const vmServiceUriKey = 'uri'; static const hideScreensKey = 'hide'; static const hideExtensionsValue = 'extensions'; static const hideAllExceptExtensionsValue = 'all-except-extensions'; static const offlineScreenIdKey = 'screen'; static const inspectorRefKey = 'inspectorRef'; + static const ideKey = 'ide'; + static const ideFeatureKey = 'ideFeature'; // TODO(kenz): remove legacy value in May of 2025 when all IDEs are not using // these and 12 months have passed to allow users ample upgrade time. diff --git a/packages/devtools_app/lib/src/shared/utils.dart b/packages/devtools_app/lib/src/shared/utils.dart index 541287f53f2..2b288070442 100644 --- a/packages/devtools_app/lib/src/shared/utils.dart +++ b/packages/devtools_app/lib/src/shared/utils.dart @@ -26,6 +26,7 @@ import 'common_widgets.dart'; import 'connected_app.dart'; import 'globals.dart'; import 'primitives/utils.dart'; +import 'query_parameters.dart'; final _log = Logger('lib/src/shared/utils'); @@ -133,7 +134,7 @@ List generateDeviceDescription( /// This method should be public, because it is used by g3 specific code. List issueLinkDetails() { - final ide = ideFromUrl(); + final ide = DevToolsQueryParams.load().ide; final issueDescriptionItems = [ '<-- Please describe your problem here. Be sure to include repro steps. -->', '___', // This will create a separator in the rendered markdown. @@ -225,15 +226,6 @@ class ConnectionDescription { final List actions; } -String? ideFromUrl() { - return lookupFromQueryParams('ide'); -} - -String? lookupFromQueryParams(String key) { - final queryParameters = loadQueryParams(); - return queryParameters[key]; -} - const _google3PathSegment = 'google3'; bool isGoogle3Path(List pathParts) => diff --git a/packages/devtools_app_shared/CHANGELOG.md b/packages/devtools_app_shared/CHANGELOG.md index eb966dd80b0..15a26f97d27 100644 --- a/packages/devtools_app_shared/CHANGELOG.md +++ b/packages/devtools_app_shared/CHANGELOG.md @@ -1,3 +1,6 @@ +## 0.2.4 +* Add `updateQueryParameter` utility method. + ## 0.2.3 * Bump `web` dependency to `^1.0.0` * Bump `pointer_interceptor` dependency to `^0.10.1+1` diff --git a/packages/devtools_app_shared/lib/src/utils/url/_url_stub.dart b/packages/devtools_app_shared/lib/src/utils/url/_url_stub.dart index 9103800db01..47e8a9b37ab 100644 --- a/packages/devtools_app_shared/lib/src/utils/url/_url_stub.dart +++ b/packages/devtools_app_shared/lib/src/utils/url/_url_stub.dart @@ -15,3 +15,9 @@ String? getWebUrl() => null; // Unused parameter lint doesn't make sense for stub files. // ignore: avoid-unused-parameters void webRedirect(String url) {} + +/// Updates the query parameter with [key] to the new [value], and optionally +/// reloads the page when [reload] is true. +/// +/// No-op for non-web platforms. +void updateQueryParameter(String key, String? value, {bool reload = false}) {} diff --git a/packages/devtools_app_shared/lib/src/utils/url/_url_web.dart b/packages/devtools_app_shared/lib/src/utils/url/_url_web.dart index def617b3d59..ab1f6acb375 100644 --- a/packages/devtools_app_shared/lib/src/utils/url/_url_web.dart +++ b/packages/devtools_app_shared/lib/src/utils/url/_url_web.dart @@ -15,3 +15,23 @@ String? getWebUrl() => window.location.toString(); void webRedirect(String url) { window.location.replace(url); } + +void updateQueryParameter(String key, String? value, {bool reload = false}) { + final newQueryParams = Map.of(loadQueryParams()); + if (value == null) { + newQueryParams.remove(key); + } else { + newQueryParams[key] = value; + } + final newUri = Uri.parse(window.location.toString()) + .replace(queryParameters: newQueryParams); + window.history.replaceState( + window.history.state, + '', + newUri.toString(), + ); + + if (reload) { + window.location.reload(); + } +} diff --git a/packages/devtools_app_shared/pubspec.yaml b/packages/devtools_app_shared/pubspec.yaml index f1a8bd26421..a3c31dafd43 100644 --- a/packages/devtools_app_shared/pubspec.yaml +++ b/packages/devtools_app_shared/pubspec.yaml @@ -1,6 +1,6 @@ name: devtools_app_shared description: Package of Dart & Flutter structures shared between devtools_app and devtools extensions. -version: 0.2.3 +version: 0.2.4 repository: https://github.com/flutter/devtools/tree/master/packages/devtools_app_shared environment: diff --git a/packages/devtools_extensions/CHANGELOG.md b/packages/devtools_extensions/CHANGELOG.md index 2bbd77ac3f0..e55e64e3cb4 100644 --- a/packages/devtools_extensions/CHANGELOG.md +++ b/packages/devtools_extensions/CHANGELOG.md @@ -1,3 +1,6 @@ +## 0.3.0-dev.1 +* Bump `devtools_app_shared` dependency to `0.2.4`. + ## 0.3.0-dev.0 * Add `ExtensionManager.copyToClipboard` method. * Add `DevToolsExtensionEventType.copyToClipboard` enum type. diff --git a/packages/devtools_extensions/lib/src/template/extension_manager.dart b/packages/devtools_extensions/lib/src/template/extension_manager.dart index 401a84d8edb..230b896639e 100644 --- a/packages/devtools_extensions/lib/src/template/extension_manager.dart +++ b/packages/devtools_extensions/lib/src/template/extension_manager.dart @@ -161,7 +161,7 @@ class ExtensionManager { await serviceManager.manuallyDisconnect(); } if (loadQueryParams().containsKey(_vmServiceQueryParameter)) { - _updateQueryParameter(_vmServiceQueryParameter, null); + updateQueryParameter(_vmServiceQueryParameter, null); } return; } @@ -182,7 +182,7 @@ class ExtensionManager { vmService, onClosed: finishedCompleter.future, ); - _updateQueryParameter( + updateQueryParameter( _vmServiceQueryParameter, serviceManager.serviceUri!, ); @@ -202,14 +202,14 @@ class ExtensionManager { await dtdManager.disconnect(); } if (loadQueryParams().containsKey(_dtdQueryParameter)) { - _updateQueryParameter(_dtdQueryParameter, null); + updateQueryParameter(_dtdQueryParameter, null); } return; } try { await dtdManager.connect(Uri.parse(dtdUri)); - _updateQueryParameter( + updateQueryParameter( _dtdQueryParameter, dtdManager.uri.toString(), ); @@ -228,7 +228,7 @@ class ExtensionManager { // Use a post frame callback so that we do not try to update this while a // build is in progress. WidgetsBinding.instance.addPostFrameCallback((_) { - _updateQueryParameter( + updateQueryParameter( 'theme', useDarkTheme ? ExtensionEventParameters.themeValueDark @@ -316,20 +316,4 @@ class ExtensionManager { ), ); } - - void _updateQueryParameter(String key, String? value) { - final newQueryParams = Map.of(loadQueryParams()); - if (value == null) { - newQueryParams.remove(key); - } else { - newQueryParams[key] = value; - } - final newUri = Uri.parse(window.location.toString()) - .replace(queryParameters: newQueryParams); - window.history.replaceState( - window.history.state, - '', - newUri.toString(), - ); - } } diff --git a/packages/devtools_extensions/pubspec.yaml b/packages/devtools_extensions/pubspec.yaml index acba38656c0..85a8bb14db4 100644 --- a/packages/devtools_extensions/pubspec.yaml +++ b/packages/devtools_extensions/pubspec.yaml @@ -1,6 +1,6 @@ name: devtools_extensions description: A package for building and supporting extensions for Dart DevTools. -version: 0.3.0-dev.0 +version: 0.3.0-dev.1 repository: https://github.com/flutter/devtools/tree/master/packages/devtools_extensions @@ -14,7 +14,7 @@ executables: dependencies: args: ^2.4.2 devtools_shared: ^10.0.2 - devtools_app_shared: ^0.2.3 + devtools_app_shared: ^0.2.4 flutter: sdk: flutter io: ^1.0.4 diff --git a/packages/devtools_shared/test/helpers/helpers.dart b/packages/devtools_shared/test/helpers/helpers.dart index d5fbb435779..64ae19f0f18 100644 --- a/packages/devtools_shared/test/helpers/helpers.dart +++ b/packages/devtools_shared/test/helpers/helpers.dart @@ -44,7 +44,7 @@ Future startDtd() async { completer.complete( ( info: DtdInfo(Uri.parse(uri), secret: secret), - process: dtdProcess + process: dtdProcess, ), ); } else { From 014544de8171e129a2910a82991aa6847df29070 Mon Sep 17 00:00:00 2001 From: Kenzie Davisson Date: Tue, 10 Sep 2024 09:51:36 -0700 Subject: [PATCH 2/2] add testing --- .../lib/src/shared/query_parameters.dart | 22 +++---- .../test/shared/query_parameters_test.dart | 59 +++++++++++++++---- 2 files changed, 58 insertions(+), 23 deletions(-) diff --git a/packages/devtools_app/lib/src/shared/query_parameters.dart b/packages/devtools_app/lib/src/shared/query_parameters.dart index 2021a2acc3f..24f2237aced 100644 --- a/packages/devtools_app/lib/src/shared/query_parameters.dart +++ b/packages/devtools_app/lib/src/shared/query_parameters.dart @@ -25,9 +25,6 @@ extension type DevToolsQueryParams(Map params) { /// The URI for the VM Service that DevTools is connected to. String? get vmServiceUri => params[vmServiceUriKey]; - /// The current [EmbedMode] of DevTools based on the query parameters. - EmbedMode get embedMode => ideThemeParams.embedMode; - /// The set of screens that are hidden based on the query parameters. Set get hiddenScreens => {...?params[hideScreensKey]?.split(',')}; @@ -45,8 +42,13 @@ extension type DevToolsQueryParams(Map params) { /// opening the Flutter Inspector. String? get inspectorRef => params[inspectorRefKey]; - /// Keys for theming values that an IDE may pass in the embedded DevTools URI. - IdeThemeQueryParams get ideThemeParams => IdeThemeQueryParams(params); + /// The file path for the base file to load on the App Size screen. + String? get appSizeBaseFilePath => + params[AppSizeApi.baseAppSizeFilePropertyName]; + + /// The file path for the test file to load on the App Size screen. + String? get appSizeTestFilePath => + params[AppSizeApi.testAppSizeFilePropertyName]; /// The IDE that DevTools is embedded in or was launched from. String? get ide => params[ideKey]; @@ -54,13 +56,11 @@ extension type DevToolsQueryParams(Map params) { /// The feature of the IDE that DevTools was opened from. String? get ideFeature => params[ideFeatureKey]; - /// The file path for the base file to load on the App Size screen. - String? get appSizeBaseFilePath => - params[AppSizeApi.baseAppSizeFilePropertyName]; + /// Keys for theming values that an IDE may pass in the embedded DevTools URI. + IdeThemeQueryParams get ideThemeParams => IdeThemeQueryParams(params); - /// The file path for the test file to load on the App Size screen. - String? get appSizeTestFilePath => - params[AppSizeApi.testAppSizeFilePropertyName]; + /// The current [EmbedMode] of DevTools based on the query parameters. + EmbedMode get embedMode => ideThemeParams.embedMode; static const vmServiceUriKey = 'uri'; static const hideScreensKey = 'hide'; diff --git a/packages/devtools_app/test/shared/query_parameters_test.dart b/packages/devtools_app/test/shared/query_parameters_test.dart index d867da741f4..00de081dfd4 100644 --- a/packages/devtools_app/test/shared/query_parameters_test.dart +++ b/packages/devtools_app/test/shared/query_parameters_test.dart @@ -7,6 +7,8 @@ import 'dart:ui'; import 'package:devtools_app/devtools_app.dart'; import 'package:devtools_app/src/shared/query_parameters.dart'; import 'package:devtools_app_shared/shared.dart'; +import 'package:devtools_app_shared/ui.dart'; +import 'package:devtools_shared/devtools_shared.dart'; import 'package:flutter_test/flutter_test.dart'; void main() { @@ -17,17 +19,21 @@ void main() { DevToolsQueryParams.hideScreensKey: 'foo,bar,extensions,all-except-extensions', DevToolsQueryParams.offlineScreenIdKey: 'performance', + DevToolsQueryParams.inspectorRefKey: '12345', + AppSizeApi.baseAppSizeFilePropertyName: '/path/to/base/file.json', + AppSizeApi.testAppSizeFilePropertyName: '/path/to/test/file.json', + DevToolsQueryParams.ideKey: 'Android-Studio', + DevToolsQueryParams.ideFeatureKey: 'onDebugAutomatic', DevToolsQueryParams.legacyPageKey: 'memory', // IdeThemeQueryParams values 'embedMode': 'one', - 'backgroundColor': '#112233', - 'foregroundColor': '#112244', - 'fontSize': '8.0', - 'theme': 'dark', + IdeThemeQueryParams.backgroundColorKey: '#112233', + IdeThemeQueryParams.foregroundColorKey: '#112244', + IdeThemeQueryParams.fontSizeKey: '8.0', + IdeThemeQueryParams.devToolsThemeKey: 'dark', }); expect(params.vmServiceUri, 'some_uri'); - expect(params.embedMode, EmbedMode.embedOne); expect( params.hiddenScreens, {'foo', 'bar', 'extensions', 'all-except-extensions'}, @@ -35,8 +41,14 @@ void main() { expect(params.hideExtensions, true); expect(params.hideAllExceptExtensions, true); expect(params.offlineScreenId, 'performance'); + expect(params.inspectorRef, '12345'); + expect(params.appSizeBaseFilePath, '/path/to/base/file.json'); + expect(params.appSizeTestFilePath, '/path/to/test/file.json'); + expect(params.ide, 'Android-Studio'); + expect(params.ideFeature, 'onDebugAutomatic'); expect(params.legacyPage, 'memory'); expect(params.ideThemeParams.params, isNotEmpty); + expect(params.embedMode, EmbedMode.embedOne); expect(params.ideThemeParams.embedMode, EmbedMode.embedOne); expect(params.ideThemeParams.backgroundColor, const Color(0xFF112233)); expect(params.ideThemeParams.foregroundColor, const Color(0xFF112244)); @@ -47,11 +59,18 @@ void main() { test('creates empty params', () { final params = DevToolsQueryParams.empty(); expect(params.vmServiceUri, isNull); - expect(params.embedMode, EmbedMode.none); expect(params.hiddenScreens, isEmpty); + expect(params.hideExtensions, false); + expect(params.hideAllExceptExtensions, false); expect(params.offlineScreenId, isNull); + expect(params.inspectorRef, isNull); + expect(params.appSizeBaseFilePath, isNull); + expect(params.appSizeTestFilePath, isNull); + expect(params.ide, isNull); + expect(params.ideFeature, isNull); expect(params.legacyPage, isNull); expect(params.ideThemeParams.params, isEmpty); + expect(params.embedMode, EmbedMode.none); }); test('creates params with updates', () { @@ -59,21 +78,31 @@ void main() { DevToolsQueryParams.vmServiceUriKey: 'some_uri', DevToolsQueryParams.hideScreensKey: 'foo,bar,baz', DevToolsQueryParams.offlineScreenIdKey: 'performance', + DevToolsQueryParams.inspectorRefKey: '12345', + AppSizeApi.baseAppSizeFilePropertyName: '/path/to/base/file.json', + AppSizeApi.testAppSizeFilePropertyName: '/path/to/test/file.json', + DevToolsQueryParams.ideKey: 'Android-Studio', + DevToolsQueryParams.ideFeatureKey: 'onDebugAutomatic', DevToolsQueryParams.legacyPageKey: 'memory', // IdeThemeQueryParams values 'embedMode': 'one', - 'backgroundColor': '#112233', - 'foregroundColor': '#112244', - 'fontSize': '8.0', - 'theme': 'dark', + IdeThemeQueryParams.backgroundColorKey: '#112233', + IdeThemeQueryParams.foregroundColorKey: '#112244', + IdeThemeQueryParams.fontSizeKey: '8.0', + IdeThemeQueryParams.devToolsThemeKey: 'dark', }); expect(params.vmServiceUri, 'some_uri'); - expect(params.embedMode, EmbedMode.embedOne); expect(params.hiddenScreens, {'foo', 'bar', 'baz'}); expect(params.offlineScreenId, 'performance'); + expect(params.inspectorRef, '12345'); + expect(params.appSizeBaseFilePath, '/path/to/base/file.json'); + expect(params.appSizeTestFilePath, '/path/to/test/file.json'); + expect(params.ide, 'Android-Studio'); + expect(params.ideFeature, 'onDebugAutomatic'); expect(params.legacyPage, 'memory'); expect(params.ideThemeParams.params, isNotEmpty); + expect(params.embedMode, EmbedMode.embedOne); expect(params.ideThemeParams.embedMode, EmbedMode.embedOne); expect(params.ideThemeParams.backgroundColor, const Color(0xFF112233)); expect(params.ideThemeParams.foregroundColor, const Color(0xFF112244)); @@ -83,6 +112,7 @@ void main() { params = params.withUpdates({ DevToolsQueryParams.vmServiceUriKey: 'some_other_uri', DevToolsQueryParams.hideScreensKey: 'foo', + DevToolsQueryParams.inspectorRefKey: '23456', // Update some IdeThemeQueryParams values 'embedMode': 'many', 'fontSize': '10.0', @@ -90,11 +120,16 @@ void main() { }); expect(params.vmServiceUri, 'some_other_uri'); - expect(params.embedMode, EmbedMode.embedMany); expect(params.hiddenScreens, {'foo'}); expect(params.offlineScreenId, 'performance'); + expect(params.inspectorRef, '23456'); + expect(params.appSizeBaseFilePath, '/path/to/base/file.json'); + expect(params.appSizeTestFilePath, '/path/to/test/file.json'); + expect(params.ide, 'Android-Studio'); + expect(params.ideFeature, 'onDebugAutomatic'); expect(params.legacyPage, 'memory'); expect(params.ideThemeParams.params, isNotEmpty); + expect(params.embedMode, EmbedMode.embedMany); expect(params.ideThemeParams.embedMode, EmbedMode.embedMany); expect(params.ideThemeParams.backgroundColor, const Color(0xFF112233)); expect(params.ideThemeParams.foregroundColor, const Color(0xFF112244));