mirror of
https://github.com/flutter/flutter.git
synced 2026-02-03 17:51:05 +08:00
Bumps the Dart version to 3.8 across the repo (excluding engine/src/flutter/third_party) and applies formatting updates from Dart 3.8. ## Pre-launch Checklist - [x] I read the [Contributor Guide] and followed the process outlined there for submitting PRs. - [x] I read the [Tree Hygiene] wiki page, which explains my responsibilities. - [x] I read and followed the [Flutter Style Guide], including [Features we expect every widget to implement]. - [x] I signed the [CLA]. - [ ] I listed at least one issue that this PR fixes in the description above. - [ ] I updated/added relevant documentation (doc comments with `///`). - [x] I added new tests to check the change I am making, or this PR is [test-exempt]. - [x] I followed the [breaking change policy] and added [Data Driven Fixes] where supported. - [x] All existing and new tests are passing. If you need help, consider asking for advice on the #hackers-new channel on [Discord]. <!-- Links --> [Contributor Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#overview [Tree Hygiene]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md [test-exempt]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#tests [Flutter Style Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md [Features we expect every widget to implement]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md#features-we-expect-every-widget-to-implement [CLA]: https://cla.developers.google.com/ [flutter/tests]: https://github.com/flutter/tests [breaking change policy]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#handling-breaking-changes [Discord]: https://github.com/flutter/flutter/blob/main/docs/contributing/Chat.md [Data Driven Fixes]: https://github.com/flutter/flutter/blob/main/docs/contributing/Data-driven-Fixes.md
135 lines
4.2 KiB
Dart
135 lines
4.2 KiB
Dart
// Copyright 2014 The Flutter Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import 'dart:convert';
|
|
import 'dart:io';
|
|
|
|
/// A result of running a single task.
|
|
class TaskResult {
|
|
TaskResult.buildOnly()
|
|
: succeeded = true,
|
|
data = null,
|
|
detailFiles = null,
|
|
benchmarkScoreKeys = null,
|
|
message = 'No tests run';
|
|
|
|
/// Constructs a successful result.
|
|
TaskResult.success(
|
|
this.data, {
|
|
this.benchmarkScoreKeys = const <String>[],
|
|
this.detailFiles = const <String>[],
|
|
this.message = 'success',
|
|
}) : succeeded = true {
|
|
const JsonEncoder prettyJson = JsonEncoder.withIndent(' ');
|
|
if (benchmarkScoreKeys != null) {
|
|
for (final String key in benchmarkScoreKeys!) {
|
|
if (!data!.containsKey(key)) {
|
|
throw 'Invalid benchmark score key "$key". It does not exist in task '
|
|
'result data ${prettyJson.convert(data)}';
|
|
} else if (data![key] is! num) {
|
|
throw 'Invalid benchmark score for key "$key". It is expected to be a num '
|
|
'but was ${(data![key] as Object).runtimeType}: ${prettyJson.convert(data![key])}';
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Constructs a successful result using JSON data stored in a file.
|
|
factory TaskResult.successFromFile(
|
|
File file, {
|
|
List<String> benchmarkScoreKeys = const <String>[],
|
|
List<String> detailFiles = const <String>[],
|
|
}) {
|
|
return TaskResult.success(
|
|
json.decode(file.readAsStringSync()) as Map<String, dynamic>?,
|
|
benchmarkScoreKeys: benchmarkScoreKeys,
|
|
detailFiles: detailFiles,
|
|
);
|
|
}
|
|
|
|
/// Constructs a [TaskResult] from JSON.
|
|
factory TaskResult.fromJson(Map<String, dynamic> json) {
|
|
final bool success = json['success'] as bool;
|
|
if (success) {
|
|
final List<String> benchmarkScoreKeys =
|
|
(json['benchmarkScoreKeys'] as List<dynamic>? ?? <String>[]).cast<String>();
|
|
final List<String> detailFiles = (json['detailFiles'] as List<dynamic>? ?? <String>[])
|
|
.cast<String>();
|
|
return TaskResult.success(
|
|
json['data'] as Map<String, dynamic>?,
|
|
benchmarkScoreKeys: benchmarkScoreKeys,
|
|
detailFiles: detailFiles,
|
|
message: json['reason'] as String?,
|
|
);
|
|
}
|
|
|
|
return TaskResult.failure(json['reason'] as String?);
|
|
}
|
|
|
|
/// Constructs an unsuccessful result.
|
|
TaskResult.failure(this.message)
|
|
: succeeded = false,
|
|
data = null,
|
|
detailFiles = null,
|
|
benchmarkScoreKeys = null;
|
|
|
|
/// Whether the task succeeded.
|
|
final bool succeeded;
|
|
|
|
/// Task-specific JSON data
|
|
final Map<String, dynamic>? data;
|
|
|
|
/// Files containing detail on the run (e.g. timeline trace files)
|
|
final List<String>? detailFiles;
|
|
|
|
/// Keys in [data] that store scores that will be submitted to Cocoon.
|
|
///
|
|
/// Each key is also part of a benchmark's name tracked by Cocoon.
|
|
final List<String>? benchmarkScoreKeys;
|
|
|
|
/// Whether the task failed.
|
|
bool get failed => !succeeded;
|
|
|
|
/// Explains the result in a human-readable format.
|
|
final String? message;
|
|
|
|
/// Serializes this task result to JSON format.
|
|
///
|
|
/// The JSON format is as follows:
|
|
///
|
|
/// {
|
|
/// "success": true|false,
|
|
/// "data": arbitrary JSON data valid only for successful results,
|
|
/// "detailFiles": list of filenames containing detail on the run
|
|
/// "benchmarkScoreKeys": [
|
|
/// contains keys into "data" that represent benchmarks scores, which
|
|
/// can be uploaded, for example. to golem, valid only for successful
|
|
/// results
|
|
/// ],
|
|
/// "reason": failure reason string valid only for unsuccessful results
|
|
/// }
|
|
Map<String, dynamic> toJson() {
|
|
final Map<String, dynamic> json = <String, dynamic>{'success': succeeded};
|
|
|
|
if (succeeded) {
|
|
json['data'] = data;
|
|
json['detailFiles'] = detailFiles;
|
|
json['benchmarkScoreKeys'] = benchmarkScoreKeys;
|
|
}
|
|
|
|
if (message != null || !succeeded) {
|
|
json['reason'] = message;
|
|
}
|
|
|
|
return json;
|
|
}
|
|
|
|
@override
|
|
String toString() => message ?? '';
|
|
}
|
|
|
|
class TaskResultCheckProcesses extends TaskResult {
|
|
TaskResultCheckProcesses() : super.success(null);
|
|
}
|