Skip to content

Commit

Permalink
Checking for devtools config file for opt out (#227)
Browse files Browse the repository at this point in the history
* Checking for devtools config file for opt out

* Update version

* Correct mislabeled tests
  • Loading branch information
eliasyishak authored Jan 29, 2024
1 parent 8ffc077 commit b97bd5c
Show file tree
Hide file tree
Showing 5 changed files with 155 additions and 5 deletions.
4 changes: 4 additions & 0 deletions pkgs/unified_analytics/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
## 5.8.1

- Check devtools config file for legacy opt out status

## 5.8.0

- Fix template string for consent message
Expand Down
2 changes: 1 addition & 1 deletion pkgs/unified_analytics/lib/src/constants.dart
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@ const int kLogFileLength = 2500;
const String kLogFileName = 'dart-flutter-telemetry.log';

/// The current version of the package, should be in line with pubspec version.
const String kPackageVersion = '5.8.0';
const String kPackageVersion = '5.8.1';

/// The minimum length for a session.
const int kSessionDurationMinutes = 30;
Expand Down
36 changes: 36 additions & 0 deletions pkgs/unified_analytics/lib/src/utils.dart
Original file line number Diff line number Diff line change
Expand Up @@ -137,13 +137,17 @@ Directory? getHomeDirectory(FileSystem fs) {
/// Dart: `$HOME/.dart/dartdev.json`
///
/// Flutter: `$HOME/.flutter`
///
/// Devtools: `$HOME/.flutter-devtools/.devtools`
bool legacyOptOut({
required FileSystem fs,
required Directory home,
}) {
final dartLegacyConfigFile =
fs.file(p.join(home.path, '.dart', 'dartdev.json'));
final flutterLegacyConfigFile = fs.file(p.join(home.path, '.flutter'));
final devtoolsLegacyConfigFile =
fs.file(p.join(home.path, '.flutter-devtools', '.devtools'));

// Example of what the file looks like for dart
//
Expand Down Expand Up @@ -202,6 +206,38 @@ bool legacyOptOut({
}
}

// Example of what the file looks like for devtools
//
// {
// "analyticsEnabled": false, <-- THIS USER HAS OPTED OUT
// "isFirstRun": false,
// "lastReleaseNotesVersion": "2.31.0",
// "2023-Q4": {
// "surveyActionTaken": false,
// "surveyShownCount": 0
// }
// }
if (devtoolsLegacyConfigFile.existsSync()) {
try {
final devtoolsObj =
jsonDecode(devtoolsLegacyConfigFile.readAsStringSync())
as Map<String, Object?>;
if (devtoolsObj.containsKey('analyticsEnabled') &&
devtoolsObj['analyticsEnabled'] == false) {
return true;
}
} on FormatException {
// In the case of an error when parsing the json file, return true
// which will result in the user being opted out of unified_analytics
//
// A corrupted file could mean they opted out previously but for some
// reason, the file was written incorrectly
return true;
} on FileSystemException {
return true;
}
}

return false;
}

Expand Down
2 changes: 1 addition & 1 deletion pkgs/unified_analytics/pubspec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ description: >-
to Google Analytics.
# When updating this, keep the version consistent with the changelog and the
# value in lib/src/constants.dart.
version: 5.8.0
version: 5.8.1
repository: https://github.com/dart-lang/tools/tree/main/pkgs/unified_analytics

environment:
Expand Down
116 changes: 113 additions & 3 deletions pkgs/unified_analytics/test/legacy_analytics_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -102,7 +102,7 @@ void main() {
});

test('Honor legacy flutter analytics opt out', () {
// Create the file for the dart legacy opt out
// Create the file for the flutter legacy opt out
final flutterLegacyConfigFile =
home.childDirectory('.dart').childFile('dartdev.json');
flutterLegacyConfigFile.createSync(recursive: true);
Expand Down Expand Up @@ -134,7 +134,7 @@ void main() {
});

test('Telemetry enabled if legacy flutter analytics is enabled', () {
// Create the file for the dart legacy opt out
// Create the file for the flutter legacy opt out
final flutterLegacyConfigFile =
home.childDirectory('.dart').childFile('dartdev.json');
flutterLegacyConfigFile.createSync(recursive: true);
Expand Down Expand Up @@ -165,6 +165,78 @@ void main() {
expect(analytics.telemetryEnabled, true);
});

test('Honor legacy devtools analytics opt out', () {
// Create the file for the devtools legacy opt out
final devtoolsLegacyConfigFile =
home.childDirectory('.flutter-devtools').childFile('.devtools');
devtoolsLegacyConfigFile.createSync(recursive: true);
devtoolsLegacyConfigFile.writeAsStringSync('''
{
"analyticsEnabled": false,
"isFirstRun": false,
"lastReleaseNotesVersion": "2.31.0",
"2023-Q4": {
"surveyActionTaken": false,
"surveyShownCount": 0
}
}
''');

// The main analytics instance, other instances can be spawned within tests
// to test how to instances running together work
analytics = Analytics.test(
tool: initialTool,
homeDirectory: home,
measurementId: measurementId,
apiSecret: apiSecret,
flutterChannel: flutterChannel,
toolsMessageVersion: toolsMessageVersion,
toolsMessage: toolsMessage,
flutterVersion: flutterVersion,
dartVersion: dartVersion,
fs: fs,
platform: platform,
);

expect(analytics.telemetryEnabled, false);
});

test('Telemetry enabled if legacy devtools analytics is enabled', () {
// Create the file for the devtools legacy opt out
final devtoolsLegacyConfigFile =
home.childDirectory('.flutter-devtools').childFile('.devtools');
devtoolsLegacyConfigFile.createSync(recursive: true);
devtoolsLegacyConfigFile.writeAsStringSync('''
{
"analyticsEnabled": true,
"isFirstRun": false,
"lastReleaseNotesVersion": "2.31.0",
"2023-Q4": {
"surveyActionTaken": false,
"surveyShownCount": 0
}
}
''');

// The main analytics instance, other instances can be spawned within tests
// to test how to instances running together work
analytics = Analytics.test(
tool: initialTool,
homeDirectory: home,
measurementId: measurementId,
apiSecret: apiSecret,
flutterChannel: flutterChannel,
toolsMessageVersion: toolsMessageVersion,
toolsMessage: toolsMessage,
flutterVersion: flutterVersion,
dartVersion: dartVersion,
fs: fs,
platform: platform,
);

expect(analytics.telemetryEnabled, true);
});

test('Telemetry disabled if dart config file corrupted', () {
// Create the file for the dart legacy opt out with text that
// is not valid JSON
Expand Down Expand Up @@ -199,8 +271,46 @@ NOT VALID JSON
expect(analytics.telemetryEnabled, false);
});

test('Telemetry disabled if devtools config file corrupted', () {
// Create the file for the devtools legacy opt out with text that
// is not valid JSON
final devtoolsLegacyConfigFile =
home.childDirectory('.flutter-devtools').childFile('.devtools');
devtoolsLegacyConfigFile.createSync(recursive: true);
devtoolsLegacyConfigFile.writeAsStringSync('''
NOT VALID JSON
{
"analyticsEnabled": true,
"isFirstRun": false,
"lastReleaseNotesVersion": "2.31.0",
"2023-Q4": {
"surveyActionTaken": false,
"surveyShownCount": 0
}
}
''');

// The main analytics instance, other instances can be spawned within tests
// to test how to instances running together work
analytics = Analytics.test(
tool: initialTool,
homeDirectory: home,
measurementId: measurementId,
apiSecret: apiSecret,
flutterChannel: flutterChannel,
toolsMessageVersion: toolsMessageVersion,
toolsMessage: toolsMessage,
flutterVersion: flutterVersion,
dartVersion: dartVersion,
fs: fs,
platform: platform,
);

expect(analytics.telemetryEnabled, false);
});

test('Telemetry disabled if flutter config file corrupted', () {
// Create the file for the dart legacy opt out with text that
// Create the file for the flutter legacy opt out with text that
// is not valid JSON
final fluttterLegacyConfigFile =
home.childDirectory('.dart').childFile('dartdev.json');
Expand Down

0 comments on commit b97bd5c

Please sign in to comment.