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\WebDriverKeys;
use PHPUnit\Framework\Assert;
use PHPUnit\Framework\ExpectationFailedException;
use SilverStripe\Assets\File;
use SilverStripe\Assets\Filesystem;
use SilverStripe\BehatExtension\Utility\StepHelper;
@ -1350,13 +1351,56 @@ JS;
*
* @Then /^I add "([^"]+)" to the "([^"]+)" tag field$/
* @param string $value
* @param string $locator
* @param string $selector
*/
public function iAddToTheTagField($value, $locator)
public function iAddToTheTagField($value, $selector)
{
$tagFieldInput = $this->getElement($locator);
$tagFieldInput->setValue($value);
$tagFieldInput->getParent()->getParent()->getParent()->getParent()->find('css', '.Select-menu-outer')->click();
$page = $this->getSession()->getPage();
/** @var NodeElement $parentElement */
$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;
$emailContent = null;
if ($email->Content) {
$emailContent = $email->Content;
if ($email['Content']) {
$emailContent = $email['Content'];
} else {
$emailContent = $email->PlainContent;
$emailContent = $email['PlainContent'];
}
if (trim($negate ?? '')) {
@ -154,8 +154,7 @@ class EmailContext implements Context
}
$email = $this->lastMatchedEmail;
$emailContent = ($email->Content) ? ($email->Content) : ($email->PlainContent);
$emailPlainText = strip_tags($emailContent ?? '');
$emailPlainText = $email['PlainContent'] ? $email['PlainContent'] : strip_tags($email['Content']);
$emailPlainText = preg_replace("/\h+/", " ", $emailPlainText ?? '');
Assert::assertStringContainsString($content, $emailPlainText);
@ -219,7 +218,7 @@ class EmailContext implements Context
}
$match = $this->lastMatchedEmail;
$crawler = new Crawler($match->Content);
$crawler = new Crawler($match['Content']);
$linkEl = $crawler->selectLink($linkSelector);
Assert::assertNotNull($linkEl);
$link = $linkEl->attr('href');
@ -254,10 +253,10 @@ class EmailContext implements Context
$email = $this->lastMatchedEmail;
$emailContent = null;
if ($email->Content) {
$emailContent = $email->Content;
if ($email['Content']) {
$emailContent = $email['Content'];
} else {
$emailContent = $email->PlainContent;
$emailContent = $email['PlainContent'];
}
// Convert html content to plain text
$emailContent = strip_tags($emailContent ?? '');
@ -309,9 +308,9 @@ class EmailContext implements Context
$match = $this->lastMatchedEmail;
if (trim($negate ?? '')) {
Assert::assertStringNotContainsString($from, $match->From);
Assert::assertStringNotContainsString($from, $match['From']);
} else {
Assert::assertStringContainsString($from, $match->From);
Assert::assertStringContainsString($from, $match['From']);
}
}
@ -328,9 +327,9 @@ class EmailContext implements Context
$match = $this->lastMatchedEmail;
if (trim($negate ?? '')) {
Assert::assertStringNotContainsString($to, $match->To);
Assert::assertStringNotContainsString($to, $match['To']);
} else {
Assert::assertStringContainsString($to, $match->To);
Assert::assertStringContainsString($to, $match['To']);
}
}
@ -348,7 +347,7 @@ class EmailContext implements Context
}
$email = $this->lastMatchedEmail;
$html = $email->Content;
$html = $email['Content'];
$dom = new \DOMDocument();
$dom->loadHTML($html);