blob: acd273d2101574116eb165e5dac025cf27910871 [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.
*/
/**
* @description Tests that intrinsic width values on absolutely positioned
* element work.
*/
import "dart:html";
import "../../testcommon.dart";
import "../../../Utils/async_utils.dart";
import "../../resources/check-layout.dart";
import "pwd.dart";
main() {
var f = new DocumentFragment.html('''
<style>
.container {
position:relative;
border: 5px solid blue;
width: 250px;
height: 250px;
}
.child {
position:absolute;
display: -webkit-flex;
-webkit-flex-wrap: wrap;
border: 5px solid pink;
}
.content {
display: inline-block;
width: 100px;
height: 100px;
background-color: salmon;
}
</style>
''', treeSanitizer: new NullTreeSanitizer());
document.head.append(f);
document.body.setInnerHtml('''
<!-- width tests -->
<div class="container">
<div class="child" style="width: -webkit-max-content;" data-expected-width="210">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container">
<div class="child" style="width: -webkit-min-content;" data-expected-width="110">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container">
<div class="child" style="width: -webkit-fit-content;" data-expected-width="210">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container" style="width: 50px">
<div class="child" style="width: -webkit-fit-content;" data-expected-width="110">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container">
<div class="child" style="width: -webkit-fill-available;" data-expected-width="250">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<!-- min-width tests -->
<div class="container">
<div class="child" style="min-width: -webkit-max-content; width: 10px;" data-expected-width="210">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container">
<div class="child" style="min-width: -webkit-min-content; width: 10px;" data-expected-width="110">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container">
<div class="child" style="min-width: -webkit-fit-content; width: 10px;" data-expected-width="210">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container" style="width: 50px">
<div class="child" style="min-width: -webkit-fit-content; width: 10px;" data-expected-width="110">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container">
<div class="child" style="min-width: -webkit-fill-available; width: 10px;" data-expected-width="250">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<!-- max-width tests -->
<div class="container">
<div class="child" style="max-width: -webkit-max-content; width: 1000px;" data-expected-width="210">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container">
<div class="child" style="max-width: -webkit-min-content; width: 1000px;" data-expected-width="110">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container">
<div class="child" style="max-width: -webkit-fit-content; width: 1000px;" data-expected-width="210">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container" style="width: 50px">
<div class="child" style="max-width: -webkit-fit-content; width: 1000px;" data-expected-width="110">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
<div class="container">
<div class="child" style="max-width: -webkit-fill-available; width: 1000px;" data-expected-width="250">
<div class="content"></div>
<div class="content"></div>
</div>
</div>
''', treeSanitizer: new NullTreeSanitizer());
asyncStart();
window.onLoad.listen((_) {
checkLayout('.container');
asyncEnd();
});
}