Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[WIP] Facebook driver #304

Closed
wants to merge 66 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
66 commits
Select commit Hold shift + click to select a range
5be40f8
moved driver to facebook/webdriver
oleg-andreyev Nov 30, 2018
9921b40
fixing initial commit
oleg-andreyev Nov 30, 2018
34197e2
added chrome to travis
oleg-andreyev Nov 30, 2018
ecd9e46
updated run-selenium.sh
oleg-andreyev Nov 30, 2018
305323d
crlf to lf for bin, removed local override in phpunit.xml.dist, some …
oleg-andreyev Dec 2, 2018
6666a62
adjusted travis for chrome and ff
oleg-andreyev Dec 2, 2018
3a988ef
fixing
oleg-andreyev Dec 2, 2018
4b97f28
fixing
oleg-andreyev Dec 2, 2018
ed49807
fixing
oleg-andreyev Dec 2, 2018
2181be3
fixing upload & wait
oleg-andreyev Dec 8, 2018
d1cdddc
unskipping testWindowMaximize
oleg-andreyev Dec 8, 2018
e7ad036
updated phpunit.xml.dist with examples for FF, updated Selenium2Confi…
oleg-andreyev Dec 9, 2018
9dcf505
downgrade firefox to 2.53.1
oleg-andreyev Dec 15, 2018
d84acc3
reverted "setRequestHeader", unified key actions
oleg-andreyev Dec 30, 2018
77c961f
reverted tests/Custom
oleg-andreyev Jan 4, 2019
25a2d90
added fix to getAttribute, added fix to setValue file-upload, fixing …
oleg-andreyev Jan 4, 2019
2f2ea4f
removed accident phpunit from composer
oleg-andreyev Jan 4, 2019
fcbb4c4
removed charToOptions
oleg-andreyev Jan 4, 2019
8afc38b
reverted spaces in composer, removed roave/security-advisories
oleg-andreyev Jan 4, 2019
c4f0b73
updated .travis.yml to match facebook/webdriver
oleg-andreyev Jan 4, 2019
63fa6fc
added no-api
oleg-andreyev Jan 4, 2019
939caf7
added prefer-dist
oleg-andreyev Jan 4, 2019
4fc6729
fix
oleg-andreyev Jan 4, 2019
aa12542
removed bin/
oleg-andreyev Jan 4, 2019
b01aea6
added logs dir
oleg-andreyev Jan 4, 2019
ba7fad4
fixing travis build
oleg-andreyev Jan 3, 2019
00cc9a8
Merge branch 'fix-master-build' into facebook-driver
oleg-andreyev Jan 5, 2019
bea3c59
adapted .travis.yml from facebook/php-webdriver
oleg-andreyev Jan 5, 2019
d705afc
returned driver specific timeouts, setTimeouts/applyTimeouts
oleg-andreyev Jan 5, 2019
2d4a965
fixing setDesiredCapabilities and getWebDriverSessionId, added more t…
oleg-andreyev Jan 5, 2019
f584e6f
improving wait
oleg-andreyev Jan 5, 2019
a58f29a
improving Selenium2Config
oleg-andreyev Jan 5, 2019
97c2c0b
updated build config
oleg-andreyev Jan 5, 2019
643c0cc
fixing build
oleg-andreyev Jan 5, 2019
c2bb586
fixing build
oleg-andreyev Jan 5, 2019
a5fb84e
update build
oleg-andreyev Jan 5, 2019
d785496
removed selenium jar
oleg-andreyev Jan 5, 2019
b54d351
reusing mink-test-server instead of direct php build-in server, updat…
oleg-andreyev Jan 8, 2019
1180e1c
removed USE_ZEND_ALLOC, added travis_retry
oleg-andreyev Jan 8, 2019
839e9c8
renamed DEPENDENCIES to COMPOSER_FLAGS
oleg-andreyev Jan 8, 2019
1db167c
bumped dev-master alias to 2.0.x-dev
oleg-andreyev Jan 8, 2019
8a96a7f
commented WEB_FIXTURES_HOST in phpunit.xml.dist and added comment
oleg-andreyev Jan 8, 2019
fb7bf5c
removed typehint from Selenium2Config
oleg-andreyev Jan 8, 2019
e79fc7a
added test case for 7.0 with SELENIUM_DRIVER
oleg-andreyev Jan 8, 2019
7d68a07
added BROWSER_NAME for SELENIUM_DRIVER, added --network=host
oleg-andreyev Jan 8, 2019
77f0d98
added typehint to setTimeouts
oleg-andreyev Jan 8, 2019
14ca3c6
moved "if started" check up
oleg-andreyev Jan 8, 2019
390326d
removed "setWebDriver"
oleg-andreyev Jan 8, 2019
127434f
added "getWebDriver" to bypass Mink API
oleg-andreyev Jan 8, 2019
f0351a1
changed visibility of executeJsOnXpath from protected to private
oleg-andreyev Jan 8, 2019
f6000fa
removed $started property in favor of isStarted, where we are checkin…
oleg-andreyev Jan 8, 2019
33d7e8f
avoid override $element variable in getValue/setValue
oleg-andreyev Jan 8, 2019
eeeb1e1
removed comment from clickOnElement
oleg-andreyev Jan 8, 2019
5510e51
removed typehint from attachFile, added correct return type to findEl…
oleg-andreyev Jan 8, 2019
4ba0fe5
changed exception in resizeWindow/maximizeWindow from generic Excepti…
oleg-andreyev Jan 8, 2019
eddbe48
removed extra space in ensureInputType
oleg-andreyev Jan 8, 2019
97827c0
removed unused method uploadFile
oleg-andreyev Jan 8, 2019
d964481
updated docblock to keyModifier/decodeChar
oleg-andreyev Jan 8, 2019
ae01600
updated docblock to `wait` method
oleg-andreyev Jan 8, 2019
12209e5
updated travis.yml
oleg-andreyev Jan 8, 2019
c00efd4
changed implementation of focus/blur
oleg-andreyev Jan 8, 2019
741cd41
return --network to docker
oleg-andreyev Jan 8, 2019
0959ab8
update .travis.yml
oleg-andreyev Jan 8, 2019
3bba166
dummy commit (trigger build)
oleg-andreyev Jan 8, 2019
35544c1
dummy commit (trigger build)
oleg-andreyev Jan 8, 2019
1bc41c1
fixing build for selenium-firefox:2.53.1
oleg-andreyev Jan 10, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fixing setDesiredCapabilities and getWebDriverSessionId, added more t…
…ests for TimeoutTest
  • Loading branch information
oleg-andreyev committed Jan 5, 2019
commit 2d4a965730f489c75bd2d92250317842c490f968
20 changes: 18 additions & 2 deletions src/Selenium2Driver.php
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,12 @@ public function __construct($browserName = 'firefox', $desiredCapabilities = nul
} else {
$this->desiredCapabilities = new DesiredCapabilities();
}

if ($desiredCapabilities) {
foreach ($desiredCapabilities as $key => $val) {
$this->desiredCapabilities->setCapability($key, $val);
}
}
}

/**
Expand Down Expand Up @@ -139,12 +145,18 @@ protected function setBrowserName($browserName = 'firefox')
*
* See http://code.google.com/p/selenium/wiki/DesiredCapabilities
*
* @param DesiredCapabilities $desiredCapabilities
* @param DesiredCapabilities|array|null $desiredCapabilities
*
* @throws DriverException
*/
public function setDesiredCapabilities(DesiredCapabilities $desiredCapabilities = null)
public function setDesiredCapabilities($desiredCapabilities = null)
{
if (is_array($desiredCapabilities)) {
$desiredCapabilities = new DesiredCapabilities($desiredCapabilities);
} else if ($desiredCapabilities === null) {
$desiredCapabilities = new DesiredCapabilities();
}

if ($this->started) {
throw new DriverException('Unable to set desiredCapabilities, the session has already started');
oleg-andreyev marked this conversation as resolved.
Show resolved Hide resolved
}
Expand Down Expand Up @@ -918,6 +930,10 @@ public function maximizeWindow($name = null)
*/
public function getWebDriverSessionId()
{
if (!$this->started) {
return null;
}

return $this->webDriver->getSessionID();
}

Expand Down
7 changes: 5 additions & 2 deletions tests/Custom/DesiredCapabilitiesTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

use Behat\Mink\Driver\Selenium2Driver;
use Behat\Mink\Tests\Driver\TestCase;
use Facebook\WebDriver\Remote\DesiredCapabilities;

class DesiredCapabilitiesTest extends TestCase
{
Expand All @@ -23,8 +24,8 @@ public function testGetDesiredCapabilities()

$driver = new Selenium2Driver('firefox', $caps);
$this->assertNotEmpty($driver->getDesiredCapabilities(), 'desiredCapabilities empty');
$this->assertInternalType('array', $driver->getDesiredCapabilities());
$this->assertEquals($caps, $driver->getDesiredCapabilities());
$this->assertInstanceOf(DesiredCapabilities::class, $driver->getDesiredCapabilities());
$this->assertArraySubset($caps, $driver->getDesiredCapabilities()->toArray());
}

/**
Expand All @@ -46,6 +47,8 @@ public function testSetDesiredCapabilities()
);
$session = $this->getSession();
$session->start();

/** @var Selenium2Driver $driver */
$driver = $session->getDriver();
$driver->setDesiredCapabilities($caps);
}
Expand Down
70 changes: 61 additions & 9 deletions tests/Custom/TimeoutTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,40 +2,92 @@

namespace Behat\Mink\Tests\Driver\Custom;

use Behat\Mink\Driver\Selenium2Driver;
use Behat\Mink\Tests\Driver\TestCase;

class TimeoutTest extends TestCase
{
/** @var \Behat\Mink\Session */
private $session;

/** @var Selenium2Driver */
private $driver;

protected function setUp()
{
parent::setUp();
$this->session = $this->getSession();
$this->driver = $this->session->getDriver();
}

/**
* @expectedException \Behat\Mink\Exception\DriverException
*/
public function testInvalidTimeoutSettingThrowsException()
{
$this->getSession()->start();

$this->getSession()->getDriver()->setTimeouts(array('invalid' => 0));
$this->session->start();
$this->driver->setTimeouts(array('invalid' => 0));
}

public function testShortTimeoutDoesNotWaitForElementToAppear()
{
$this->getSession()->getDriver()->setTimeouts(array('implicit' => 0));
$this->driver->setTimeouts(array('implicit' => 0));

$this->getSession()->visit($this->pathTo('/js_test.html'));
$this->session->visit($this->pathTo('/js_test.html'));
$this->findById('waitable')->click();

$element = $this->getSession()->getPage()->find('css', '#waitable > div');
$element = $this->session->getPage()->find('css', '#waitable > div');

$this->assertNull($element);
}

public function testLongTimeoutWaitsForElementToAppear()
{
$this->getSession()->getDriver()->setTimeouts(array('implicit' => 5000));
$this->driver->setTimeouts(array('implicit' => 5000));

$this->getSession()->visit($this->pathTo('/js_test.html'));
$this->session->visit($this->pathTo('/js_test.html'));
$this->findById('waitable')->click();
$element = $this->getSession()->getPage()->find('css', '#waitable > div');
$element = $this->session->getPage()->find('css', '#waitable > div');

$this->assertNotNull($element);
}

/**
* @expectedException \Behat\Mink\Exception\DriverException
*/
public function testPageLoadTimeout()
{
$this->driver->setTimeouts(array('pageLoad' => 1));
$this->session->visit($this->pathTo('/page_load.php?sleep=2'));
}

/**
* @expectedException \Behat\Mink\Exception\DriverException
*/
public function testPageReloadTimeout()
{
$this->session->visit($this->pathTo('/page_load.php?sleep=2'));
$this->driver->setTimeouts(array('pageLoad' => 1));
$this->session->reload();
}

/**
* @expectedException \Behat\Mink\Exception\DriverException
*/
public function testScriptTimeout()
{
$this->driver->setTimeouts(array('script' => 1));
$this->session->visit($this->pathTo('/js_test.html'));

// @see https://w3c.github.io/webdriver/#execute-async-script
$this->driver->executeAsyncScript(
'var callback = arguments[arguments.length - 1];
setTimeout(
function(){
callback();
},
2000
);'
);
}
}