2017-04-21 17:10:48 +12:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace SilverStripe\CMS\Tests\Behaviour;
|
|
|
|
|
2021-03-18 15:15:16 +13:00
|
|
|
use Behat\Behat\Hook\Scope\BeforeScenarioScope;
|
2020-10-22 21:21:15 +13:00
|
|
|
use Behat\Mink\Element\DocumentElement;
|
|
|
|
use Behat\Mink\Element\NodeElement;
|
2021-03-18 15:15:16 +13:00
|
|
|
use SilverStripe\BehatExtension\Context\BasicContext;
|
2017-04-21 17:10:48 +12:00
|
|
|
use SilverStripe\BehatExtension\Context\FixtureContext as BehatFixtureContext;
|
|
|
|
use SilverStripe\CMS\Model\RedirectorPage;
|
|
|
|
use SilverStripe\CMS\Model\SiteTree;
|
|
|
|
use SilverStripe\Core\ClassInfo;
|
|
|
|
use SilverStripe\Core\Injector\Injector;
|
|
|
|
use SilverStripe\Dev\FixtureBlueprint;
|
|
|
|
use SilverStripe\Versioned\Versioned;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Context used to create fixtures in the SilverStripe ORM.
|
|
|
|
*/
|
|
|
|
class FixtureContext extends BehatFixtureContext
|
|
|
|
{
|
2021-03-18 15:15:16 +13:00
|
|
|
/**
|
|
|
|
* @var BasicContext
|
|
|
|
*/
|
|
|
|
protected $basicContext;
|
|
|
|
|
|
|
|
|
|
|
|
/** @BeforeScenario */
|
|
|
|
public function gatherContexts(BeforeScenarioScope $scope)
|
|
|
|
{
|
|
|
|
$this->basicContext = $scope->getEnvironment()->getContext(BasicContext::class);
|
|
|
|
}
|
|
|
|
|
2017-04-21 17:10:48 +12:00
|
|
|
protected function scaffoldDefaultFixtureFactory()
|
|
|
|
{
|
|
|
|
$factory = parent::scaffoldDefaultFixtureFactory();
|
|
|
|
|
|
|
|
// Use blueprints which auto-publish all subclasses of SiteTree
|
|
|
|
foreach (ClassInfo::subclassesFor(SiteTree::class) as $class) {
|
|
|
|
$blueprint = Injector::inst()->create(FixtureBlueprint::class, $class);
|
|
|
|
$blueprint->addCallback('afterCreate', function ($obj, $identifier, &$data, &$fixtures) {
|
|
|
|
/** @var SiteTree $obj */
|
|
|
|
$obj->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
});
|
|
|
|
$factory->define($class, $blueprint);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $factory;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Find or create a redirector page and link to another existing page.
|
|
|
|
* Example: Given a "page" "My Redirect" which redirects to a "page" "Page 1"
|
|
|
|
*
|
|
|
|
* @Given /^(?:(an|a|the) )"(?<type>[^"]+)" "(?<id>[^"]+)" (:?which )?redirects to (?:(an|a|the) )"(?<targetType>[^"]+)" "(?<targetId>[^"]+)"$/
|
|
|
|
* @param string $type
|
|
|
|
* @param string $id
|
|
|
|
* @param string $targetType
|
|
|
|
* @param string $targetId
|
|
|
|
*/
|
|
|
|
public function stepCreateRedirectorPage($type, $id, $targetType, $targetId)
|
|
|
|
{
|
|
|
|
$class = RedirectorPage::class;
|
|
|
|
$targetClass = $this->convertTypeToClass($targetType);
|
|
|
|
|
|
|
|
$targetObj = $this->fixtureFactory->get($targetClass, $targetId);
|
|
|
|
if (!$targetObj) {
|
|
|
|
$targetObj = $this->fixtureFactory->get($targetClass, $targetId);
|
|
|
|
}
|
|
|
|
|
2020-04-19 16:18:01 +12:00
|
|
|
$fields = ['LinkToID' => $targetObj->ID];
|
2017-04-21 17:10:48 +12:00
|
|
|
/** @var RedirectorPage $obj */
|
|
|
|
$obj = $this->fixtureFactory->get($class, $id);
|
|
|
|
if ($obj) {
|
|
|
|
$obj->update($fields);
|
|
|
|
} else {
|
|
|
|
$obj = $this->fixtureFactory->createObject($class, $id, $fields);
|
|
|
|
}
|
|
|
|
$obj->write();
|
|
|
|
$obj->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
|
|
|
|
}
|
2020-10-22 21:21:15 +13:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @When /^I see the "([^"]+)" element$/
|
|
|
|
* @param $selector
|
|
|
|
*/
|
|
|
|
public function iSeeTheElement($selector)
|
|
|
|
{
|
|
|
|
/** @var DocumentElement $page */
|
|
|
|
$page = $this->getMainContext()->getSession()->getPage();
|
|
|
|
$element = $page->find('css', $selector);
|
|
|
|
|
|
|
|
assertNotNull($element, sprintf('Element %s not found', $selector));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Selects the specified radio button
|
|
|
|
*
|
|
|
|
* @Given /^I see the "([^"]*)" radio button "([^"]*)" attribute equals "([^"]*)"$/
|
|
|
|
* @param string $radioLabel
|
|
|
|
* @param string $attribute
|
|
|
|
* @param string $value
|
|
|
|
*/
|
|
|
|
public function iSeeTheRadioButtonAttributeEquals($radioLabel, $attribute, $value)
|
|
|
|
{
|
|
|
|
/** @var NodeElement $radioButton */
|
|
|
|
$session = $this->getMainContext()->getSession();
|
|
|
|
$radioButton = $session->getPage()->find('named', [
|
|
|
|
'radio',
|
|
|
|
$this->getMainContext()->getXpathEscaper()->escapeLiteral($radioLabel)
|
|
|
|
]);
|
|
|
|
assertNotNull($radioButton);
|
|
|
|
assertEquals($value, $radioButton->getAttribute($attribute));
|
|
|
|
}
|
2017-04-21 17:10:48 +12:00
|
|
|
}
|