Security update for permissions_by_term
[yaffs-website] / vendor / behat / gherkin / src / Behat / Gherkin / Filter / RoleFilter.php
1 <?php
2
3 /*
4  * This file is part of the Behat Gherkin.
5  * (c) Konstantin Kudryashov <ever.zet@gmail.com>
6  *
7  * For the full copyright and license information, please view the LICENSE
8  * file that was distributed with this source code.
9  */
10
11 namespace Behat\Gherkin\Filter;
12
13 use Behat\Gherkin\Node\FeatureNode;
14 use Behat\Gherkin\Node\ScenarioInterface;
15
16 /**
17  * Filters features by their actors role.
18  *
19  * @author Konstantin Kudryashov <ever.zet@gmail.com>
20  */
21 class RoleFilter extends SimpleFilter
22 {
23     protected $pattern;
24
25     /**
26      * Initializes filter.
27      *
28      * @param string $role Approved role wildcard
29      */
30     public function __construct($role)
31     {
32         $this->pattern = '/as an? ' . strtr(preg_quote($role, '/'), array(
33             '\*' => '.*',
34             '\?' => '.',
35             '\[' => '[',
36             '\]' => ']'
37         )) . '[$\n]/i';
38     }
39
40     /**
41      * Checks if Feature matches specified filter.
42      *
43      * @param FeatureNode $feature Feature instance
44      *
45      * @return Boolean
46      */
47     public function isFeatureMatch(FeatureNode $feature)
48     {
49         return 1 === preg_match($this->pattern, $feature->getDescription());
50     }
51
52     /**
53      * Checks if scenario or outline matches specified filter.
54      *
55      * @param ScenarioInterface $scenario Scenario or Outline node instance
56      *
57      * @return false This filter is designed to work only with features
58      */
59     public function isScenarioMatch(ScenarioInterface $scenario)
60     {
61         return false;
62     }
63 }