mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-11 12:03:14 +00:00
221 lines
6.0 KiB
PHP
221 lines
6.0 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Phraseanet
|
|
*
|
|
* (c) 2005-2014 Alchemy
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
require_once __DIR__ . '/../../vendor/autoload.php';
|
|
|
|
use Alchemy\Phrasea\Application;
|
|
use Behat\Behat\Exception\PendingException;
|
|
use Behat\MinkExtension\Context\MinkContext;
|
|
use Alchemy\Phrasea\Model\Entities\User;
|
|
|
|
class GuiContext extends MinkContext
|
|
{
|
|
/** @var Application */
|
|
protected $app;
|
|
|
|
/**
|
|
* Initializes context.
|
|
* Every scenario gets it's own context object.
|
|
*
|
|
* @param array $parameters context parameters (set them up through behat.yml)
|
|
*/
|
|
public function __construct(array $parameters)
|
|
{
|
|
$this->app = new Application('test');
|
|
}
|
|
|
|
/**
|
|
* @Given /^I am not authenticated$/
|
|
*/
|
|
public function iAmNotAuthenticated()
|
|
{
|
|
$this->app['session']->clear();
|
|
$this->app['authentication']->reinitUser();
|
|
}
|
|
|
|
/**
|
|
* @Given /^locale is "([^"]*)"$/
|
|
*/
|
|
public function localeIs($localeI18n)
|
|
{
|
|
$this->getSession()->setCookie('locale', $localeI18n);
|
|
}
|
|
|
|
/**
|
|
* @When /^I click "([^"]*)"$/
|
|
*/
|
|
public function iClick($css)
|
|
{
|
|
$page = $this->getSession()->getPage();
|
|
|
|
$el = $page->find('css', $css);
|
|
|
|
$el->click();
|
|
}
|
|
|
|
/**
|
|
* @Given /^a user "([^"]*)" does not exist$/
|
|
*/
|
|
public function aUserDoesNotExist($login)
|
|
{
|
|
if (null !== $user = $this->app['manipulator.user']->getRepository()->findByLogin($login)) {
|
|
$this->app['acl']->get($user)->revoke_access_from_bases(array_keys(
|
|
$this->app['acl']->get($this->app['authentication']->getUser())->get_granted_base(array('canadmin'))
|
|
));
|
|
|
|
$this->app['manipulator.user']->delete($user);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Given /^a user "([^"]*)" exists with "([^"]*)" as password$/
|
|
*/
|
|
public function aUserExistsWithAsPassword($login, $password)
|
|
{
|
|
if (null === $user = $this->app['manipulator.user']->getRepository()->findByLogin($login)) {
|
|
$this->app['manipulator.user']->create($login, $password, null, false);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Given /^a user "([^"]*)" exists$/
|
|
*/
|
|
public function aUserExists($login)
|
|
{
|
|
$this->aUserExistsWithAsPassword($login, uniqid());
|
|
}
|
|
|
|
/**
|
|
* @Given /^captcha system is enable$/
|
|
*/
|
|
public function captchaSystemIsEnable()
|
|
{
|
|
$this->app['phraseanet.registry']->set('GV_captchas', true, \registry::TYPE_BOOLEAN);
|
|
}
|
|
|
|
/**
|
|
* @Given /^captcha system is disable/
|
|
*/
|
|
public function captchaSystemIsDisable()
|
|
{
|
|
$this->app['phraseanet.registry']->set('GV_captchas', false, \registry::TYPE_BOOLEAN);
|
|
}
|
|
|
|
/**
|
|
* @Given /^user registration is enable$/
|
|
*/
|
|
public function userRegistrationIsEnable()
|
|
{
|
|
$databox = current($this->app['phraseanet.appbox']->get_databoxes());
|
|
|
|
$xml = $databox->get_sxml_structure();
|
|
|
|
if (!$xml) {
|
|
throw new \Exception('Invalid databox xml structure');
|
|
}
|
|
|
|
if (!isset($xml->caninscript)) {
|
|
|
|
$xml->addChild('caninscript', '1');
|
|
|
|
$dom = new \DOMDocument();
|
|
$dom->loadXML($xml->asXML());
|
|
|
|
$databox->saveStructure($dom);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Given /^user registration is disable/
|
|
*/
|
|
public function userRegistrationIsDisable()
|
|
{
|
|
$databox = current($this->app['phraseanet.appbox']->get_databoxes());
|
|
|
|
$xml = $databox->get_sxml_structure();
|
|
|
|
if (!$xml) {
|
|
throw new \Exception('Invalid databox xml structure');
|
|
}
|
|
|
|
if (isset($xml->caninscript)) {
|
|
unset($xml->caninscript);
|
|
|
|
$dom = new \DOMDocument();
|
|
$dom->loadXML($xml->asXML());
|
|
|
|
$databox->saveStructure($dom);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Given /^user guest access is enable$/
|
|
*/
|
|
public function userGuestAccessIsEnable()
|
|
{
|
|
if (null === $user = $this->app['manipulator.user']->getRepository()->findByLogin(User::USER_GUEST)) {
|
|
$user = $this->app['manipulator.user']->create(User::USER_GUEST, '');
|
|
}
|
|
|
|
$this->app['acl']->get($user)->give_access_to_sbas(array_keys($this->app['phraseanet.appbox']->get_databoxes()));
|
|
|
|
foreach ($this->app['phraseanet.appbox']->get_databoxes() as $databox) {
|
|
foreach ($databox->get_collections() as $collection) {
|
|
$this->app['acl']->get($user)->give_access_to_base(array($collection->get_base_id()));
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Given /^user guest access is disable/
|
|
*/
|
|
public function userGuestAccessIsDisable()
|
|
{
|
|
if (null !== $user = $this->app['manipulator.user']->getRepository()->findByLogin(User::USER_GUEST)) {
|
|
foreach ($this->app['phraseanet.appbox']->get_databoxes() as $databox) {
|
|
foreach ($databox->get_collections() as $collection) {
|
|
$this->app['acl']->get($user)->revoke_access_from_bases(array($collection->get_base_id()));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Given /^a user "([^"]*)" exists with a valid password token "([^"]*)"$/
|
|
*/
|
|
public function aUserExistsWithAValidPasswordToken($login, $token)
|
|
{
|
|
throw new PendingException();
|
|
}
|
|
|
|
/**
|
|
* @Given /^"([^"]*)" is not authenticated$/
|
|
*/
|
|
public function isNotAuthenticated($login)
|
|
{
|
|
$this->iAmNotAuthenticated();
|
|
}
|
|
|
|
/**
|
|
* @Given /^"([^"]*)" is authenticated$/
|
|
*/
|
|
public function isAuthenticated($login)
|
|
{
|
|
if (null === $user = $this->app['manipulator.user']->getRepository()->findByLogin($login)) {
|
|
throw new \Exception(sprintf('User %s does not exists, use the following definition to create it : a user "%s" exists', $login, $login));
|
|
}
|
|
|
|
$this->app['authentication']->openAccount($user);
|
|
|
|
throw new PendingException();
|
|
}
|
|
}
|