diff --git a/src/Selenium2Driver.php b/src/Selenium2Driver.php index 463479be..2964038c 100755 --- a/src/Selenium2Driver.php +++ b/src/Selenium2Driver.php @@ -953,7 +953,7 @@ public function mouseOver(string $xpath) private function scrollElementIntoView(Element $element): void { $script = <<attribute('value') === $value) { - $element->click(); + $this->clickOnElement($element); return; } @@ -1230,7 +1230,7 @@ private function selectRadioValue(Element $element, string $value): void throw new DriverException($message, 0, $e); } - $input->click(); + $this->clickOnElement($input); } /** @@ -1242,6 +1242,7 @@ private function selectOptionOnElement(Element $element, string $value, bool $mu // The value of an option is the normalized version of its text when it has no value attribute $optionQuery = sprintf('.//option[@value = %s or (not(@value) and normalize-space(.) = %s)]', $escapedValue, $escapedValue); $option = $element->element('xpath', $optionQuery); + $this->doMouseOver($element); if ($multiple || !$element->attribute('multiple')) { if (!$option->selected()) { diff --git a/tests/Custom/LargePageClickTest.php b/tests/Custom/LargePageClickTest.php index 17a16960..4705eeed 100644 --- a/tests/Custom/LargePageClickTest.php +++ b/tests/Custom/LargePageClickTest.php @@ -8,14 +8,48 @@ class LargePageClickTest extends TestCase { public function testLargePageClick(): void { - $this->getSession()->visit($this->pathTo('/multi_input_form.html')); + $this->getSession()->visit($this->pathTo('/advanced_form.html')); + // @todo Why is size attribute causing ElementClickIntercepted errors? + $this->getSession()->executeScript('document.querySelector("input[name=\'first_name\']").setAttribute("size", 200);'); - // Add a large amount of br tags so that the button is not in view. + // Add a large amount of br tags so that form elements are not in view. $this->makePageLong(); $page = $this->getSession()->getPage(); + + // Test select focus. + $this->scrollToTop(); + $page->selectFieldOption('select_number', 'thirty'); + + // Test radio button focus. + $this->scrollToTop(); + $page->selectFieldOption('sex', 'm'); + + // Test checkboxes focus. + $this->scrollToTop(); + $page->uncheckField('mail_list'); + $this->scrollToTop(); + $page->checkField('agreement'); + + // Test button focus and submit. + $this->scrollToTop(); $page->pressButton('Register'); - $this->assertStringContainsString('no file', $page->getContent()); + + $expected = <<assertStringContainsString($expected, $page->getContent()); } public function testDragDrop(): void @@ -47,4 +81,11 @@ private function makePageLong(): void { $this->getSession()->executeScript($script); } + /** + * Scrolls to the top of the page. + */ + private function scrollToTop(): void { + $this->getSession()->executeScript('window.scrollTo(0, 0);'); + } + }