Skip to content

Commit

Permalink
feat(package_info_plus)!: Support multiple version.json locations (#2733
Browse files Browse the repository at this point in the history
)

Co-authored-by: Miguel Beltran <[email protected]>
  • Loading branch information
AriasBros and miquelbeltran authored Mar 23, 2024
1 parent 961c8e2 commit 26047f3
Show file tree
Hide file tree
Showing 15 changed files with 612 additions and 108 deletions.
29 changes: 22 additions & 7 deletions packages/package_info_plus/package_info_plus/example/.metadata
Original file line number Diff line number Diff line change
@@ -1,23 +1,38 @@
# This file tracks properties of this Flutter project.
# Used by Flutter tool to assess capabilities and perform upgrades etc.
#
# This file should be version controlled.
# This file should be version controlled and should not be manually edited.

version:
revision: e3c29ec00c9c825c891d75054c63fcc46454dca1
channel: stable
revision: "ba393198430278b6595976de84fe170f553cc728"
channel: "stable"

project_type: app

# Tracks metadata for the flutter migrate command
migration:
platforms:
- platform: root
create_revision: e3c29ec00c9c825c891d75054c63fcc46454dca1
base_revision: e3c29ec00c9c825c891d75054c63fcc46454dca1
create_revision: ba393198430278b6595976de84fe170f553cc728
base_revision: ba393198430278b6595976de84fe170f553cc728
- platform: android
create_revision: ba393198430278b6595976de84fe170f553cc728
base_revision: ba393198430278b6595976de84fe170f553cc728
- platform: ios
create_revision: ba393198430278b6595976de84fe170f553cc728
base_revision: ba393198430278b6595976de84fe170f553cc728
- platform: linux
create_revision: ba393198430278b6595976de84fe170f553cc728
base_revision: ba393198430278b6595976de84fe170f553cc728
- platform: macos
create_revision: ba393198430278b6595976de84fe170f553cc728
base_revision: ba393198430278b6595976de84fe170f553cc728
- platform: web
create_revision: ba393198430278b6595976de84fe170f553cc728
base_revision: ba393198430278b6595976de84fe170f553cc728
- platform: windows
create_revision: e3c29ec00c9c825c891d75054c63fcc46454dca1
base_revision: e3c29ec00c9c825c891d75054c63fcc46454dca1
create_revision: ba393198430278b6595976de84fe170f553cc728
base_revision: ba393198430278b6595976de84fe170f553cc728

# User provided section

Expand Down
13 changes: 13 additions & 0 deletions packages/package_info_plus/package_info_plus/example/build.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
targets:
$default:
sources:
- $package$
- lib/$lib$
- lib/**.dart
- test/**.dart
- integration_test/**.dart
builders:
mockito|mockBuilder:
generate_for:
- test/**.dart
- integration_test/**.dart
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@
library package_info_plus_web_test;

import 'dart:convert';
import 'dart:ui_web' as ui_web;

import 'package:clock/clock.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:http/http.dart' as http;
import 'package:integration_test/integration_test.dart';
Expand All @@ -13,7 +15,7 @@ import 'package:package_info_plus/src/package_info_plus_web.dart';
import 'package_info_plus_test.dart' as common_tests;
import 'package_info_plus_web_test.mocks.dart';

@GenerateMocks([http.Client])
@GenerateMocks([http.Client, ui_web.AssetManager])
void main() {
common_tests.main();

Expand All @@ -29,17 +31,28 @@ void main() {
'build_signature': '',
};

// ignore: constant_identifier_names
const VERSION_2_JSON = {
'app_name': 'package_info_example',
'build_number': '2',
'package_name': 'io.flutter.plugins.packageinfoexample',
'version': '2.0',
'installerStore': null,
'build_signature': '',
};

late PackageInfoPlusWebPlugin plugin;
late MockClient client;

setUp(() {
client = MockClient();
plugin = PackageInfoPlusWebPlugin(client);
});
late MockAssetManager assetManagerMock;

group(
'Package Info Web',
() {
setUp(() {
client = MockClient();
plugin = PackageInfoPlusWebPlugin(client);
});

testWidgets(
'Get correct values when response status is 200',
(tester) async {
Expand Down Expand Up @@ -78,6 +91,35 @@ void main() {
},
);

testWidgets(
'Get correct values when using a custom base URL',
(tester) async {
const String baseUrl = 'https://www.example.com/';
final DateTime now = DateTime.now();
final Clock fakeClock = Clock(() => now);

await withClock(fakeClock, () async {
final int cache = now.millisecondsSinceEpoch;

when(client.get(
Uri.parse('${baseUrl}version.json?cachebuster=$cache'),
)).thenAnswer(
(_) => Future.value(
http.Response(jsonEncode(VERSION_JSON), 200),
),
);

final versionMap = await plugin.getAll(baseUrl: baseUrl);

expect(versionMap.appName, VERSION_JSON['app_name']);
expect(versionMap.version, VERSION_JSON['version']);
expect(versionMap.buildNumber, VERSION_JSON['build_number']);
expect(versionMap.packageName, VERSION_JSON['package_name']);
expect(versionMap.buildSignature, VERSION_JSON['build_signature']);
});
},
);

testWidgets(
'Get correct versionJsonUrl for http and https',
(tester) async {
Expand Down Expand Up @@ -177,4 +219,89 @@ void main() {
});
},
);

group('Package Info Web (using MockAssetManager)', () {
setUp(() {
client = MockClient();
assetManagerMock = MockAssetManager();
plugin = PackageInfoPlusWebPlugin(client, assetManagerMock);
});

testWidgets(
'Get correct values when using the AssetManager baseUrl',
(tester) async {
const String baseUrl = 'https://an.example.com/using-asset-manager/';
const String assetsDir = 'assets';
final DateTime now = DateTime.now();
final Clock fakeClock = Clock(() => now);

when(assetManagerMock.assetsDir).thenReturn(assetsDir);
when(assetManagerMock.getAssetUrl(''))
.thenReturn('$baseUrl$assetsDir/');

await withClock(fakeClock, () async {
final int cache = now.millisecondsSinceEpoch;

when(client.get(
Uri.parse('${baseUrl}version.json?cachebuster=$cache'),
)).thenAnswer(
(_) => Future.value(
http.Response(jsonEncode(VERSION_JSON), 200),
),
);

final versionMap = await plugin.getAll();

expect(versionMap.appName, VERSION_JSON['app_name']);
expect(versionMap.version, VERSION_JSON['version']);
expect(versionMap.buildNumber, VERSION_JSON['build_number']);
expect(versionMap.packageName, VERSION_JSON['package_name']);
expect(versionMap.buildSignature, VERSION_JSON['build_signature']);
});
},
);

testWidgets(
'Has preference for the custom base URL over the other 2 locations',
(tester) async {
const String customBaseUrl = 'https://www.example.com/with-path/';
const String managerBaseUrl = 'https://www.asset-manager.com/path/';
const String assetsDir = 'assets';
final DateTime now = DateTime.now();
final Clock fakeClock = Clock(() => now);

when(assetManagerMock.assetsDir).thenReturn(assetsDir);
when(assetManagerMock.getAssetUrl(''))
.thenReturn('$managerBaseUrl$assetsDir/');

await withClock(fakeClock, () async {
final int cache = now.millisecondsSinceEpoch;

when(client.get(
Uri.parse('${customBaseUrl}version.json?cachebuster=$cache'),
)).thenAnswer(
(_) => Future.value(
http.Response(jsonEncode(VERSION_JSON), 200),
),
);

when(client.get(
Uri.parse('${managerBaseUrl}version.json?cachebuster=$cache'),
)).thenAnswer(
(_) => Future.value(
http.Response(jsonEncode(VERSION_2_JSON), 200),
),
);

final versionMap = await plugin.getAll(baseUrl: customBaseUrl);

expect(versionMap.appName, VERSION_JSON['app_name']);
expect(versionMap.version, VERSION_JSON['version']);
expect(versionMap.buildNumber, VERSION_JSON['build_number']);
expect(versionMap.packageName, VERSION_JSON['package_name']);
expect(versionMap.buildSignature, VERSION_JSON['build_signature']);
});
},
);
});
}
Loading

0 comments on commit 26047f3

Please sign in to comment.