fix(ElementHandle.screenshot): account for scroll (#1323)
Currently, `elementHandle.screenshot` passes bounding box into the `page.captureScreenshot` method. This is wrong since `captureScreenshot` accepts viewport, not bounding box. This patch uses layout metrics to convert bounding box into viewport. Fixes #1315.
This commit is contained in:
parent
2c8f658815
commit
b0b22199f9
@ -144,12 +144,16 @@ class ElementHandle extends JSHandle {
|
||||
*/
|
||||
async screenshot(options = {}) {
|
||||
await this._scrollIntoViewIfNeeded();
|
||||
const { layoutViewport: { pageX, pageY } } = await this._client.send('Page.getLayoutMetrics');
|
||||
|
||||
const boundingBox = await this.boundingBox();
|
||||
if (!boundingBox)
|
||||
throw new Error('Node is not visible');
|
||||
|
||||
const clip = Object.assign({}, boundingBox);
|
||||
clip.x += pageX;
|
||||
clip.y += pageY;
|
||||
return await this._page.screenshot(Object.assign({}, {
|
||||
clip: boundingBox
|
||||
clip
|
||||
}, options));
|
||||
}
|
||||
|
||||
|
BIN
test/golden/screenshot-element-scrolled-into-view.png
Normal file
BIN
test/golden/screenshot-element-scrolled-into-view.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 168 B |
23
test/test.js
23
test/test.js
@ -1796,6 +1796,29 @@ describe('Page', function() {
|
||||
const screenshot = await elementHandle.screenshot();
|
||||
expect(screenshot).toBeGolden('screenshot-element-padding-border.png');
|
||||
}));
|
||||
it('should scroll element into view', SX(async function() {
|
||||
await page.setViewport({width: 500, height: 500});
|
||||
await page.setContent(`
|
||||
something above
|
||||
<style>div.above {
|
||||
border: 2px solid blue;
|
||||
background: red;
|
||||
height: 1500px;
|
||||
}
|
||||
div.to-screenshot {
|
||||
border: 2px solid blue;
|
||||
background: green;
|
||||
width: 50px;
|
||||
height: 50px;
|
||||
}
|
||||
</style>
|
||||
<div class="above"></div>
|
||||
<div class="to-screenshot"></div>
|
||||
`);
|
||||
const elementHandle = await page.$('div.to-screenshot');
|
||||
const screenshot = await elementHandle.screenshot();
|
||||
expect(screenshot).toBeGolden('screenshot-element-scrolled-into-view.png');
|
||||
}));
|
||||
it('should work with a rotated element', SX(async function() {
|
||||
await page.setViewport({width: 500, height: 500});
|
||||
await page.setContent(`<div style="position:absolute;
|
||||
|
Loading…
Reference in New Issue
Block a user