|
4 | 4 | use Behat\Behat\Hook\Scope\BeforeScenarioScope; |
5 | 5 | use Behat\MinkExtension\Context\MinkContext; |
6 | 6 | use Behat\Behat\Hook\Scope\BeforeFeatureScope; |
| 7 | +use Behat\Testwork\Hook\Scope\BeforeSuiteScope; |
7 | 8 | use Ramsey\Uuid\Uuid; |
8 | 9 | use Surfnet\StepupBehat\Factory\CommandPayloadFactory; |
9 | 10 | use Surfnet\StepupBehat\Repository\SecondFactorRepository; |
@@ -44,24 +45,64 @@ class FeatureContext implements Context |
44 | 45 | */ |
45 | 46 | private $institutionConfiguration; |
46 | 47 |
|
| 48 | + public static function execCommand(string $command): void |
| 49 | + { |
| 50 | + $output = []; |
| 51 | + $returnCode = -1; |
| 52 | + $result = exec($command, $output, $returnCode); |
| 53 | + |
| 54 | + if($result === false) { |
| 55 | + echo "Failed executing command\n"; |
| 56 | + die(); |
| 57 | + } |
| 58 | + |
| 59 | + foreach ($output as $line) { |
| 60 | + echo $line."\n"; |
| 61 | + } |
| 62 | + |
| 63 | + if ($returnCode !== 0) { |
| 64 | + die(); |
| 65 | + } |
| 66 | + } |
| 67 | + |
47 | 68 | /** |
48 | | - * @BeforeFeature |
| 69 | + * @BeforeSuite |
49 | 70 | */ |
50 | | - public static function setupDatabase(BeforeFeatureScope $scope) |
| 71 | + public static function setupDatabase(BeforeSuiteScope $scope) |
51 | 72 | { |
52 | 73 | // Generate test databases |
53 | 74 | echo "Preparing test schemas\n"; |
54 | | - shell_exec("docker exec -t stepup-middleware-1 bin/console doctrine:schema:drop --env=smoketest --force"); |
55 | | - shell_exec("docker exec -t stepup-gateway-1 bin/console doctrine:schema:drop --env=smoketest --force"); |
56 | | - shell_exec("docker exec -t stepup-middleware-1 bin/console doctrine:schema:create --env=smoketest"); |
57 | | - shell_exec("docker exec -t stepup-gateway-1 bin/console doctrine:schema:create --env=smoketest"); |
| 75 | + self::execCommand('docker exec -t stepup-middleware-1 bin/console doctrine:schema:drop --em=middleware --env=smoketest --force'); |
| 76 | + self::execCommand('docker exec -t stepup-middleware-1 bin/console doctrine:schema:drop --em=gateway --env=smoketest --force'); |
| 77 | + self::execCommand('docker exec -t stepup-middleware-1 bin/console doctrine:schema:create --em=middleware --env=smoketest'); |
| 78 | + self::execCommand('docker exec -t stepup-middleware-1 bin/console doctrine:schema:create --em=gateway --env=smoketest'); |
58 | 79 |
|
59 | | - echo "Replaying event stream\n"; |
60 | 80 | // Import the events.sql into middleware |
61 | | - shell_exec("mysql -uroot -psecret middleware_test -h mariadb < ./fixtures/events.sql"); |
62 | | - shell_exec("./fixtures/middleware-push-config.sh"); |
| 81 | + echo "Add events to test database\n"; |
| 82 | + self::execCommand("mysql -uroot -psecret middleware_test -h mariadb < ./fixtures/events.sql"); |
| 83 | + |
63 | 84 | // Perform an event replay |
64 | | - shell_exec("docker exec -t stepup-middleware-1 bin/console middleware:event:replay --env=smoketest_event_replay --no-interaction -q"); |
| 85 | + echo "Replaying event stream\n"; |
| 86 | + self::execCommand("docker exec -t stepup-middleware-1 bin/console middleware:event:replay --env=smoketest_event_replay --no-interaction -vvv"); |
| 87 | + |
| 88 | + // Push config |
| 89 | + echo "Push Middleware config\n"; |
| 90 | + self::execCommand("./fixtures/middleware-push-config.sh"); |
| 91 | + self::execCommand("./fixtures/middleware-push-whitelist.sh"); |
| 92 | + self::execCommand("./fixtures/middleware-push-institution.sh"); |
| 93 | + |
| 94 | + // Write base setup for initializing features |
| 95 | + echo "Dump empty setup to mysql file\n"; |
| 96 | + self::execCommand("mysqldump -h mariadb -u root -psecret --single-transaction --databases middleware_test gateway_test > setup.sql"); |
| 97 | + } |
| 98 | + |
| 99 | + /** |
| 100 | + * @BeforeFeature |
| 101 | + */ |
| 102 | + public static function load(BeforeFeatureScope $scope) |
| 103 | + { |
| 104 | + // restore base setup |
| 105 | + self::execCommand("mysql -h mariadb -u root -psecret < setup.sql"); |
65 | 106 | } |
66 | 107 |
|
67 | 108 | /** |
|
0 commit comments