Security update for permissions_by_term
[yaffs-website] / vendor / behat / behat / src / Behat / Testwork / Hook / Call / RuntimeSuiteHook.php
diff --git a/vendor/behat/behat/src/Behat/Testwork/Hook/Call/RuntimeSuiteHook.php b/vendor/behat/behat/src/Behat/Testwork/Hook/Call/RuntimeSuiteHook.php
new file mode 100644 (file)
index 0000000..237bc76
--- /dev/null
@@ -0,0 +1,83 @@
+<?php
+
+/*
+ * This file is part of the Behat Testwork.
+ * (c) Konstantin Kudryashov <ever.zet@gmail.com>
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Behat\Testwork\Hook\Call;
+
+use Behat\Testwork\Call\Exception\BadCallbackException;
+use Behat\Testwork\Hook\Scope\HookScope;
+use Behat\Testwork\Hook\Scope\SuiteScope;
+use Behat\Testwork\Suite\Suite;
+
+/**
+ * Represents suite hook executed in the runtime.
+ *
+ * @author Konstantin Kudryashov <ever.zet@gmail.com>
+ */
+abstract class RuntimeSuiteHook extends RuntimeFilterableHook
+{
+    /**
+     * Initializes hook.
+     *
+     * @param string      $scopeName
+     * @param null|string $filterString
+     * @param callable    $callable
+     * @param null|string $description
+     *
+     * @throws BadCallbackException If callback is method, but not a static one
+     */
+    public function __construct($scopeName, $filterString, $callable, $description = null)
+    {
+        parent::__construct($scopeName, $filterString, $callable, $description);
+
+        if ($this->isAnInstanceMethod()) {
+            throw new BadCallbackException(sprintf(
+                'Suite hook callback: %s::%s() must be a static method',
+                $callable[0],
+                $callable[1]
+            ), $callable);
+        }
+    }
+
+    /**
+     * {@inheritdoc}
+     */
+    public function filterMatches(HookScope $scope)
+    {
+        if (!$scope instanceof SuiteScope) {
+            return false;
+        }
+        if (null === ($filterString = $this->getFilterString())) {
+            return true;
+        }
+
+        if (!empty($filterString)) {
+            return $this->isSuiteMatch($scope->getSuite(), $filterString);
+        }
+
+        return false;
+    }
+
+    /**
+     * Checks if Feature matches specified filter.
+     *
+     * @param Suite  $suite
+     * @param string $filterString
+     *
+     * @return Boolean
+     */
+    private function isSuiteMatch(Suite $suite, $filterString)
+    {
+        if ('/' === $filterString[0]) {
+            return 1 === preg_match($filterString, $suite->getName());
+        }
+
+        return false !== mb_strpos($suite->getName(), $filterString, 0, 'utf8');
+    }
+}