blob: 27cd50a90d09b2b3fa09d5cc24c1dac9d25025b3 [file] [log] [blame]
// Copyright 2015 Google Inc. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
@TestOn("vm")
library webdriver.command_event_test;
import 'package:stack_trace/stack_trace.dart';
import 'package:test/test.dart';
import 'package:webdriver/async_core.dart';
import 'package:webdriver/support/async.dart';
import 'io_config.dart' as config;
void main() {
group('CommandEvent', () {
WebDriver driver;
var events = <WebDriverCommandEvent>[];
var sub;
setUp(() async {
driver = await config.createTestDriver();
sub = driver.onCommand.listen(events.add);
await driver.get(config.testPagePath);
});
tearDown(() async {
sub.cancel();
sub = null;
events.clear();
await driver.quit();
driver = null;
});
test('handles exceptions', () async {
try {
await driver.switchTo.alert;
} catch (e) {}
await waitFor(() => events, matcher: hasLength(2));
expect(events[1].method, 'GET');
expect(events[1].endPoint, contains('alert'));
expect(events[1].exception, new isInstanceOf<WebDriverException>());
expect(events[1].result, isNull);
expect(events[1].startTime.isBefore(events[1].endTime), isTrue);
expect(events[1].stackTrace, new isInstanceOf<Chain>());
});
test('handles normal operation', () async {
await driver.findElements(const By.cssSelector('nosuchelement')).toList();
await waitFor(() => events, matcher: hasLength(2));
expect(events[1].method, 'POST');
expect(events[1].endPoint, contains('elements'));
expect(events[1].exception, isNull);
expect(events[1].result, hasLength(0));
expect(events[1].startTime.isBefore(events[1].endTime), isTrue);
expect(events[1].stackTrace, new isInstanceOf<Chain>());
});
}, testOn: '!js');
}