mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
This is called right after stamping the template into the ShadowRoot. This is a useful place to querySelector/getElementById for elements inside the ShadowRoot. R=eseidel@chromium.org Review URL: https://codereview.chromium.org/817053002
63 lines
1.9 KiB
Plaintext
63 lines
1.9 KiB
Plaintext
<sky>
|
|
<import src="/sky/tests//resources/chai.sky" />
|
|
<import src="/sky/tests/resources/mocha.sky" />
|
|
<import src="/sky/tests/resources/test-element.sky" as="TestElement" />
|
|
|
|
<div id="sandbox"></div>
|
|
|
|
<script>
|
|
describe("SkyElement templates", function() {
|
|
var element;
|
|
var sandbox = document.getElementById("sandbox");
|
|
|
|
beforeEach(function() {
|
|
element = new TestElement();
|
|
});
|
|
afterEach(function() {
|
|
element.remove();
|
|
});
|
|
|
|
it("should stamp when the element is inserted", function() {
|
|
assert.isNull(element.shadowRoot);
|
|
sandbox.appendChild(element);
|
|
assert.instanceOf(element.shadowRoot, ShadowRoot);
|
|
assert.ok(element.shadowRoot.getElementById("inside"));
|
|
});
|
|
|
|
it("should connect data binding", function(done) {
|
|
sandbox.appendChild(element);
|
|
var inside = element.shadowRoot.getElementById("inside");
|
|
Promise.resolve().then(function() {
|
|
assert.equal(inside.textContent, 10);
|
|
assert.equal(inside.attr, 10);
|
|
element.value = 20;
|
|
}).then(function() {
|
|
assert.equal(inside.textContent, 20);
|
|
assert.equal(inside.attr, 20);
|
|
done();
|
|
}).catch(function(e) {
|
|
done(e);
|
|
});
|
|
});
|
|
|
|
it("should connect event handlers", function() {
|
|
sandbox.appendChild(element);
|
|
var inside = element.shadowRoot.getElementById("inside");
|
|
inside.dispatchEvent(new CustomEvent("wrong-event"));
|
|
assert.isNull(element.lastEvent);
|
|
var event = new CustomEvent("test-event");
|
|
inside.dispatchEvent(event);
|
|
assert.equal(element.lastEvent, event);
|
|
});
|
|
|
|
it("should call shadowRootReady after creating the template instance", function() {
|
|
assert.equal(element.shadowRootReadyCount, 0);
|
|
sandbox.appendChild(element);
|
|
assert.equal(element.shadowRootReadyCount, 1);
|
|
element.remove();
|
|
sandbox.appendChild(element);
|
|
assert.equal(element.shadowRootReadyCount, 1);
|
|
});
|
|
});
|
|
</script>
|
|
</sky> |