233 lines
7.3 KiB
Dart
233 lines
7.3 KiB
Dart
// Copyright 2016 The Chromium 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 'package:meta/meta.dart';
|
|
|
|
import 'error.dart';
|
|
import 'message.dart';
|
|
|
|
const List<Type> _supportedKeyValueTypes = const <Type>[String, int];
|
|
|
|
DriverError _createInvalidKeyValueTypeError(String invalidType) {
|
|
return new DriverError('Unsupported key value type $invalidType. Flutter Driver only supports ${_supportedKeyValueTypes.join(", ")}');
|
|
}
|
|
|
|
/// A command aimed at an object to be located by [finder].
|
|
///
|
|
/// Implementations must provide a concrete [kind]. If additional data is
|
|
/// required beyond the [finder] the implementation may override [serialize]
|
|
/// and add more keys to the returned map.
|
|
abstract class CommandWithTarget extends Command {
|
|
/// Constructs this command given a [finder].
|
|
CommandWithTarget(this.finder, {Duration timeout}) : super(timeout: timeout) {
|
|
if (finder == null)
|
|
throw new DriverError('$runtimeType target cannot be null');
|
|
}
|
|
|
|
/// Deserializes the command from JSON generated by [serialize].
|
|
CommandWithTarget.deserialize(Map<String, String> json)
|
|
: finder = SerializableFinder.deserialize(json),
|
|
super.deserialize(json);
|
|
|
|
/// Locates the object or objects targeted by this command.
|
|
final SerializableFinder finder;
|
|
|
|
/// This method is meant to be overridden if data in addition to [finder]
|
|
/// is serialized to JSON.
|
|
///
|
|
/// Example:
|
|
///
|
|
/// Map<String, String> toJson() => super.toJson()..addAll({
|
|
/// 'foo': this.foo,
|
|
/// });
|
|
@override
|
|
Map<String, String> serialize() =>
|
|
super.serialize()..addAll(finder.serialize());
|
|
}
|
|
|
|
/// Waits until [finder] can locate the target.
|
|
class WaitFor extends CommandWithTarget {
|
|
@override
|
|
final String kind = 'waitFor';
|
|
|
|
/// Creates a command that waits for the widget identified by [finder] to
|
|
/// appear within the [timeout] amount of time.
|
|
///
|
|
/// If [timeout] is not specified the command times out after 5 seconds.
|
|
WaitFor(SerializableFinder finder, {Duration timeout})
|
|
: super(finder, timeout: timeout);
|
|
|
|
/// Deserializes the command from JSON generated by [serialize].
|
|
WaitFor.deserialize(Map<String, String> json) : super.deserialize(json);
|
|
}
|
|
|
|
/// Waits until there are no more transient callbacks in the queue.
|
|
class WaitUntilNoTransientCallbacks extends Command {
|
|
@override
|
|
final String kind = 'waitUntilNoTransientCallbacks';
|
|
|
|
WaitUntilNoTransientCallbacks({Duration timeout}) : super(timeout: timeout);
|
|
|
|
/// Deserializes the command from JSON generated by [serialize].
|
|
WaitUntilNoTransientCallbacks.deserialize(Map<String, String> json)
|
|
: super.deserialize(json);
|
|
}
|
|
|
|
/// The result of a [WaitFor] command.
|
|
class WaitForResult extends Result {
|
|
/// Deserializes the result from JSON.
|
|
static WaitForResult fromJson(Map<String, dynamic> json) {
|
|
return new WaitForResult();
|
|
}
|
|
|
|
@override
|
|
Map<String, dynamic> toJson() => <String, dynamic>{};
|
|
}
|
|
|
|
/// Describes how to the driver should search for elements.
|
|
abstract class SerializableFinder {
|
|
/// Identifies the type of finder to be used by the driver extension.
|
|
String get finderType;
|
|
|
|
/// Deserializes a finder from JSON generated by [serialize].
|
|
static SerializableFinder deserialize(Map<String, String> json) {
|
|
final String finderType = json['finderType'];
|
|
switch(finderType) {
|
|
case 'ByValueKey': return ByValueKey.deserialize(json);
|
|
case 'ByTooltipMessage': return ByTooltipMessage.deserialize(json);
|
|
case 'ByText': return ByText.deserialize(json);
|
|
}
|
|
throw new DriverError('Unsupported search specification type $finderType');
|
|
}
|
|
|
|
/// Serializes common fields to JSON.
|
|
///
|
|
/// Methods that override [serialize] are expected to call `super.serialize`
|
|
/// and add more fields to the returned [Map].
|
|
@mustCallSuper
|
|
Map<String, String> serialize() => <String, String>{
|
|
'finderType': finderType,
|
|
};
|
|
}
|
|
|
|
/// Finds widgets by tooltip text.
|
|
class ByTooltipMessage extends SerializableFinder {
|
|
@override
|
|
final String finderType = 'ByTooltipMessage';
|
|
|
|
/// Creates a tooltip finder given the tooltip's message [text].
|
|
ByTooltipMessage(this.text);
|
|
|
|
/// Tooltip message text.
|
|
final String text;
|
|
|
|
@override
|
|
Map<String, String> serialize() => super.serialize()..addAll(<String, String>{
|
|
'text': text,
|
|
});
|
|
|
|
/// Deserializes the finder from JSON generated by [serialize].
|
|
static ByTooltipMessage deserialize(Map<String, String> json) {
|
|
return new ByTooltipMessage(json['text']);
|
|
}
|
|
}
|
|
|
|
/// Finds widgets by [text] inside a `Text` widget.
|
|
class ByText extends SerializableFinder {
|
|
@override
|
|
final String finderType = 'ByText';
|
|
|
|
/// Creates a text finder given the text.
|
|
ByText(this.text);
|
|
|
|
/// The text that appears inside the `Text` widget.
|
|
final String text;
|
|
|
|
@override
|
|
Map<String, String> serialize() => super.serialize()..addAll(<String, String>{
|
|
'text': text,
|
|
});
|
|
|
|
/// Deserializes the finder from JSON generated by [serialize].
|
|
static ByText deserialize(Map<String, String> json) {
|
|
return new ByText(json['text']);
|
|
}
|
|
}
|
|
|
|
/// Finds widgets by `ValueKey`.
|
|
class ByValueKey extends SerializableFinder {
|
|
@override
|
|
final String finderType = 'ByValueKey';
|
|
|
|
/// Creates a finder given the key value.
|
|
ByValueKey(this.keyValue)
|
|
: this.keyValueString = '$keyValue',
|
|
this.keyValueType = '${keyValue.runtimeType}' {
|
|
if (!_supportedKeyValueTypes.contains(keyValue.runtimeType))
|
|
throw _createInvalidKeyValueTypeError('$keyValue.runtimeType');
|
|
}
|
|
|
|
/// The true value of the key.
|
|
final dynamic keyValue;
|
|
|
|
/// Stringified value of the key (we can only send strings to the VM service)
|
|
final String keyValueString;
|
|
|
|
/// The type name of the key.
|
|
///
|
|
/// May be one of "String", "int". The list of supported types may change.
|
|
final String keyValueType;
|
|
|
|
@override
|
|
Map<String, String> serialize() => super.serialize()..addAll(<String, String>{
|
|
'keyValueString': keyValueString,
|
|
'keyValueType': keyValueType,
|
|
});
|
|
|
|
/// Deserializes the finder from JSON generated by [serialize].
|
|
static ByValueKey deserialize(Map<String, String> json) {
|
|
final String keyValueString = json['keyValueString'];
|
|
final String keyValueType = json['keyValueType'];
|
|
switch(keyValueType) {
|
|
case 'int':
|
|
return new ByValueKey(int.parse(keyValueString));
|
|
case 'String':
|
|
return new ByValueKey(keyValueString);
|
|
default:
|
|
throw _createInvalidKeyValueTypeError(keyValueType);
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Command to read the text from a given element.
|
|
class GetText extends CommandWithTarget {
|
|
@override
|
|
final String kind = 'get_text';
|
|
|
|
/// [finder] looks for an element that contains a piece of text.
|
|
GetText(SerializableFinder finder, { Duration timeout }) : super(finder, timeout: timeout);
|
|
|
|
/// Deserializes the command from JSON generated by [serialize].
|
|
GetText.deserialize(Map<String, dynamic> json) : super.deserialize(json);
|
|
}
|
|
|
|
/// The result of the [GetText] command.
|
|
class GetTextResult extends Result {
|
|
/// Creates a result with the given [text].
|
|
GetTextResult(this.text);
|
|
|
|
/// The text extracted by the [GetText] command.
|
|
final String text;
|
|
|
|
/// Deserializes the result from JSON.
|
|
static GetTextResult fromJson(Map<String, dynamic> json) {
|
|
return new GetTextResult(json['text']);
|
|
}
|
|
|
|
@override
|
|
Map<String, dynamic> toJson() => <String, String>{
|
|
'text': text,
|
|
};
|
|
}
|