mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
test(ElementHandle.boxModel): remake test to make it more readable (#2287)
This patch: - re-makes test for EH.boxModel to make it more readable - slightly changes wording in the `docs/api.md`. References #1357.
This commit is contained in:
parent
c6c60aa1cb
commit
c4da19bd23
@ -2207,7 +2207,7 @@ This method returns the bounding box of the element (relative to the main frame)
|
|||||||
- width <[number]> Element's width.
|
- width <[number]> Element's width.
|
||||||
- height <[number]> Element's height.
|
- height <[number]> Element's height.
|
||||||
|
|
||||||
This method returns boxes of the element, or `null` if the element is not visible. Boxes are represented as an array of objects, {x, y} for each point, points clock-wise. See [getBoxModel](https://chromedevtools.github.io/devtools-protocol/tot/DOM#method-getBoxModel) for more details.
|
This method returns boxes of the element, or `null` if the element is not visible. Boxes are represented as an array of points; each Point is an object `{x, y}`. Box points are sorted clock-wise.
|
||||||
|
|
||||||
#### elementHandle.click([options])
|
#### elementHandle.click([options])
|
||||||
- `options` <[Object]>
|
- `options` <[Object]>
|
||||||
|
50
test/assets/resetcss.html
Normal file
50
test/assets/resetcss.html
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
<style>
|
||||||
|
/* http://meyerweb.com/eric/tools/css/reset/
|
||||||
|
v2.0 | 20110126
|
||||||
|
License: none (public domain)
|
||||||
|
*/
|
||||||
|
|
||||||
|
html, body, div, span, applet, object, iframe,
|
||||||
|
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
|
||||||
|
a, abbr, acronym, address, big, cite, code,
|
||||||
|
del, dfn, em, img, ins, kbd, q, s, samp,
|
||||||
|
small, strike, strong, sub, sup, tt, var,
|
||||||
|
b, u, i, center,
|
||||||
|
dl, dt, dd, ol, ul, li,
|
||||||
|
fieldset, form, label, legend,
|
||||||
|
table, caption, tbody, tfoot, thead, tr, th, td,
|
||||||
|
article, aside, canvas, details, embed,
|
||||||
|
figure, figcaption, footer, header, hgroup,
|
||||||
|
menu, nav, output, ruby, section, summary,
|
||||||
|
time, mark, audio, video {
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
border: 0;
|
||||||
|
font-size: 100%;
|
||||||
|
font: inherit;
|
||||||
|
vertical-align: baseline;
|
||||||
|
}
|
||||||
|
/* HTML5 display-role reset for older browsers */
|
||||||
|
article, aside, details, figcaption, figure,
|
||||||
|
footer, header, hgroup, menu, nav, section {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
body {
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
ol, ul {
|
||||||
|
list-style: none;
|
||||||
|
}
|
||||||
|
blockquote, q {
|
||||||
|
quotes: none;
|
||||||
|
}
|
||||||
|
blockquote:before, blockquote:after,
|
||||||
|
q:before, q:after {
|
||||||
|
content: '';
|
||||||
|
content: none;
|
||||||
|
}
|
||||||
|
table {
|
||||||
|
border-collapse: collapse;
|
||||||
|
border-spacing: 0;
|
||||||
|
}
|
||||||
|
</style>
|
@ -54,22 +54,58 @@ module.exports.addTests = function({testRunner, expect}) {
|
|||||||
|
|
||||||
describe('ElementHandle.boxModel', function() {
|
describe('ElementHandle.boxModel', function() {
|
||||||
it('should work', async({page, server}) => {
|
it('should work', async({page, server}) => {
|
||||||
const leftTop = {x: 28, y: 260};
|
await page.goto(server.PREFIX + '/resetcss.html');
|
||||||
const rightTop = {x: 292, y: 260};
|
|
||||||
const rightBottom = {x: 292, y: 278};
|
|
||||||
const leftBottom = {x: 28, y: 278};
|
|
||||||
|
|
||||||
await page.setViewport({width: 500, height: 500});
|
// Step 1: Add Frame and position it absolutely.
|
||||||
await page.goto(server.PREFIX + '/frames/nested-frames.html');
|
await utils.attachFrame(page, 'frame1', server.PREFIX + '/resetcss.html');
|
||||||
const nestedFrame = page.frames()[1].childFrames()[1];
|
await page.evaluate(() => {
|
||||||
const elementHandle = await nestedFrame.$('div');
|
const frame = document.querySelector('#frame1');
|
||||||
const box = await elementHandle.boxModel();
|
frame.style = `
|
||||||
expect(box.content).toEqual([leftTop, rightTop, rightBottom, leftBottom]);
|
position: absolute;
|
||||||
expect(box.padding).toEqual([leftTop, rightTop, rightBottom, leftBottom]);
|
left: 1px;
|
||||||
expect(box.border).toEqual([leftTop, rightTop, rightBottom, leftBottom]);
|
top: 2px;
|
||||||
expect(box.margin).toEqual([leftTop, rightTop, rightBottom, leftBottom]);
|
`;
|
||||||
expect(box.height).toBe(18);
|
});
|
||||||
expect(box.width).toBe(264);
|
|
||||||
|
// Step 2: Add div and position it absolutely inside frame.
|
||||||
|
const frame = page.frames()[1];
|
||||||
|
const divHandle = (await frame.evaluateHandle(() => {
|
||||||
|
const div = document.createElement('div');
|
||||||
|
document.body.appendChild(div);
|
||||||
|
div.style = `
|
||||||
|
box-sizing: border-box;
|
||||||
|
position: absolute;
|
||||||
|
border-left: 1px solid black;
|
||||||
|
padding-left: 2px;
|
||||||
|
margin-left: 3px;
|
||||||
|
left: 4px;
|
||||||
|
top: 5px;
|
||||||
|
width: 6px;
|
||||||
|
height: 7px;
|
||||||
|
`;
|
||||||
|
return div;
|
||||||
|
})).asElement();
|
||||||
|
|
||||||
|
// Step 3: query div's boxModel and assert box values.
|
||||||
|
const box = await divHandle.boxModel();
|
||||||
|
expect(box.width).toBe(6);
|
||||||
|
expect(box.height).toBe(7);
|
||||||
|
expect(box.margin[0]).toEqual({
|
||||||
|
x: 1 + 4, // frame.left + div.left
|
||||||
|
y: 2 + 5,
|
||||||
|
});
|
||||||
|
expect(box.border[0]).toEqual({
|
||||||
|
x: 1 + 4 + 3, // frame.left + div.left + div.margin-left
|
||||||
|
y: 2 + 5,
|
||||||
|
});
|
||||||
|
expect(box.padding[0]).toEqual({
|
||||||
|
x: 1 + 4 + 3 + 1, // frame.left + div.left + div.marginLeft + div.borderLeft
|
||||||
|
y: 2 + 5,
|
||||||
|
});
|
||||||
|
expect(box.content[0]).toEqual({
|
||||||
|
x: 1 + 4 + 3 + 1 + 2, // frame.left + div.left + div.marginLeft + div.borderLeft + dif.paddingLeft
|
||||||
|
y: 2 + 5,
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return null for invisible elements', async({page, server}) => {
|
it('should return null for invisible elements', async({page, server}) => {
|
||||||
|
Loading…
Reference in New Issue
Block a user