Skip to content

Commit

Permalink
[js] Use the proper W3C command for getLocation/getSize
Browse files Browse the repository at this point in the history
Fixes #3513
  • Loading branch information
jleyba committed Feb 15, 2017
1 parent b94c902 commit 317ae67
Show file tree
Hide file tree
Showing 3 changed files with 64 additions and 0 deletions.
2 changes: 2 additions & 0 deletions javascript/node/selenium-webdriver/CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@
* Added the ability to use Firefox Nightly
* If Firefox cannot be found in the default location, look for it on the PATH
* Allow SafariDriver to use Safari Technology Preview.
* Use the proper wire command for WebElement.getLocation() and
WebElement.getSize() for W3C compliant drivers.

## v3.0.1

Expand Down
2 changes: 2 additions & 0 deletions javascript/node/selenium-webdriver/lib/http.js
Original file line number Diff line number Diff line change
Expand Up @@ -259,6 +259,8 @@ const W3C_COMMAND_MAP = new Map([
[cmd.Name.GET_ELEMENT_ATTRIBUTE, (cmd) => {
return toExecuteAtomCommand(cmd, Atom.GET_ATTRIBUTE, 'id', 'name');
}],
[cmd.Name.GET_ELEMENT_LOCATION, get('/session/:sessionId/element/:id/rect')],
[cmd.Name.GET_ELEMENT_SIZE, get('/session/:sessionId/element/:id/rect')],
[cmd.Name.IS_ELEMENT_DISPLAYED, (cmd) => {
return toExecuteAtomCommand(cmd, Atom.IS_DISPLAYED, 'id');
}],
Expand Down
60 changes: 60 additions & 0 deletions javascript/node/selenium-webdriver/test/rect_test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
// Licensed to the Software Freedom Conservancy (SFC) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The SFC licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.

'use strict';

const assert = require('assert');

const {By} = require('..');
const test = require('../lib/test');

test.suite(function(env) {
describe('rect commands', function() {
let driver;
let el;

test.before(function*() {
driver = yield env.builder().build();
yield driver.get(
'data:text/html,<!DOCTYPE html><style>'
+ '*{padding:0; margin:0}'
+ 'div{position: absolute; top: 50px; left: 50px;'
+ 'height: 50px;width:50px;background: green;}'
+ '</style><div>Hello</div>');
el = yield driver.findElement(By.css('div'));
});

after(function() {
if (driver) {
return driver.quit();
}
});

test.it('WebElement.getLocation()', function*() {
let location = yield el.getLocation();
assert.equal(location.x, 50);
assert.equal(location.y, 50);
});

test.it('WebElement.getSize()', function*() {
let size = yield el.getSize();
assert.equal(size.width, 50);
assert.equal(size.height, 50);
});

});
});

0 comments on commit 317ae67

Please sign in to comment.