blob: 761aa199bc4e1370b7ada91fe6eee31626cf6d78 [file] [log] [blame]
// Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
// @dart = 2.9
import 'dart:html';
import 'dart:js' as js;
import 'package:async_helper/async_minitest.dart';
import 'utils.dart';
class FooElement extends HtmlElement {
static final tag = 'x-foo';
final int initializedField = 666;
js.JsObject _proxy;
factory FooElement() => new Element.tag(tag);
FooElement.created() : super.created() {
_proxy = new js.JsObject.fromBrowserObject(this);
}
String doSomething() => _proxy.callMethod('doSomething');
bool get fooCreated => _proxy['fooCreated'];
}
main() async {
await customElementsReady;
var upgrader = document.createElementUpgrader(FooElement);
js.context['upgradeListener'] = (e) {
upgrader.upgrade(e);
};
document.registerElement2('custom-element', {'prototype': CustomElement});
test('created gets proxied', () {
var element = document.createElement(FooElement.tag);
expect(element is FooElement, isTrue);
expect((element as FooElement).initializedField, 666);
expect(element.text, 'constructed');
js.context.callMethod('validateIsFoo', [element]);
expect((element as FooElement).doSomething(), 'didSomething');
expect((element as FooElement).fooCreated, true);
});
test('dart constructor works', () {
var element = new FooElement();
expect(element is FooElement, isTrue);
expect(element.text, 'constructed');
js.context.callMethod('validateIsFoo', [element]);
expect(element.doSomething(), 'didSomething');
});
test('cannot upgrade more than once', () {
var fooElement = new FooElement();
expect(() {
upgrader.upgrade(fooElement);
}, throws);
});
test('cannot upgrade non-matching elements', () {
expect(() {
upgrader.upgrade(new DivElement());
}, throws);
});
test('cannot upgrade custom elements', () {
var custom = new CustomElement();
expect(() {
upgrader.upgrade(custom);
}, throws);
});
test('can upgrade with extendsTag', () {
var upgrader = document.createElementUpgrader(CustomDiv, extendsTag: 'div');
var div = new DivElement();
var customDiv = upgrader.upgrade(div);
expect(customDiv is CustomDiv, isTrue);
var htmlElement = document.createElement('not-registered');
expect(() {
upgrader.upgrade(htmlElement);
}, throws);
});
test('cannot create upgrader for built-in types', () {
expect(() {
document.createElementUpgrader(HtmlElement);
}, throws);
});
}
class CustomDiv extends DivElement {
CustomDiv.created() : super.created();
}
class CustomElement extends HtmlElement {
factory CustomElement() => document.createElement('custom-element');
CustomElement.created() : super.created();
}