Skip to content

Commit

Permalink
HTML Imports: Add a case for "Fetching import" section.
Browse files Browse the repository at this point in the history
  • Loading branch information
omo committed Aug 4, 2014
1 parent 06e4193 commit ade8bde
Show file tree
Hide file tree
Showing 6 changed files with 113 additions and 0 deletions.
28 changes: 28 additions & 0 deletions html-imports/fetching/already-in-import-map.html
@@ -0,0 +1,28 @@
<!DOCTYPE html>
<html>
<head>
<title>Fetching import</title>
<link rel="help" href="http://w3c.github.io/webcomponents/spec/imports/#fetching-import">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<link rel="stylesheet" href="/resources/testharness.css">

<link id="first" rel="import" href="resources/hello.html">
<link id="shouldBeInImportMap" rel="import" href="resources/hello.html">
<link id="parentOfFirst" rel="import" href="resources/parent-of-hello.html">

</head>
<body>
<div id="log"></div>
<script>
test(function() {
assert_true(window.first.import === window.shouldBeInImportMap.import);
}, 'If LOCATION is already in the import map, let IMPORT be the imported document for LOCATION and stop. (1)');

test(function() {
console.log(window.parentOfFirst);
assert_true(window.first.import === window.parentOfFirst.import.getElementById('child').import);
}, 'If LOCATION is already in the import map, let IMPORT be the imported document for LOCATION and stop. (2)');
</script>
</body>
</html>
77 changes: 77 additions & 0 deletions html-imports/fetching/loading-attempt.html
@@ -0,0 +1,77 @@
<!DOCTYPE html>
<html>
<head>
<title>Fetching import</title>
<link rel="help" href="http://w3c.github.io/webcomponents/spec/imports/#fetching-import">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<link rel="stylesheet" href="/resources/testharness.css">

<script>
var onloadWasCalledOnSuccess = false;
var onerrorWasCalledOnSuccess = false;
function helloLoadHandler() { onloadWasCalledOnSuccess = true; }
function helloErrorHandler() { onerrorWasCalledOnSuccess = true; }

var onloadWasCalledOnFail = false;
var onerrorWasCalledOnFail = false;
function nosuchLoadHandler() { onloadWasCalledOnFail = true; }
function nosuchErrorHandler() { onerrorWasCalledOnFail = true; }
</script>

<link rel="import" href="resources/hello.html" onload="helloLoadHandler()" onerror="helloLoadHandler()">
<link rel="import" href="resources/no-such.html" onload="nosuchLoadHandler()" onerror="nosuchErrorHandler()">

<script>
test(function() {
assert_true(onloadWasCalledOnSuccess);
assert_false(onerrorWasCalledOnSuccess);
}, 'The loading attempt must be considered successful if IMPORT is not null on the algorithm completion, and failed otherwise. (1)');

test(function() {
assert_false(onloadWasCalledOnFail);
assert_true(onerrorWasCalledOnFail);
}, 'The loading attempt must be considered successful if IMPORT is not null on the algorithm completion, and failed otherwise. (2)');

t1 = async_test('The loading attempt must be considered successful if IMPORT is not null on the algorithm completion, and failed otherwise. (3)')
t1.step(function() {
var importElement = document.createElement('link');
importElement.setAttribute('rel', 'import');
importElement.setAttribute('href', 'resources/dynamic.html');
importElement.addEventListener("error", assert_unreached);
importElement.addEventListener("load", function() {
t1.done();
});

document.head.appendChild(importElement);
});

var onloadWasCalledOnAsync = false;
var onerrorWasCalledOnAsync = false;
var asyncAttemptDone = function() { assert_unreached(); };

function asyncLoadHandler() {
onloadWasCalledOnAsync = true;
asyncAttemptDone();
}
function asyncErrorHandler() {
onerrorWasCalledOnAsync = true;
asyncAttemptDone();
}

t2 = async_test('Every import that is not marked as async delays the load event in the Document.');
asyncAttemptDone = function() {
t2.step(function() {
assert_true(onloadWasCalledOnAsync);
assert_false(onerrorWasCalledOnAsync);
t2.done();
});
};

</script>
<link rel="import" href="resources/async.html" onload="asyncLoadHandler()" onerror="asyncErrorHandler()" async>
</head>
<body>
<div id="log"></div>
</body>
</html>
2 changes: 2 additions & 0 deletions html-imports/fetching/resources/async.html
@@ -0,0 +1,2 @@
<!DOCTYPE html>
<body>Async</body>
2 changes: 2 additions & 0 deletions html-imports/fetching/resources/dynamic.html
@@ -0,0 +1,2 @@
<!DOCTYPE html>
<body>Dyamic</body>
2 changes: 2 additions & 0 deletions html-imports/fetching/resources/hello.html
@@ -0,0 +1,2 @@
<!DOCTYPE html>
<body>Hello</body>
2 changes: 2 additions & 0 deletions html-imports/fetching/resources/parent-of-hello.html
@@ -0,0 +1,2 @@
<!DOCTYPE html>
<link id="child" rel="import" href="hello.html">

0 comments on commit ade8bde

Please sign in to comment.