Merge pull request #236 from creative-commoners/pulls/5/support-frontend-changes

Various fixes to resolve issues in behat tests
This commit is contained in:
Steve Boyd 2023-01-30 10:40:11 +13:00 committed by GitHub
commit c4c0be1dc8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 62 additions and 19 deletions

View File

@ -21,6 +21,7 @@ use Facebook\WebDriver\WebDriverAlert;
use Facebook\WebDriver\WebDriverExpectedCondition; use Facebook\WebDriver\WebDriverExpectedCondition;
use Facebook\WebDriver\WebDriverKeys; use Facebook\WebDriver\WebDriverKeys;
use PHPUnit\Framework\Assert; use PHPUnit\Framework\Assert;
use PHPUnit\Framework\ExpectationFailedException;
use SilverStripe\Assets\File; use SilverStripe\Assets\File;
use SilverStripe\Assets\Filesystem; use SilverStripe\Assets\Filesystem;
use SilverStripe\BehatExtension\Utility\StepHelper; use SilverStripe\BehatExtension\Utility\StepHelper;
@ -1350,13 +1351,56 @@ JS;
* *
* @Then /^I add "([^"]+)" to the "([^"]+)" tag field$/ * @Then /^I add "([^"]+)" to the "([^"]+)" tag field$/
* @param string $value * @param string $value
* @param string $locator * @param string $selector
*/ */
public function iAddToTheTagField($value, $locator) public function iAddToTheTagField($value, $selector)
{ {
$tagFieldInput = $this->getElement($locator); $page = $this->getSession()->getPage();
$tagFieldInput->setValue($value); /** @var NodeElement $parentElement */
$tagFieldInput->getParent()->getParent()->getParent()->getParent()->find('css', '.Select-menu-outer')->click(); $parentElement = null;
$dropdown = null;
$this->retryThrowable(function () use (&$parentElement, &$page, $selector) {
$parentElement = $page->find('css', $selector);
Assert::assertNotNull($parentElement, sprintf('"%s" element not found', $selector));
$page = $this->getSession()->getPage();
});
$this->retryThrowable(function () use (&$dropdown, $parentElement, $selector) {
$dropdown = $parentElement->find('css', '.ss-tag-field__dropdown-indicator');
Assert::assertNotNull($dropdown, sprintf('Unable to find the dropdown in "%s"', $selector));
$dropdown->click();
});
$inputField = null;
try {
// Try setting to a value already in the dropdown
$this->retryThrowable(function () use ($value, $parentElement, $selector) {
$element = $parentElement->find('xpath', sprintf('//*[count(*)=0 and .="%s"]', $value));
Assert::assertNotNull($element, sprintf('"%s" not found in "%s"', $value, $selector));
$element->click();
});
} catch (ExpectationFailedException $e) {
// Try creating a new value
$this->retryThrowable(function () use (&$inputField, $value, $parentElement, $selector) {
/** @var NodeElement $parentElement */
$inputField = $parentElement->find('css', '.ss-tag-field__input');
Assert::assertNotNull($inputField, sprintf('Could not create "%s" in "%s"', $value, $selector));
// We need to type the value in - react won't accept us just setting the value via js
$inputField->focus();
/** @var FacebookWebDriver $driver */
$driver = $this->getSession()->getDriver();
$keyboard = $driver->getWebDriver()->getKeyboard();
$keyboard->sendKeys($value);
});
// Try selecting the 'Create "$value"' option
$this->retryThrowable(function () use ($value, $parentElement, $selector) {
$createOption = 'Create "' . $value . '"';
$element = $parentElement->find('xpath', sprintf('//*[count(*)=0 and .=\'%s\']', $createOption));
Assert::assertNotNull($element, sprintf('"%s" not found in "%s"', $createOption, $selector));
$element->click();
});
}
} }
/** /**

View File

@ -125,10 +125,10 @@ class EmailContext implements Context
$email = $this->lastMatchedEmail; $email = $this->lastMatchedEmail;
$emailContent = null; $emailContent = null;
if ($email->Content) { if ($email['Content']) {
$emailContent = $email->Content; $emailContent = $email['Content'];
} else { } else {
$emailContent = $email->PlainContent; $emailContent = $email['PlainContent'];
} }
if (trim($negate ?? '')) { if (trim($negate ?? '')) {
@ -154,8 +154,7 @@ class EmailContext implements Context
} }
$email = $this->lastMatchedEmail; $email = $this->lastMatchedEmail;
$emailContent = ($email->Content) ? ($email->Content) : ($email->PlainContent); $emailPlainText = $email['PlainContent'] ? $email['PlainContent'] : strip_tags($email['Content']);
$emailPlainText = strip_tags($emailContent ?? '');
$emailPlainText = preg_replace("/\h+/", " ", $emailPlainText ?? ''); $emailPlainText = preg_replace("/\h+/", " ", $emailPlainText ?? '');
Assert::assertStringContainsString($content, $emailPlainText); Assert::assertStringContainsString($content, $emailPlainText);
@ -219,7 +218,7 @@ class EmailContext implements Context
} }
$match = $this->lastMatchedEmail; $match = $this->lastMatchedEmail;
$crawler = new Crawler($match->Content); $crawler = new Crawler($match['Content']);
$linkEl = $crawler->selectLink($linkSelector); $linkEl = $crawler->selectLink($linkSelector);
Assert::assertNotNull($linkEl); Assert::assertNotNull($linkEl);
$link = $linkEl->attr('href'); $link = $linkEl->attr('href');
@ -254,10 +253,10 @@ class EmailContext implements Context
$email = $this->lastMatchedEmail; $email = $this->lastMatchedEmail;
$emailContent = null; $emailContent = null;
if ($email->Content) { if ($email['Content']) {
$emailContent = $email->Content; $emailContent = $email['Content'];
} else { } else {
$emailContent = $email->PlainContent; $emailContent = $email['PlainContent'];
} }
// Convert html content to plain text // Convert html content to plain text
$emailContent = strip_tags($emailContent ?? ''); $emailContent = strip_tags($emailContent ?? '');
@ -309,9 +308,9 @@ class EmailContext implements Context
$match = $this->lastMatchedEmail; $match = $this->lastMatchedEmail;
if (trim($negate ?? '')) { if (trim($negate ?? '')) {
Assert::assertStringNotContainsString($from, $match->From); Assert::assertStringNotContainsString($from, $match['From']);
} else { } else {
Assert::assertStringContainsString($from, $match->From); Assert::assertStringContainsString($from, $match['From']);
} }
} }
@ -328,9 +327,9 @@ class EmailContext implements Context
$match = $this->lastMatchedEmail; $match = $this->lastMatchedEmail;
if (trim($negate ?? '')) { if (trim($negate ?? '')) {
Assert::assertStringNotContainsString($to, $match->To); Assert::assertStringNotContainsString($to, $match['To']);
} else { } else {
Assert::assertStringContainsString($to, $match->To); Assert::assertStringContainsString($to, $match['To']);
} }
} }
@ -348,7 +347,7 @@ class EmailContext implements Context
} }
$email = $this->lastMatchedEmail; $email = $this->lastMatchedEmail;
$html = $email->Content; $html = $email['Content'];
$dom = new \DOMDocument(); $dom = new \DOMDocument();
$dom->loadHTML($html); $dom->loadHTML($html);