blob: 0db2ec1f76b20dceac4b7239102b4c8a9d064f11 [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>[];
setUp(() async {
driver = await config.createTestDriver();
driver.addEventListener((WebDriverCommandEvent e) {
events.add(e);
});
await driver.get(config.testPagePath);
});
tearDown(() async {
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, const TypeMatcher<WebDriverException>());
expect(events[1].result, isNull);
expect(events[1].startTime.isBefore(events[1].endTime), isTrue);
expect(events[1].stackTrace, const TypeMatcher<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, const TypeMatcher<Chain>());
});
}, testOn: '!js');
}