From 4020919d08122aaff496036523abef0c8c2aa7d2 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Mon, 3 Feb 2020 10:45:28 -0800 Subject: [PATCH 01/18] Adding template for circle-cI. --- .circleci/config.yml | 230 ++++++++++++++++++ .gitignore | 2 + composer.json | 15 +- phpunit.core.xml.dist | 75 ++++++ tests/src/Behat/behat.yml | 38 +++ tests/src/Behat/example.behat.local.yml | 31 +++ .../bootstrap/ApigeeEdgeFeatureContext.php | 33 +++ 7 files changed, 420 insertions(+), 4 deletions(-) create mode 100644 .circleci/config.yml create mode 100644 phpunit.core.xml.dist create mode 100644 tests/src/Behat/behat.yml create mode 100644 tests/src/Behat/example.behat.local.yml create mode 100644 tests/src/Behat/features/bootstrap/ApigeeEdgeFeatureContext.php diff --git a/.circleci/config.yml b/.circleci/config.yml new file mode 100644 index 00000000..4f7b9fe9 --- /dev/null +++ b/.circleci/config.yml @@ -0,0 +1,230 @@ +# Default configuration file for Drupal modules. +# +# Use setup.sh to automate setting this up. Otherwise, to use this in a new +# module: +# 1. Copy config.yml to the module's .circleci directory. +# 2. Change 'latest' in the image tag to the latest tag. +# 3. Update the working_directory key. +# 4. Connect CircleCI to the repository through the Circle UI. +# 5. Set the COMPOSER_AUTH environment variable in Circle to grant access to +# any private repositories. +# 6. Create a status badge embed code in Circle and add it to the README.md. +# +# Check https://circleci.com/docs/2.0/language-php/ for more details +# + +defaults: &defaults + docker: + # specify the version you desire here (avoid latest except for testing) + - image: andrewberry/drupal_tests:0.4.0 + + - image: selenium/standalone-chrome-debug:3.141.59-neon + + - image: mariadb:10.4 + environment: + MYSQL_ALLOW_EMPTY_PASSWORD: 1 + + # Specify service dependencies here if necessary + # CircleCI maintains a library of pre-built images + # documented at https://circleci.com/docs/2.0/circleci-images/ + # - image: circleci/mysql:9.4 + + # 'checkout' supports a path key, but not on locals where you test with the + # circleci CLI tool. + # https://discuss.circleci.com/t/bug-circleci-build-command-ignores-checkout-path-config/13004 + working_directory: /var/www/html/modules/apigee_edge + +# YAML does not support merging of lists. That means we can't have a default +# 'steps' configuration, though we can have defaults for individual step +# properties. + +# We use the composer.json as a way to determine if we can cache our build. +restore_cache: &restore_cache + keys: + - v4-dependencies-{{ checksum "composer.json" }}-{{ checksum "../../composer.json" }} + # fallback to using the latest cache if no exact match is found + - v4-dependencies- + +# If composer.json hasn't changed, restore the Composer cache directory. We +# don't restore the lock file so we ensure we get updated dependencies. +save_cache: &save_cache + paths: + - /root/.composer/cache/files + key: v4-dependencies-{{ checksum "composer.json" }}-{{ checksum "../../composer.json" }} + +# Install composer dependencies into the workspace to share with all jobs. +update_dependencies: &update_dependencies + <<: *defaults + steps: + - checkout + + - restore_cache: *restore_cache + + - run: + working_directory: /var/www/html + command: | + ./update-dependencies.sh $CIRCLE_PROJECT_REPONAME + + - save_cache: *save_cache + + - persist_to_workspace: + root: /var/www/html + paths: + - . + +# Run Drupal unit and kernel tests as one job. This command invokes the test.sh +# hook. +unit_kernel_tests: &unit_kernel_tests + <<: *defaults + steps: + - attach_workspace: + at: /var/www/html + + - checkout + + - run: + working_directory: /var/www/html + command: | + ./test.sh $CIRCLE_PROJECT_REPONAME + + - store_test_results: + path: /var/www/html/artifacts/phpunit + - store_artifacts: + path: /var/www/html/artifacts + +# Run Drupal functional tests. This command invokes the test-functional.sh +# hook. +functional_tests: &functional_tests + <<: *defaults + steps: + - attach_workspace: + at: /var/www/html + + - checkout + + - run: + working_directory: /var/www/html + command: | + ./test-functional.sh $CIRCLE_PROJECT_REPONAME + + - store_test_results: + path: /var/www/html/artifacts/phpunit + - store_artifacts: + path: /var/www/html/artifacts + +# Run Drupal functional tests. This command invokes the test-functional-js.sh +# hook. +functional_js_tests: &functional_js_tests + <<: *defaults + steps: + - attach_workspace: + at: /var/www/html + + - checkout + + - run: + working_directory: /var/www/html + command: | + ./test-functional-js.sh $CIRCLE_PROJECT_REPONAME + + - store_test_results: + path: /var/www/html/artifacts/phpunit + - store_artifacts: + path: /var/www/html/artifacts + +# Run Behat tests. This command invokes the behat.sh hook. +behat_tests: &behat_tests + <<: *defaults + steps: + - attach_workspace: + at: /var/www/html + + - checkout + + - run: + working_directory: /var/www/html + command: | + ./behat.sh $CIRCLE_PROJECT_REPONAME + + - store_artifacts: + path: /var/www/html/artifacts + +# Run code quality tests. This invokes code-sniffer.sh. +code_sniffer: &code_sniffer + <<: *defaults + steps: + - attach_workspace: + at: /var/www/html + + - checkout + + - run: + working_directory: /var/www/html + command: | + ./code-sniffer.sh $CIRCLE_PROJECT_REPONAME + + - store_test_results: + path: /var/www/html/artifacts/phpcs + - store_artifacts: + path: /var/www/html/artifacts + +# Run code coverage tests. This invokes code-coverage-stats.sh. +code_coverage: &code_coverage + <<: *defaults + steps: + - attach_workspace: + at: /var/www/html + + - checkout + + - run: + working_directory: /var/www/html + command: | + ./code-coverage-stats.sh $CIRCLE_PROJECT_REPONAME + - store_artifacts: + path: /var/www/html/artifacts + +# Declare all of the jobs we should run. +version: 2 +jobs: + update-dependencies: + <<: *update_dependencies + run-unit-kernel-tests: + <<: *unit_kernel_tests + run-functional-tests: + <<: *functional_tests + run-functional-js-tests: + <<: *functional_js_tests + run-behat-tests: + <<: *behat_tests + run-code-sniffer: + <<: *code_sniffer + run-code-coverage: + <<: *code_coverage + +workflows: + version: 2 + + # Declare a workflow that runs all of our jobs in parallel. + test_and_lint: + jobs: + - update-dependencies + - run-unit-kernel-tests: + requires: + - update-dependencies + - run-functional-tests: + requires: + - update-dependencies + - run-functional-js-tests: + requires: + - update-dependencies + - run-behat-tests: + requires: + - update-dependencies + - run-code-sniffer: + requires: + - update-dependencies + - run-code-coverage: + requires: + - update-dependencies + - run-unit-kernel-tests diff --git a/.gitignore b/.gitignore index 3b54f6c5..1ad38b3a 100644 --- a/.gitignore +++ b/.gitignore @@ -1,5 +1,6 @@ # Ignore all hidden files exept these. .* +!/.circleci !/.github !/.gitignore !/.gitattributes @@ -10,3 +11,4 @@ # Other ignored paths and files. /vendor composer.lock +tests/src/Behat/behat.local.yml diff --git a/composer.json b/composer.json index 0ed6d0d3..5c7d444f 100644 --- a/composer.json +++ b/composer.json @@ -7,17 +7,24 @@ "php": ">=7.1", "ext-json": "*", "apigee/apigee-client-php": "^2.0.4", - "cweagans/composer-patches": "^1.6.5", "drupal/core": "~8.7", "drupal/entity": "^1.0", "drupal/key": "^1.8", "php-http/guzzle6-adapter": "^1.1.1" }, "require-dev": { - "behat/mink" : "dev-master#9ea1cebe", + "behat/mink": "dev-master#9ea1cebe", + "behat/mink-extension": "v2.2", + "behat/mink-selenium2-driver": "1.3.x-dev", + "bex/behat-screenshot": "^1.2", + "cweagans/composer-patches": "^1.6", + "drupal/coder": "^8.3", + "drupal/core-dev": "^8.7", + "drupal/drupal-extension": "master-dev", "drush/drush": "^9.0", - "phpunit/phpunit": "^6.5", - "drupal/core-dev": "^8.7" + "phpmd/phpmd": "^2.8", + "phpmetrics/phpmetrics": "^2.5", + "phpunit/phpunit": "^6.5" }, "config": { "sort-packages": true diff --git a/phpunit.core.xml.dist b/phpunit.core.xml.dist new file mode 100644 index 00000000..3a3ad061 --- /dev/null +++ b/phpunit.core.xml.dist @@ -0,0 +1,75 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + ./tests/TestSuites/UnitTestSuite.php + + + ./tests/TestSuites/KernelTestSuite.php + + + ./tests/TestSuites/FunctionalTestSuite.php + + + ./tests/TestSuites/UnitTestSuite.php + ./tests/TestSuites/KernelTestSuite.php + + + ./tests/TestSuites/FunctionalJavascriptTestSuite.php + + + + + + + + + + + + + ../modules/apigee_edge + + + ../modules/apigee_edge/tests + ../modules/apigee_edge/test_modules + + + + diff --git a/tests/src/Behat/behat.yml b/tests/src/Behat/behat.yml new file mode 100644 index 00000000..7e6ff21f --- /dev/null +++ b/tests/src/Behat/behat.yml @@ -0,0 +1,38 @@ +default: + suites: + default: + contexts: + - ApigeeEdgeFeatureContext + - Drupal\DrupalExtension\Context\DrupalContext + - Drupal\DrupalExtension\Context\MinkContext + - Drupal\DrupalExtension\Context\MessageContext + extensions: + Behat\MinkExtension: + goutte: ~ + selenium2: ~ + base_url: http://localhost + sessions: + default: + goutte: ~ + javascript: + selenium2: + browser: chrome + wd_host: http://localhost:4444/wd/hub + Drupal\DrupalExtension: + blackbox: ~ + api_driver: 'drupal' + drush: + alias: 'local' + drupal: + drupal_root: '/var/www/html' + region_map: + footer: "#footer" + selectors: + message_selector: '.messages' + error_message_selector: '.messages--error' + success_message_selector: '.messages--status' + Bex\Behat\ScreenshotExtension: + screenshot_taking_mode: all_scenarios + image_drivers: + local: + screenshot_directory: '/var/www/html/artifacts/screenshots' diff --git a/tests/src/Behat/example.behat.local.yml b/tests/src/Behat/example.behat.local.yml new file mode 100644 index 00000000..86541ec8 --- /dev/null +++ b/tests/src/Behat/example.behat.local.yml @@ -0,0 +1,31 @@ +# Local Behat configuration file. +# +# See the testing section of the [README.md](README.md) to learn how to use this file. +default: + suites: + default: + contexts: + - ApigeeEdgeFeatureContext + - Drupal\DrupalExtension\Context\DrupalContext + - Drupal\DrupalExtension\Context\MinkContext + - Drupal\DrupalExtension\Context\MessageContext + extensions: + Behat\MinkExtension: + goutte: ~ + selenium2: + wd_host: http://MY-IP-ADDRESS:4444/wd/hub + base_url: http://localhost:8080 + browser_name: 'chrome' + Drupal\DrupalExtension: + blackbox: ~ + api_driver: 'drupal' + drush: + alias: 'local' + drupal: + drupal_root: '/var/www/docroot' + region_map: + footer: "#footer" + selectors: + message_selector: '.messages' + error_message_selector: '.messages.messages--error' + success_message_selector: '.messages.messages--status' diff --git a/tests/src/Behat/features/bootstrap/ApigeeEdgeFeatureContext.php b/tests/src/Behat/features/bootstrap/ApigeeEdgeFeatureContext.php new file mode 100644 index 00000000..3f2cf60e --- /dev/null +++ b/tests/src/Behat/features/bootstrap/ApigeeEdgeFeatureContext.php @@ -0,0 +1,33 @@ +moduleExists('apigee_edge')) { + \Drupal::service('module_installer')->install(['apigee_edge']); + } + + // Also uninstall the inline form errors module for easier testing. + if ($moduleHandler->moduleExists('inline_form_errors')) { + \Drupal::service('module_installer')->uninstall(['inline_form_errors']); + } + } + +} From b0af0469bfc346d71718c1a57b620e44c4825914 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Wed, 5 Feb 2020 13:50:41 -0800 Subject: [PATCH 02/18] CircleCI: adding RoboFile. --- .circleci/RoboFile.php | 398 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 398 insertions(+) create mode 100644 .circleci/RoboFile.php diff --git a/.circleci/RoboFile.php b/.circleci/RoboFile.php new file mode 100644 index 00000000..0286ce32 --- /dev/null +++ b/.circleci/RoboFile.php @@ -0,0 +1,398 @@ +stopOnFail(); + } + + /** + * Files which we don't want to copy into the module directory. + */ + static $excludeFiles = [ + '.', + '..', + 'vendor', + 'RoboFile.php', + '.git', + '.idea', + ]; + + /** + * Set up the Drupal skeleton. + */ + public function setupSkeleton() + { + // composer config doesn't allow us to set arrays, so we have to do this by + // hand. + $config = json_decode(file_get_contents('composer.json')); + $config->require->{"drush/drush"} = "~9.0"; + $config->extra->{"enable-patching"} = 'true'; + $config->extra->{"patches"} = new \stdClass(); + file_put_contents('composer.json', json_encode($config)); + + // Create a directory for our artifacts. + $this->taskFilesystemStack() + ->mkdir('artifacts') + ->mkdir('artifacts/phpunit') + ->mkdir('artifacts/phpcs') + ->mkdir('artifacts/phpmd') + ->run(); + + $this->taskFilesystemStack() + ->chown('artifacts', 'www-data', TRUE) + ->run(); + } + + /** + * Adds coding standard dependencies. + */ + public function addCodingStandardsDeps() + { + $config = json_decode(file_get_contents('composer.json')); + $config->require->{"drupal/coder"} = "^2.0|^8.2"; + file_put_contents('composer.json', json_encode($config)); + } + + /** + * Adds Behat dependencies. + */ + public function addBehatDeps() + { + $config = json_decode(file_get_contents('composer.json')); + $config->require->{"behat/mink-selenium2-driver"} = "^1.3"; + $config->require->{"drupal/drupal-extension"} = "master-dev"; + $config->require->{"drush/drush"} = "~9.0"; + $config->require->{"guzzlehttp/guzzle"} = "^6.0@dev"; + file_put_contents('composer.json', json_encode($config)); + } + + /** + * Adds modules to the merge section. + * + * @param array $modules + * The list of modules. + */ + public function addModules(array $modules) + { + $config = json_decode(file_get_contents('composer.json')); + + foreach ($modules as $module) { + list($module,) = explode(':', $module); + $config->extra->{"merge-plugin"}->include[] = "modules/$module/composer.json"; + $base = isset($config->extra->{"patches"}) ? (array)$config->extra->{"patches"} : []; + $config->extra->{"patches"} = (object)array_merge($base, + (array)$this->getPatches($module)); + } + + file_put_contents('composer.json', json_encode($config)); + } + + /** + * Adds contrib modules to the require section. + * + * @param array $modules + * The list of modules. + */ + public function addContribModules(array $modules) + { + $config = json_decode(file_get_contents('composer.json')); + + foreach ($modules as $module) { + list($module, $version) = explode(':', $module); + $config->require->{"drupal/" . $module} = $version; + } + + file_put_contents('composer.json', json_encode($config)); + } + + /** + * Updates modules. + * + * @param array $modules + * The list of modules. + */ + public function updateModules(array $modules) + { + $config = json_decode(file_get_contents('composer.json')); + + // Rebuild the patches array. + $config->extra->{"patches"} = new \stdClass(); + foreach ($modules as $module) { + list($module,) = explode(':', $module); + $config->extra->{"patches"} = (object)array_merge((array)$config->extra->{"patches"}, + (array)$this->getPatches($module)); + } + + file_put_contents('composer.json', json_encode($config)); + } + + /** + * Updates contrib modules. + * + * @param array $modules + * The list of modules. + */ + public function updateContribModules(array $modules) + { + // The implementation is the same as adding modules but for + // readability we have this alias when updating sites. + $this->addContribModules($modules); + } + + /** + * Updates composer dependencies. + */ + public function updateDependencies() + { + // Disable xdebug. + $this->taskExec('sed -i \'s/^zend_extension/;zend_extension/g\' /usr/local/etc/php/conf.d/xdebug.ini') + ->run(); + + // The git checkout includes a composer.lock, and running composer update + // on it fails for the first time. + $this->taskFilesystemStack()->remove('composer.lock')->run(); + + $this->taskDeleteDir('vendor/behat/mink')->run(); + + // Composer often runs out of memory when installing drupal. + $this->taskComposerUpdate('php -d memory_limit=-1 /usr/local/bin/composer') + ->optimizeAutoloader() + ->run(); + + // Preserve composer.lock as an artifact for future debugging. + $this->taskFilesystemStack() + ->copy('composer.json', 'artifacts/composer.json') + ->copy('composer.lock', 'artifacts/composer.lock') + ->run(); + + // Write drush status results to an artifact file. + $this->taskExec('vendor/bin/drush status > artifacts/core-stats.txt') + ->run(); + $this->taskExec('cat artifacts/core-stats.txt') + ->run(); + + // Add php info to an artifact file. + $this->taskExec('php -i > artifacts/phpinfo.txt') + ->run(); + } + + /** + * Returns an array of patches to apply for a given module. + * + * @param string $module + * The name of the module. + * + * @return \stdClass + * An object containing a list of patches to apply via Composer Patches. + */ + protected function getPatches($module) + { + $path = 'modules/' . $module . '/patches.json'; + if (file_exists($path)) { + return json_decode(file_get_contents($path)); + } else { + return new stdClass(); + } + } + + /** + * Install Drupal. + * + * @param array $opts + * (optional) The array of options. + */ + public function setupDrupal($opts = [ + 'admin-user' => null, + 'admin-password' => null, + 'site-name' => null, + 'db-url' => 'mysql://root@127.0.0.1/drupal8', + ] + ) { + $task = $this->drush() + ->args('site-install') + ->option('yes') + ->option('db-url', $opts['db-url'], '='); + + if ($opts['admin-user']) { + $task->option('account-name', $admin_user, '='); + } + + if ($opts['admin-password']) { + $task->option('account-pass', $admin_password, '='); + } + + if ($opts['site-name']) { + $task->option('site-name', $site_name, '='); + } + + // Sending email will fail, so we need to allow this to always pass. + $this->stopOnFail(false); + $task->run(); + $this->stopOnFail(); + } + + /** + * Return drush with default arguments. + * + * @return \Robo\Task\Base\Exec + * A drush exec command. + */ + protected function drush() + { + // Drush needs an absolute path to the docroot. + $docroot = $this->getDocroot(); + return $this->taskExec('vendor/bin/drush') + ->option('root', $docroot, '='); + } + + /** + * Get the absolute path to the docroot. + * + * @return string + */ + protected function getDocroot() + { + $docroot = (getcwd()); + return $docroot; + } + + /** + * Overrides phpunit's configuration with module specific one. + * + * @param string $module + * The module name where phpunit config files may be located. + */ + public function overridePhpunitConfig($module) + { + $module_path = "modules/$module"; + // Copy in our custom phpunit.xml.core.dist file. + if (file_exists("$module_path/phpunit.core.xml")) { + $this->taskFilesystemStack() + ->copy("$module_path/phpunit.core.xml", 'core/phpunit.xml') + ->run(); + } elseif (file_exists("$module_path/phpunit.core.xml.dist")) { + $this->taskFilesystemStack() + ->copy("$module_path/phpunit.core.xml.dist", 'core/phpunit.xml') + ->run(); + } + } + + /** + * Run PHPUnit and simpletests for the module. + * + * @param string $module + * The module name. + */ + public function test($module) + { + $this->phpUnit($module) + ->run(); + } + + /** + * Run tests with code coverage reports. + * + * @param string $module + * The module name. + * @param string $report_output_path + * The full path of the report to generate. + */ + public function testCoverage($module, $report_output_path) + { + $this->phpUnit($module) + ->option('coverage-xml', $report_output_path . '/coverage-xml') + ->option('coverage-html', $report_output_path . '/coverage-html') + ->option('testsuite', 'nonfunctional') + ->run(); + } + + /** + * Return a configured phpunit task. + * + * This will check for PHPUnit configuration first in the module directory. + * If no configuration is found, it will fall back to Drupal's core + * directory. + * + * @param string $module + * The module name. + * + * @return \Robo\Task\Testing\PHPUnit + */ + private function phpUnit($module) + { + return $this->taskPhpUnit('vendor/bin/phpunit') + ->option('verbose') + ->option('debug') + ->configFile('core') + ->group($module); + } + + /** + * Gathers coding standard statistics from a module. + * + * @param string $path + * Path were cs.json and cs-practice.json files have been stored + * by the container where phpcs was executed. + * + * @return string + * A short string with the total violations. + */ + public function extractCodingStandardsStats($path) + { + $errors = 0; + $warnings = 0; + + if (file_exists($path . '/cs.json')) { + $stats = json_decode(file_get_contents($path . '/cs.json')); + $errors += $stats->totals->errors; + $warnings += $stats->totals->warnings; + } + + return $errors . ' errors and ' . $warnings . ' warnings.'; + } + + /** + * Gathers code coverage stats from a module. + * + * @param string $path + * Path to a Clover report file. + * + * @return string + * A short string with the coverage percentage. + */ + public function extractCoverageStats($path) + { + if (file_exists($path . '/index.xml')) { + $data = file_get_contents($path . '/index.xml'); + $xml = simplexml_load_string($data); + $totals = $xml->project->directory->totals; + $lines = (string)$totals->lines['percent']; + $methods = (string)$totals->methods['percent']; + $classes = (string)$totals->classes['percent']; + return 'Lines ' . $lines . ' Methods ' . $methods . ' Classes ' . $classes; + } else { + return 'Clover report was not found at ' . $path; + } + } + +} From 40a6ceaf204e3a299beaa6ea5f3c70a70dcdecac Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Wed, 5 Feb 2020 14:22:12 -0800 Subject: [PATCH 03/18] CircleCI: updates to config, removing behat step. --- .circleci/config.yml | 35 ++++------------- .circleci/update-dependencies.sh | 13 +++++++ tests/src/Behat/behat.yml | 38 ------------------- tests/src/Behat/example.behat.local.yml | 31 --------------- .../bootstrap/ApigeeEdgeFeatureContext.php | 33 ---------------- 5 files changed, 20 insertions(+), 130 deletions(-) create mode 100644 .circleci/update-dependencies.sh delete mode 100644 tests/src/Behat/behat.yml delete mode 100644 tests/src/Behat/example.behat.local.yml delete mode 100644 tests/src/Behat/features/bootstrap/ApigeeEdgeFeatureContext.php diff --git a/.circleci/config.yml b/.circleci/config.yml index 4f7b9fe9..cf8ba1ce 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -63,7 +63,8 @@ update_dependencies: &update_dependencies - run: working_directory: /var/www/html command: | - ./update-dependencies.sh $CIRCLE_PROJECT_REPONAME + cp ./modules/apigee_edge/.circleci/update-dependencies.sh /var/www/html + ./update-dependencies.sh apigee_edge - save_cache: *save_cache @@ -85,7 +86,7 @@ unit_kernel_tests: &unit_kernel_tests - run: working_directory: /var/www/html command: | - ./test.sh $CIRCLE_PROJECT_REPONAME + ./test.sh apigee_edge - store_test_results: path: /var/www/html/artifacts/phpunit @@ -105,7 +106,7 @@ functional_tests: &functional_tests - run: working_directory: /var/www/html command: | - ./test-functional.sh $CIRCLE_PROJECT_REPONAME + ./test-functional.sh apigee_edge - store_test_results: path: /var/www/html/artifacts/phpunit @@ -125,30 +126,13 @@ functional_js_tests: &functional_js_tests - run: working_directory: /var/www/html command: | - ./test-functional-js.sh $CIRCLE_PROJECT_REPONAME + ./test-functional-js.sh apigee_edge - store_test_results: path: /var/www/html/artifacts/phpunit - store_artifacts: path: /var/www/html/artifacts -# Run Behat tests. This command invokes the behat.sh hook. -behat_tests: &behat_tests - <<: *defaults - steps: - - attach_workspace: - at: /var/www/html - - - checkout - - - run: - working_directory: /var/www/html - command: | - ./behat.sh $CIRCLE_PROJECT_REPONAME - - - store_artifacts: - path: /var/www/html/artifacts - # Run code quality tests. This invokes code-sniffer.sh. code_sniffer: &code_sniffer <<: *defaults @@ -161,7 +145,7 @@ code_sniffer: &code_sniffer - run: working_directory: /var/www/html command: | - ./code-sniffer.sh $CIRCLE_PROJECT_REPONAME + ./code-sniffer.sh apigee_edge - store_test_results: path: /var/www/html/artifacts/phpcs @@ -180,7 +164,7 @@ code_coverage: &code_coverage - run: working_directory: /var/www/html command: | - ./code-coverage-stats.sh $CIRCLE_PROJECT_REPONAME + ./code-coverage-stats.sh apigee_edge - store_artifacts: path: /var/www/html/artifacts @@ -195,8 +179,6 @@ jobs: <<: *functional_tests run-functional-js-tests: <<: *functional_js_tests - run-behat-tests: - <<: *behat_tests run-code-sniffer: <<: *code_sniffer run-code-coverage: @@ -218,9 +200,6 @@ workflows: - run-functional-js-tests: requires: - update-dependencies - - run-behat-tests: - requires: - - update-dependencies - run-code-sniffer: requires: - update-dependencies diff --git a/.circleci/update-dependencies.sh b/.circleci/update-dependencies.sh new file mode 100644 index 00000000..1e8e71b6 --- /dev/null +++ b/.circleci/update-dependencies.sh @@ -0,0 +1,13 @@ +#!/bin/bash -ex + +# Make sure the robofile is in the correct location. +cp modules/apigee_edge/.circleci/RoboFile.php ./ + +robo setup:skeleton +robo add:modules $1 +robo update:dependencies + +# Touch a flag so we know dependencies have been set. Otherwise, there is no +# easy way to know this step needs to be done when running circleci locally since +# it does not support workflows. +touch dependencies_updated diff --git a/tests/src/Behat/behat.yml b/tests/src/Behat/behat.yml deleted file mode 100644 index 7e6ff21f..00000000 --- a/tests/src/Behat/behat.yml +++ /dev/null @@ -1,38 +0,0 @@ -default: - suites: - default: - contexts: - - ApigeeEdgeFeatureContext - - Drupal\DrupalExtension\Context\DrupalContext - - Drupal\DrupalExtension\Context\MinkContext - - Drupal\DrupalExtension\Context\MessageContext - extensions: - Behat\MinkExtension: - goutte: ~ - selenium2: ~ - base_url: http://localhost - sessions: - default: - goutte: ~ - javascript: - selenium2: - browser: chrome - wd_host: http://localhost:4444/wd/hub - Drupal\DrupalExtension: - blackbox: ~ - api_driver: 'drupal' - drush: - alias: 'local' - drupal: - drupal_root: '/var/www/html' - region_map: - footer: "#footer" - selectors: - message_selector: '.messages' - error_message_selector: '.messages--error' - success_message_selector: '.messages--status' - Bex\Behat\ScreenshotExtension: - screenshot_taking_mode: all_scenarios - image_drivers: - local: - screenshot_directory: '/var/www/html/artifacts/screenshots' diff --git a/tests/src/Behat/example.behat.local.yml b/tests/src/Behat/example.behat.local.yml deleted file mode 100644 index 86541ec8..00000000 --- a/tests/src/Behat/example.behat.local.yml +++ /dev/null @@ -1,31 +0,0 @@ -# Local Behat configuration file. -# -# See the testing section of the [README.md](README.md) to learn how to use this file. -default: - suites: - default: - contexts: - - ApigeeEdgeFeatureContext - - Drupal\DrupalExtension\Context\DrupalContext - - Drupal\DrupalExtension\Context\MinkContext - - Drupal\DrupalExtension\Context\MessageContext - extensions: - Behat\MinkExtension: - goutte: ~ - selenium2: - wd_host: http://MY-IP-ADDRESS:4444/wd/hub - base_url: http://localhost:8080 - browser_name: 'chrome' - Drupal\DrupalExtension: - blackbox: ~ - api_driver: 'drupal' - drush: - alias: 'local' - drupal: - drupal_root: '/var/www/docroot' - region_map: - footer: "#footer" - selectors: - message_selector: '.messages' - error_message_selector: '.messages.messages--error' - success_message_selector: '.messages.messages--status' diff --git a/tests/src/Behat/features/bootstrap/ApigeeEdgeFeatureContext.php b/tests/src/Behat/features/bootstrap/ApigeeEdgeFeatureContext.php deleted file mode 100644 index 3f2cf60e..00000000 --- a/tests/src/Behat/features/bootstrap/ApigeeEdgeFeatureContext.php +++ /dev/null @@ -1,33 +0,0 @@ -moduleExists('apigee_edge')) { - \Drupal::service('module_installer')->install(['apigee_edge']); - } - - // Also uninstall the inline form errors module for easier testing. - if ($moduleHandler->moduleExists('inline_form_errors')) { - \Drupal::service('module_installer')->uninstall(['inline_form_errors']); - } - } - -} From fa5e0a33cf8ed860ef1ff0bce67abe90b0c066d5 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Wed, 5 Feb 2020 14:45:34 -0800 Subject: [PATCH 04/18] CircleCI: temporarily disabling functional tests. --- .circleci/config.yml | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index cf8ba1ce..b590b9cb 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -73,6 +73,9 @@ update_dependencies: &update_dependencies paths: - . + - store_artifacts: + path: /var/www/html/artifacts + # Run Drupal unit and kernel tests as one job. This command invokes the test.sh # hook. unit_kernel_tests: &unit_kernel_tests @@ -194,12 +197,12 @@ workflows: - run-unit-kernel-tests: requires: - update-dependencies - - run-functional-tests: - requires: - - update-dependencies - - run-functional-js-tests: - requires: - - update-dependencies +# - run-functional-tests: +# requires: +# - update-dependencies +# - run-functional-js-tests: +# requires: +# - update-dependencies - run-code-sniffer: requires: - update-dependencies From 84f8a6be85b9fe4bda3635e16b1e3a0c4806d948 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Wed, 5 Feb 2020 15:22:54 -0800 Subject: [PATCH 05/18] CircleCI: updates. --- .circleci/RoboFile.php | 28 ++++++++++++++++++++++++++++ .circleci/update-dependencies.sh | 1 + 2 files changed, 29 insertions(+) diff --git a/.circleci/RoboFile.php b/.circleci/RoboFile.php index 0286ce32..c7475215 100644 --- a/.circleci/RoboFile.php +++ b/.circleci/RoboFile.php @@ -395,4 +395,32 @@ public function extractCoverageStats($path) } } + /** + * Adds modules to the merge section. + */ + public function configureModuleDependencies() + { + $config = json_decode(file_get_contents('composer.json')); + + // The Drupal core image might be updated. Request the newest stable. + $config->require->{"drupal/core"} = "~8.8"; + $config->require->{"drupal/core-recommended"} = "~8.8"; + + // If you require core, you must not replace it. + unset($config->replace); + + // You can't merge from a package that is required. + foreach ($config->extra->{"merge-plugin"}->include as $index => $merge_entry) { + if ($merge_entry === 'core/composer.json') { + unset($config->extra->{"merge-plugin"}->include[$index]); + } + } + $config->extra->{"merge-plugin"}->include = array_values($config->extra->{"merge-plugin"}->include); + + // Add dependencies for phpunit tests. + $config->require->{"drupal/core-dev"} = "~8.8"; + + file_put_contents('composer.json', json_encode($config, JSON_PRETTY_PRINT)); + } + } diff --git a/.circleci/update-dependencies.sh b/.circleci/update-dependencies.sh index 1e8e71b6..41b46e9b 100644 --- a/.circleci/update-dependencies.sh +++ b/.circleci/update-dependencies.sh @@ -5,6 +5,7 @@ cp modules/apigee_edge/.circleci/RoboFile.php ./ robo setup:skeleton robo add:modules $1 +robo configure:module-dependencies robo update:dependencies # Touch a flag so we know dependencies have been set. Otherwise, there is no From 0f2c8713e1f72952c963a1c3a98a09ab6ec25d15 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Wed, 5 Feb 2020 15:28:52 -0800 Subject: [PATCH 06/18] CircleCI: updates. --- .circleci/RoboFile.php | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.circleci/RoboFile.php b/.circleci/RoboFile.php index c7475215..3cbb1e2d 100644 --- a/.circleci/RoboFile.php +++ b/.circleci/RoboFile.php @@ -194,6 +194,10 @@ public function updateDependencies() // Add php info to an artifact file. $this->taskExec('php -i > artifacts/phpinfo.txt') ->run(); + + // Add composer version info to an artifact file. + $this->taskExec('composer show > artifacts/composer-show.txt') + ->run(); } /** From 5c9fd2b93ccdd09fa4bde36b6c9d3d8bce0d8bb5 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Mon, 10 Feb 2020 11:02:07 -0800 Subject: [PATCH 07/18] CircleCI: updates. --- phpcs.xml.dist | 10 ++++++++++ phpunit.core.xml.dist | 8 ++++++++ 2 files changed, 18 insertions(+) diff --git a/phpcs.xml.dist b/phpcs.xml.dist index b51537c9..8b6666b1 100644 --- a/phpcs.xml.dist +++ b/phpcs.xml.dist @@ -18,5 +18,15 @@ 0 + + + 0 + + + 0 + diff --git a/phpunit.core.xml.dist b/phpunit.core.xml.dist index 3a3ad061..6e04d278 100644 --- a/phpunit.core.xml.dist +++ b/phpunit.core.xml.dist @@ -35,6 +35,14 @@ + + + + + + + + From 854a55e5337892193c578d9c53b47999a2ef4aa2 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Mon, 10 Feb 2020 14:14:46 -0800 Subject: [PATCH 08/18] CircleCI: updates. --- .circleci/RoboFile.php | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/.circleci/RoboFile.php b/.circleci/RoboFile.php index 3cbb1e2d..271df2fd 100644 --- a/.circleci/RoboFile.php +++ b/.circleci/RoboFile.php @@ -347,6 +347,7 @@ private function phpUnit($module) return $this->taskPhpUnit('vendor/bin/phpunit') ->option('verbose') ->option('debug') + ->option('log-junit', '/var/www/html/artifacts/phpunit/phpunit.xml') ->configFile('core') ->group($module); } @@ -406,10 +407,14 @@ public function configureModuleDependencies() { $config = json_decode(file_get_contents('composer.json')); - // The Drupal core image might be updated. Request the newest stable. + // The Drupal core image might need updating. Request the newest stable. $config->require->{"drupal/core"} = "~8.8"; $config->require->{"drupal/core-recommended"} = "~8.8"; + // We require Drupal console and drush for some tests. + $config->require->{"drupal/console"} = "~1.0"; + $config->require->{"drush/drush"} = "^9.7"; + // If you require core, you must not replace it. unset($config->replace); From cd1eadccd37d7a004d43c6e36d449f480c6b9446 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Tue, 11 Feb 2020 11:16:18 -0800 Subject: [PATCH 09/18] CircleCI: running code sniffer from our standard. --- .circleci/code-sniffer.sh | 14 ++++++++++++++ .circleci/config.yml | 1 + 2 files changed, 15 insertions(+) create mode 100644 .circleci/code-sniffer.sh diff --git a/.circleci/code-sniffer.sh b/.circleci/code-sniffer.sh new file mode 100644 index 00000000..caa26dcf --- /dev/null +++ b/.circleci/code-sniffer.sh @@ -0,0 +1,14 @@ +#!/bin/bash -ex + +# Runs CodeSniffer checks on a Drupal module. + +if [ ! -f dependencies_updated ] +then + ./update-dependencies.sh $1 +fi + +# Install dependencies and configure phpcs +vendor/bin/phpcs --config-set installed_paths vendor/drupal/coder/coder_sniffer + +# Check coding standards +vendor/bin/phpcs -p -s -n --colors --standard=modules/apigee_edge/phpcs.xml.dist --report=junit --report-junit=artifacts/phpcs/phpcs.xml modules/$1 diff --git a/.circleci/config.yml b/.circleci/config.yml index b590b9cb..4bdec694 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -148,6 +148,7 @@ code_sniffer: &code_sniffer - run: working_directory: /var/www/html command: | + cp ./modules/apigee_edge/.circleci/code-sniffer.sh /var/www/html ./code-sniffer.sh apigee_edge - store_test_results: From b3b3065000d084665d48f1a01f9c6b7d864f7f4e Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Tue, 11 Feb 2020 13:04:40 -0800 Subject: [PATCH 10/18] CircleCI: updates, re-enabling functional tests. --- .circleci/config.yml | 12 ++++++------ composer.json | 3 ++- phpunit.core.xml.dist | 1 + 3 files changed, 9 insertions(+), 7 deletions(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index 4bdec694..2824290d 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -198,12 +198,12 @@ workflows: - run-unit-kernel-tests: requires: - update-dependencies -# - run-functional-tests: -# requires: -# - update-dependencies -# - run-functional-js-tests: -# requires: -# - update-dependencies + - run-functional-tests: + requires: + - update-dependencies + - run-functional-js-tests: + requires: + - update-dependencies - run-code-sniffer: requires: - update-dependencies diff --git a/composer.json b/composer.json index 5c7d444f..0ed3fe76 100644 --- a/composer.json +++ b/composer.json @@ -24,7 +24,8 @@ "drush/drush": "^9.0", "phpmd/phpmd": "^2.8", "phpmetrics/phpmetrics": "^2.5", - "phpunit/phpunit": "^6.5" + "phpunit/phpunit": "^6.5", + "drupal/console": "~1.0" }, "config": { "sort-packages": true diff --git a/phpunit.core.xml.dist b/phpunit.core.xml.dist index 6e04d278..f01c49f4 100644 --- a/phpunit.core.xml.dist +++ b/phpunit.core.xml.dist @@ -43,6 +43,7 @@ + From 71c3022cd9a0d1d140a3f10510a40adf623c75f5 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Tue, 11 Feb 2020 13:37:47 -0800 Subject: [PATCH 11/18] CircleCI: fixing artifacts permissions issue. --- .circleci/RoboFile.php | 24 ++++++++++++------------ .circleci/code-coverage-stats.sh | 15 +++++++++++++++ .circleci/code-sniffer.sh | 2 +- .circleci/config.yml | 21 +++++++++++---------- .circleci/test-functional-js.sh | 20 ++++++++++++++++++++ .circleci/test-functional.sh | 19 +++++++++++++++++++ .circleci/test.sh | 19 +++++++++++++++++++ 7 files changed, 97 insertions(+), 23 deletions(-) create mode 100644 .circleci/code-coverage-stats.sh create mode 100644 .circleci/test-functional-js.sh create mode 100644 .circleci/test-functional.sh create mode 100644 .circleci/test.sh diff --git a/.circleci/RoboFile.php b/.circleci/RoboFile.php index 271df2fd..77de5e04 100644 --- a/.circleci/RoboFile.php +++ b/.circleci/RoboFile.php @@ -52,14 +52,14 @@ public function setupSkeleton() // Create a directory for our artifacts. $this->taskFilesystemStack() - ->mkdir('artifacts') - ->mkdir('artifacts/phpunit') - ->mkdir('artifacts/phpcs') - ->mkdir('artifacts/phpmd') + ->mkdir('/tmp/artifacts') + ->mkdir('/tmp/artifacts/phpunit') + ->mkdir('/tmp/artifacts/phpcs') + ->mkdir('/tmp/artifacts/phpmd') ->run(); $this->taskFilesystemStack() - ->chown('artifacts', 'www-data', TRUE) + ->chown('/tmp/artifacts', 'www-data', TRUE) ->run(); } @@ -181,22 +181,22 @@ public function updateDependencies() // Preserve composer.lock as an artifact for future debugging. $this->taskFilesystemStack() - ->copy('composer.json', 'artifacts/composer.json') - ->copy('composer.lock', 'artifacts/composer.lock') + ->copy('composer.json', '/tmp/artifacts/composer.json') + ->copy('composer.lock', '/tmp/artifacts/composer.lock') ->run(); // Write drush status results to an artifact file. - $this->taskExec('vendor/bin/drush status > artifacts/core-stats.txt') + $this->taskExec('vendor/bin/drush status > /tmp/artifacts/core-stats.txt') ->run(); - $this->taskExec('cat artifacts/core-stats.txt') + $this->taskExec('cat /tmp/artifacts/core-stats.txt') ->run(); // Add php info to an artifact file. - $this->taskExec('php -i > artifacts/phpinfo.txt') + $this->taskExec('php -i > /tmp/artifacts/phpinfo.txt') ->run(); // Add composer version info to an artifact file. - $this->taskExec('composer show > artifacts/composer-show.txt') + $this->taskExec('composer show > /tmp/artifacts/composer-show.txt') ->run(); } @@ -347,7 +347,7 @@ private function phpUnit($module) return $this->taskPhpUnit('vendor/bin/phpunit') ->option('verbose') ->option('debug') - ->option('log-junit', '/var/www/html/artifacts/phpunit/phpunit.xml') + ->option('log-junit', '/tmp/artifacts/phpunit/phpunit.xml') ->configFile('core') ->group($module); } diff --git a/.circleci/code-coverage-stats.sh b/.circleci/code-coverage-stats.sh new file mode 100644 index 00000000..d8fdbd59 --- /dev/null +++ b/.circleci/code-coverage-stats.sh @@ -0,0 +1,15 @@ +#!/bin/bash -ex + +export SIMPLETEST_BASE_URL="http://localhost" +export SIMPLETEST_DB="sqlite://localhost//tmp/drupal.sqlite" +export BROWSERTEST_OUTPUT_DIRECTORY="/var/www/html/sites/simpletest" + +if [ ! -f dependencies_updated ] +then + ./update-dependencies.sh $1 +fi + +robo override:phpunit-config $1 + +timeout 60m sudo -E -u www-data robo test:coverage $1 /tmp/artifacts || true +tar czf /tmp/artifacts/coverage.tar.gz -C /tmp/artifacts coverage-html coverage-xml diff --git a/.circleci/code-sniffer.sh b/.circleci/code-sniffer.sh index caa26dcf..d07dc002 100644 --- a/.circleci/code-sniffer.sh +++ b/.circleci/code-sniffer.sh @@ -11,4 +11,4 @@ fi vendor/bin/phpcs --config-set installed_paths vendor/drupal/coder/coder_sniffer # Check coding standards -vendor/bin/phpcs -p -s -n --colors --standard=modules/apigee_edge/phpcs.xml.dist --report=junit --report-junit=artifacts/phpcs/phpcs.xml modules/$1 +vendor/bin/phpcs -p -s -n --colors --standard=modules/apigee_edge/phpcs.xml.dist --report=junit --report-junit=/tmp/artifacts/phpcs/phpcs.xml modules/$1 diff --git a/.circleci/config.yml b/.circleci/config.yml index 2824290d..e50d9b63 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -74,7 +74,7 @@ update_dependencies: &update_dependencies - . - store_artifacts: - path: /var/www/html/artifacts + path: /tmp/artifacts # Run Drupal unit and kernel tests as one job. This command invokes the test.sh # hook. @@ -89,12 +89,13 @@ unit_kernel_tests: &unit_kernel_tests - run: working_directory: /var/www/html command: | + cp ./modules/apigee_edge/.circleci/test.sh /var/www/html ./test.sh apigee_edge - store_test_results: - path: /var/www/html/artifacts/phpunit + path: /tmp/artifacts/phpunit - store_artifacts: - path: /var/www/html/artifacts + path: /tmp/artifacts # Run Drupal functional tests. This command invokes the test-functional.sh # hook. @@ -112,9 +113,9 @@ functional_tests: &functional_tests ./test-functional.sh apigee_edge - store_test_results: - path: /var/www/html/artifacts/phpunit + path: /tmp/artifacts/phpunit - store_artifacts: - path: /var/www/html/artifacts + path: /tmp/artifacts # Run Drupal functional tests. This command invokes the test-functional-js.sh # hook. @@ -132,9 +133,9 @@ functional_js_tests: &functional_js_tests ./test-functional-js.sh apigee_edge - store_test_results: - path: /var/www/html/artifacts/phpunit + path: /tmp/artifacts/phpunit - store_artifacts: - path: /var/www/html/artifacts + path: /tmp/artifacts # Run code quality tests. This invokes code-sniffer.sh. code_sniffer: &code_sniffer @@ -152,9 +153,9 @@ code_sniffer: &code_sniffer ./code-sniffer.sh apigee_edge - store_test_results: - path: /var/www/html/artifacts/phpcs + path: /tmp/artifacts/phpcs - store_artifacts: - path: /var/www/html/artifacts + path: /tmp/artifacts # Run code coverage tests. This invokes code-coverage-stats.sh. code_coverage: &code_coverage @@ -170,7 +171,7 @@ code_coverage: &code_coverage command: | ./code-coverage-stats.sh apigee_edge - store_artifacts: - path: /var/www/html/artifacts + path: /tmp/artifacts # Declare all of the jobs we should run. version: 2 diff --git a/.circleci/test-functional-js.sh b/.circleci/test-functional-js.sh new file mode 100644 index 00000000..1a5175a7 --- /dev/null +++ b/.circleci/test-functional-js.sh @@ -0,0 +1,20 @@ +#!/bin/bash -ex + +# CI test-functional-js.sh hook implementation. + +export SIMPLETEST_BASE_URL="http://localhost" +export SIMPLETEST_DB="sqlite://localhost//tmp/drupal.sqlite" +export BROWSERTEST_OUTPUT_DIRECTORY="/var/www/html/sites/simpletest" +export MINK_DRIVER_ARGS_WEBDRIVER='["chrome", null, "http://localhost:4444/wd/hub"]' + +if [ ! -f dependencies_updated ] +then + ./update-dependencies.sh $1 +fi + +# This is the command used by the base image to serve Drupal. +apache2-foreground& + +robo override:phpunit-config $1 + +sudo -E -u www-data vendor/bin/phpunit -c core --group $1 --testsuite functional-javascript --debug --verbose --log-junit /tmp/artifacts/phpunit/phpunit.xml diff --git a/.circleci/test-functional.sh b/.circleci/test-functional.sh new file mode 100644 index 00000000..9f3d4f18 --- /dev/null +++ b/.circleci/test-functional.sh @@ -0,0 +1,19 @@ +#!/bin/bash -ex + +# CI test-functional.sh hook implementation. + +export SIMPLETEST_BASE_URL="http://localhost" +export SIMPLETEST_DB="sqlite://localhost//tmp/drupal.sqlite" +export BROWSERTEST_OUTPUT_DIRECTORY="/var/www/html/sites/simpletest" + +if [ ! -f dependencies_updated ] +then + ./update-dependencies.sh $1 +fi + +# This is the command used by the base image to serve Drupal. +apache2-foreground& + +robo override:phpunit-config $1 + +sudo -E -u www-data vendor/bin/phpunit -c core --group $1 --testsuite functional --debug --verbose --log-junit /tmp/artifacts/phpunit/phpunit.xml diff --git a/.circleci/test.sh b/.circleci/test.sh new file mode 100644 index 00000000..c593bd08 --- /dev/null +++ b/.circleci/test.sh @@ -0,0 +1,19 @@ +#!/bin/bash -ex + +# CI test.sh hook implementation. + +export SIMPLETEST_BASE_URL="http://localhost" +export SIMPLETEST_DB="sqlite://localhost//tmp/drupal.sqlite" +export BROWSERTEST_OUTPUT_DIRECTORY="/var/www/html/sites/simpletest" + +if [ ! -f dependencies_updated ] +then + ./update-dependencies.sh $1 +fi + +# This is the command used by the base image to serve Drupal. +apache2-foreground& + +robo override:phpunit-config $1 + +sudo -E -u www-data vendor/bin/phpunit -c core --group $1 --testsuite unit,kernel --debug --verbose --log-junit /tmp/artifacts/phpunit/phpunit.xml From b11d382b01e7874d00eaaa882e382b192deb69c1 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Tue, 11 Feb 2020 14:02:20 -0800 Subject: [PATCH 12/18] CircleCI: fixing artifacts permissions issue. --- .circleci/README.md | 4 ++++ .circleci/RoboFile.php | 4 ++-- .circleci/code-coverage-stats.sh | 2 +- .circleci/code-sniffer.sh | 2 +- .circleci/config.yml | 6 +++--- 5 files changed, 11 insertions(+), 7 deletions(-) create mode 100644 .circleci/README.md diff --git a/.circleci/README.md b/.circleci/README.md new file mode 100644 index 00000000..0a7f24a5 --- /dev/null +++ b/.circleci/README.md @@ -0,0 +1,4 @@ +# Continuous Integration + +Continuous integration for this module has been set up in CircleCI using +[deviantintegral/drupal_tests](https://github.com/deviantintegral/drupal_tests) as as a base. diff --git a/.circleci/RoboFile.php b/.circleci/RoboFile.php index 77de5e04..0f8bf68c 100644 --- a/.circleci/RoboFile.php +++ b/.circleci/RoboFile.php @@ -52,9 +52,9 @@ public function setupSkeleton() // Create a directory for our artifacts. $this->taskFilesystemStack() - ->mkdir('/tmp/artifacts') + ->mkdir('artifacts') + ->mkdir('artifacts/phpcs') ->mkdir('/tmp/artifacts/phpunit') - ->mkdir('/tmp/artifacts/phpcs') ->mkdir('/tmp/artifacts/phpmd') ->run(); diff --git a/.circleci/code-coverage-stats.sh b/.circleci/code-coverage-stats.sh index d8fdbd59..e456b7c1 100644 --- a/.circleci/code-coverage-stats.sh +++ b/.circleci/code-coverage-stats.sh @@ -12,4 +12,4 @@ fi robo override:phpunit-config $1 timeout 60m sudo -E -u www-data robo test:coverage $1 /tmp/artifacts || true -tar czf /tmp/artifacts/coverage.tar.gz -C /tmp/artifacts coverage-html coverage-xml +tar czf artifacts/coverage.tar.gz -C artifacts coverage-html coverage-xml diff --git a/.circleci/code-sniffer.sh b/.circleci/code-sniffer.sh index d07dc002..caa26dcf 100644 --- a/.circleci/code-sniffer.sh +++ b/.circleci/code-sniffer.sh @@ -11,4 +11,4 @@ fi vendor/bin/phpcs --config-set installed_paths vendor/drupal/coder/coder_sniffer # Check coding standards -vendor/bin/phpcs -p -s -n --colors --standard=modules/apigee_edge/phpcs.xml.dist --report=junit --report-junit=/tmp/artifacts/phpcs/phpcs.xml modules/$1 +vendor/bin/phpcs -p -s -n --colors --standard=modules/apigee_edge/phpcs.xml.dist --report=junit --report-junit=artifacts/phpcs/phpcs.xml modules/$1 diff --git a/.circleci/config.yml b/.circleci/config.yml index e50d9b63..ac07448a 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -153,9 +153,9 @@ code_sniffer: &code_sniffer ./code-sniffer.sh apigee_edge - store_test_results: - path: /tmp/artifacts/phpcs + path: /var/www/html/artifacts/phpcs - store_artifacts: - path: /tmp/artifacts + path: /var/www/html/artifacts # Run code coverage tests. This invokes code-coverage-stats.sh. code_coverage: &code_coverage @@ -171,7 +171,7 @@ code_coverage: &code_coverage command: | ./code-coverage-stats.sh apigee_edge - store_artifacts: - path: /tmp/artifacts + path: /var/www/html/artifacts # Declare all of the jobs we should run. version: 2 From d2528affdac443862d21c0585f1da6a7c2a2747c Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Tue, 11 Feb 2020 14:10:14 -0800 Subject: [PATCH 13/18] CircleCI: fixing artifacts permissions issue. --- .circleci/config.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.circleci/config.yml b/.circleci/config.yml index ac07448a..8d0935db 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -110,6 +110,7 @@ functional_tests: &functional_tests - run: working_directory: /var/www/html command: | + cp ./modules/apigee_edge/.circleci/test-functional.sh /var/www/html ./test-functional.sh apigee_edge - store_test_results: @@ -130,6 +131,7 @@ functional_js_tests: &functional_js_tests - run: working_directory: /var/www/html command: | + cp ./modules/apigee_edge/.circleci/test-functional-js.sh /var/www/html ./test-functional-js.sh apigee_edge - store_test_results: From 9ccc93cf5aac8166e95612982cd5ac8971076425 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Fri, 14 Feb 2020 00:15:51 -0800 Subject: [PATCH 14/18] CircleCI: only run code sniffer and code coverage reports for now. --- .circleci/config.yml | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index 8d0935db..8e5f7a56 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -198,19 +198,19 @@ workflows: test_and_lint: jobs: - update-dependencies - - run-unit-kernel-tests: - requires: - - update-dependencies - - run-functional-tests: - requires: - - update-dependencies - - run-functional-js-tests: - requires: - - update-dependencies +# - run-unit-kernel-tests: +# requires: +# - update-dependencies +# - run-functional-tests: +# requires: +# - update-dependencies +# - run-functional-js-tests: +# requires: +# - update-dependencies - run-code-sniffer: requires: - update-dependencies - - run-code-coverage: - requires: - - update-dependencies - - run-unit-kernel-tests +# - run-code-coverage: +# requires: +# - update-dependencies +# - run-unit-kernel-tests From ac2dce7b98886c1dcd57375ba90188efed4453e0 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Fri, 14 Feb 2020 00:16:09 -0800 Subject: [PATCH 15/18] CircleCI: remote .travis directory. --- .travis/.env | 1 - .travis/Dockerfile | 10 --- .travis/composer.json | 60 --------------- .travis/docker-compose.override.yml | 37 ---------- .travis/docker-compose.yml | 62 ---------------- .travis/prepare-test-env.sh | 109 ---------------------------- .travis/push-logs.sh | 23 ------ .travis/run-test.sh | 29 -------- 8 files changed, 331 deletions(-) delete mode 100644 .travis/.env delete mode 100644 .travis/Dockerfile delete mode 100644 .travis/composer.json delete mode 100644 .travis/docker-compose.override.yml delete mode 100644 .travis/docker-compose.yml delete mode 100755 .travis/prepare-test-env.sh delete mode 100755 .travis/push-logs.sh delete mode 100755 .travis/run-test.sh diff --git a/.travis/.env b/.travis/.env deleted file mode 100644 index fbf99e39..00000000 --- a/.travis/.env +++ /dev/null @@ -1 +0,0 @@ -COMPOSE_PROJECT_NAME=apigee_edge_module_tests diff --git a/.travis/Dockerfile b/.travis/Dockerfile deleted file mode 100644 index bc65b611..00000000 --- a/.travis/Dockerfile +++ /dev/null @@ -1,10 +0,0 @@ -ARG PHP_IMAGE="wodby/drupal-php:7.1-dev-4.5.0" - -FROM ${PHP_IMAGE} - -COPY --chown=wodby:www-data . /opt/drupal-module - -USER wodby - -RUN composer global require --no-suggest dealerdirect/phpcodesniffer-composer-installer \ - drupal/coder diff --git a/.travis/composer.json b/.travis/composer.json deleted file mode 100644 index 4c5962f0..00000000 --- a/.travis/composer.json +++ /dev/null @@ -1,60 +0,0 @@ -{ - "name": "drupal/apigee_edge_travis", - "license": "GPL-2.0", - "type": "project", - "description": "Builds a test environment for the Apigee Edge module.", - "require": { - "php": ">=7.1", - "composer/installers": "^1.6", - "drupal-composer/drupal-scaffold": "^2.5.4", - "wikimedia/composer-merge-plugin": "dev-capture-input-options", - "zaporylie/composer-drupal-optimizations": "^1.0", - "drupal/console": "~1.0", - "drush/drush": "^9.7" - }, - "repositories": [ - { - "type": "composer", - "url": "https://packages.drupal.org/8" - }, - { - "type": "vcs", - "_comment1": "We have to install it from here until this PR is open: https://github.com/wikimedia/composer-merge-plugin/pull/169.", - "url": "https://github.com/mxr576/composer-merge-plugin", - "no-api": true - } - ], - "config": { - "sort-packages": true, - "optimize-autoloader": true, - "_comment1": "PHP API Client patches that modifies tests files only apply if it is installed from source.", - "preferred-install": { - "*": "dist", - "apigee/apigee-client-php": "source" - } - }, - "minimum-stability": "dev", - "prefer-stable": true, - "extra": { - "merge-plugin": { - "include": [ - "../composer.json" - ], - "merge-extra": true, - "merge-extra-deep": true - }, - "installer-paths": { - "build/core": ["type:drupal-core"], - "build/modules/contrib/{$name}": ["type:drupal-module"], - "build/profiles/contrib/{$name}": ["type:drupal-profile"], - "build/themes/contrib/{$name}": ["type:drupal-theme"], - "build/drush/contrib/{$name}": ["type:drupal-drush"], - "build/modules/custom/{$name}": ["type:drupal-custom-module"], - "build/themes/custom/{$name}": ["type:drupal-custom-theme"] - }, - "enable-patching": true, - "patchLevel": { - "drupal/core": "-p2" - } - } -} diff --git a/.travis/docker-compose.override.yml b/.travis/docker-compose.override.yml deleted file mode 100644 index eeef28d9..00000000 --- a/.travis/docker-compose.override.yml +++ /dev/null @@ -1,37 +0,0 @@ -version: "3" - -services: - database: - environment: - MYSQL_MAX_ALLOWED_PACKET: 512M - MYSQL_WAIT_TIMEOUT: 28800 - php: - volumes: - - log:/mnt/files/log - environment: - DRUPAL_CORE: ${DRUPAL_CORE:-} - DEPENDENCIES: ${DEPENDENCIES:-} - # We can not pass these environment variables with `docker-compose run -e` until - # this has not been improved. https://github.com/wodby/php/pull/21#issuecomment-361200733 - DRUPAL_MODULE_NAME: apigee_edge - APIGEE_EDGE_AUTH_TYPE: ${APIGEE_EDGE_AUTH_TYPE} - APIGEE_EDGE_ENDPOINT: ${APIGEE_EDGE_ENDPOINT} - APIGEE_EDGE_USERNAME: ${APIGEE_EDGE_USERNAME} - APIGEE_EDGE_PASSWORD: ${APIGEE_EDGE_PASSWORD} - APIGEE_EDGE_ORGANIZATION: ${APIGEE_EDGE_ORGANIZATION} - APIGEE_EDGE_TEST_LOG_DIR: "/mnt/files/log" - # Suppress deprecation warnings. - # https://api.drupal.org/api/drupal/vendor%21symfony%21phpunit-bridge%21DeprecationErrorHandler.php/8.5.x - SYMFONY_DEPRECATIONS_HELPER: disabled - THREADS: ${THREADS:-2} - TEST_ROOT: ${TEST_ROOT:-modules/contrib/apigee_edge/tests} - # We have to set this variable even if we set this to disabled, because - # otherwise xDebug does not get enabled and we need that for code coverage - # generation. - PHP_XDEBUG: 0 - webserver: - environment: - APACHE_FCGI_PROXY_TIMEOUT: 180 # Just in case, wait more than usual in tests. - -volumes: - log: diff --git a/.travis/docker-compose.yml b/.travis/docker-compose.yml deleted file mode 100644 index 630d33c5..00000000 --- a/.travis/docker-compose.yml +++ /dev/null @@ -1,62 +0,0 @@ -version: "3" - -services: - database: - image: ${DB_IMAGE:-wodby/mariadb:10.2-3.1.3} - container_name: "${COMPOSE_PROJECT_NAME:-my_project}_database" - stop_grace_period: 30s - environment: - MYSQL_ROOT_PASSWORD: ${DB_ROOT_PASSWORD:-password} - MYSQL_DATABASE: ${DB_NAME:-drupal} - MYSQL_USER: ${DB_USER:-drupal} - MYSQL_PASSWORD: ${DB_PASSWORD:-password} - POSTGRES_PASSWORD: ${DB_PASSWORD:-password} - POSTGRES_DB: ${DB_NAME:-drupal} - POSTGRES_USER: ${DB_USER:-drupal} - - php: - build: - context: .. - dockerfile: .travis/Dockerfile - args: - - PHP_IMAGE=${PHP_IMAGE:-wodby/drupal-php:7.1-dev-4.5.0} - container_name: "${COMPOSE_PROJECT_NAME:-my_project}_php" - environment: - DB_HOST: ${DB_HOST:-database} - DB_USER: ${DB_USER:-drupal} - DB_PASSWORD: ${DB_PASSWORD-password} - DB_NAME: ${DB_NAME:-drupal} - DB_DRIVER: ${DB_DRIVER:-mysql} - SIMPLETEST_BASE_URL: http://webserver - SIMPLETEST_DB: ${DB_DRIVER:-mysql}://${DB_USER:-drupal}:${DB_PASSWORD-password}@${DB_HOST:-database}/${DB_NAME:-drupal} - MINK_DRIVER_ARGS_WEBDRIVER: '["chrome", { "chromeOptions": { "w3c": false } }, "http://webdriver:4444/wd/hub"]' - BROWSERTEST_OUTPUT_DIRECTORY: "/mnt/files/log/simpletest" - COMPOSER_AUTH: ${COMPOSER_AUTH:-} - volumes: - - codebase:/var/www/html - - $HOME/.composer/cache/files:/home/wodby/.composer/cache/files - - webserver: - image: ${WEBSERVER_IMAGE:-wodby/php-apache:2.4-3.0.5} - container_name: "${COMPOSE_PROJECT_NAME:-my_project}_webserver" - depends_on: - - php - environment: - APACHE_LOG_LEVEL: debug - APACHE_BACKEND_HOST: php - APACHE_SERVER_ROOT: /var/www/html/build - NGINX_STATIC_CONTENT_OPEN_FILE_CACHE: "off" - NGINX_ERROR_LOG_LEVEL: debug - NGINX_BACKEND_HOST: php - NGINX_SERVER_ROOT: /var/www/html/build - volumes: - - codebase:/var/www/html - - webdriver: - image: selenium/standalone-chrome:3 - # Unfortunatelly its seems this image is not working at this moment. - # https://www.drupal.org/project/drupalci_environments/issues/2978243 - # image: drupalci/webdriver-chromedriver:dev - -volumes: - codebase: diff --git a/.travis/prepare-test-env.sh b/.travis/prepare-test-env.sh deleted file mode 100755 index 84c97d31..00000000 --- a/.travis/prepare-test-env.sh +++ /dev/null @@ -1,109 +0,0 @@ -#!/usr/bin/env bash - -set -e - -IS_ENV_VARS_SET=1 -for VAR in APIGEE_EDGE_AUTH_TYPE APIGEE_EDGE_ENDPOINT APIGEE_EDGE_ORGANIZATION APIGEE_EDGE_USERNAME APIGEE_EDGE_PASSWORD; do - if [[ -z "${!VAR}" ]] ; then - IS_ENV_VARS_SET=0 - echo "Incomplete configuration. The variable ${VAR} should exist and not be empty." - fi -done - -if [[ ${IS_ENV_VARS_SET} -eq 0 ]]; then - echo "Exiting" - exit 1 -fi - -# Make sure that script is standalone (it can be used even if it is not called -# by run-test.sh). -THREADS=${THREADS:-4} -MODULE_PATH=${MODULE_PATH:-"/opt/drupal-module"} -WEB_ROOT=${WEB_ROOT:-"/var/www/html/build"} -WEB_ROOT_PARENT=${WEB_ROOT_PARENT:-"/var/www/html"} -TEST_ROOT=${TEST_ROOT:-modules/custom} -TESTRUNNER=${TESTRUNNER:-"/var/www/html/testrunner"} - -COMPOSER_GLOBAL_OPTIONS="--no-interaction --no-suggest -o" - -# We mounted the cache/files folder from the host so we have to fix permissions -# on the parent cache folder because it did not exist before. -sudo -u root sh -c "chown -R wodby:wodby /home/wodby/.composer/cache" - -cd ${MODULE_PATH}/.travis - -# Install module with the highest dependencies first. -composer update ${COMPOSER_GLOBAL_OPTIONS} - -# Allow to run tests with a specific Drupal core version (ex.: latest dev). -if [[ -n "${DRUPAL_CORE}" ]]; then - composer require drupal/core:${DRUPAL_CORE} drupal/core-dev:${DRUPAL_CORE} ${COMPOSER_GLOBAL_OPTIONS}; -fi - -# Downgrade dependencies if needed. -# (This fix is necessary since PR#130 had been merged because after that lowest -# builds started to fail. Probably caused by a merge plugin issue because this -# problem could be reproduced only in this environment.) -if [[ -n "${DEPENDENCIES}" ]]; then - composer update ${COMPOSER_GLOBAL_OPTIONS} ${DEPENDENCIES} --with-dependencies -fi - -# Die if environment preparation has failed. -if [[ ! -d ${MODULE_PATH}/.travis/build ]]; then - exit 1; -fi - -# Copying Drupal to the right place. -# Symlinking is not an option because the webserver container would not be -# able to access to files. -cp -R ${MODULE_PATH}/.travis/build ${WEB_ROOT_PARENT} -cp -R ${MODULE_PATH}/.travis/vendor ${WEB_ROOT_PARENT} - -# Symlink module to the contrib folder. -ln -s ${MODULE_PATH} ${WEB_ROOT}/modules/contrib/${DRUPAL_MODULE_NAME} - -# Pre-create simpletest and screenshots directories... -sudo -u root -E mkdir -p ${WEB_ROOT}/sites/simpletest -sudo -u root mkdir -p /mnt/files/log/screenshots -# and some other. -# (These are required by core/phpunit.xml.dist). -sudo -u root mkdir -p ${WEB_ROOT}/profiles -sudo -u root mkdir -p ${WEB_ROOT}/themes - -# Based on https://www.drupal.org/node/244924, but we had to grant read -# access to files and read + execute access to directories to "others" -# otherwise Javascript tests failed by using webdriver. -# (Error: jQuery was not found an AJAX form.) -sudo -u root -E sh -c "chown -R wodby:www-data $WEB_ROOT \ - && find $WEB_ROOT -type d -exec chmod 6755 '{}' \; \ - && find $WEB_ROOT -type f -exec chmod 0644 '{}' \;" - -sudo -u root -E sh -c "mkdir -p $WEB_ROOT/sites/default/files \ - && chown -R wodby:www-data $WEB_ROOT/sites/default/files \ - && chmod 6770 $WEB_ROOT/sites/default/files" - -# Make sure that the log folder is writable for both www-data and wodby users. -# Also create a dedicated folder for PHPUnit outputs. -sudo -u root sh -c "chown -R www-data:wodby /mnt/files/log \ - && chmod -R 6750 /mnt/files/log \ - && mkdir -p /mnt/files/log/simpletest/browser_output \ - && chown -R www-data:wodby /mnt/files/log/simpletest \ - && chmod -R 6750 /mnt/files/log/simpletest \ - && chown -R www-data:wodby /mnt/files/log/screenshots \ - && chmod -R 6750 /mnt/files/log/screenshots" - -# Change location of the browser_output folder, because it seems even if -# BROWSERTEST_OUTPUT_DIRECTORY is set the html output is printed out to -# https://github.com/drupal/core/blob/8.5.0/tests/Drupal/Tests/BrowserTestBase.php#L1086 -sudo -u root ln -s /mnt/files/log/simpletest/browser_output ${WEB_ROOT}/sites/simpletest/browser_output - -# Fix permissions on on simpletest and its sub-folders. -sudo -u root sh -c "chown -R www-data:wodby $WEB_ROOT/sites/simpletest \ - && chmod -R 6750 $WEB_ROOT/sites/simpletest" - -# Let's display installed dependencies and their versions. -composer show - -# Downloading the test runner. -curl -s -L -o ${TESTRUNNER} https://github.com/Pronovix/testrunner/releases/download/v0.4/testrunner-linux-amd64 -chmod +x ${TESTRUNNER} diff --git a/.travis/push-logs.sh b/.travis/push-logs.sh deleted file mode 100755 index c95a269f..00000000 --- a/.travis/push-logs.sh +++ /dev/null @@ -1,23 +0,0 @@ -#!/usr/bin/env bash - -set -e - -if [[ -z "${LOGS_REPO_USER}" ]] || [[ -z "${LOGS_REPO_PASSWORD}" ]] || [[ -z "${LOGS_REPO_HOST}" ]] || [[ -z "${LOGS_REPO_NAME}" ]]; then - echo "There is at least one missing information about the destination repo. Make sure the following environment variables exist and not empty: LOGS_REPO_USER, LOGS_REPO_PASSWORD, LOGS_REPO_HOST, LOGS_REPO_NAME." - exit 0 -fi - -# Initial GIT setup. -git config --global user.email "travis@travis-ci.org" -git config --global user.name "Travis CI" -# Copy logs from the PHP container. -docker cp $(docker ps -f "name=.*_php" --format "{{.ID}}"):/mnt/files/log . -cd log -# Commit and push logs to the git repo. -git init -BRANCH_NAME=${TRAVIS_JOB_NUMBER}-$(date +"%y%m%d-%H%M") -git checkout -b ${BRANCH_NAME} -git add . -git commit -am "Travis build: ${TRAVIS_JOB_NUMBER}" -git remote add origin https://${LOGS_REPO_USER}:${LOGS_REPO_PASSWORD}@${LOGS_REPO_HOST}/${LOGS_REPO_USER}/${LOGS_REPO_NAME}.git -git push -u origin ${BRANCH_NAME} diff --git a/.travis/run-test.sh b/.travis/run-test.sh deleted file mode 100755 index aa3f031c..00000000 --- a/.travis/run-test.sh +++ /dev/null @@ -1,29 +0,0 @@ -#!/usr/bin/env bash - -set -e - -# Register shared variables. -export THREADS=${THREADS:-4} -export MODULE_PATH="/opt/drupal-module" -export WEB_ROOT="/var/www/html/build" -export WEB_ROOT_PARENT="/var/www/html" -export TEST_ROOT=${TEST_ROOT:-modules/custom} -export TESTRUNNER="/var/www/html/testrunner" - -if [[ ! -f ${TESTRUNNER} ]]; then - echo "Preparing test environment..." - /opt/drupal-module/.travis/prepare-test-env.sh -fi - -PHPUNIT="${WEB_ROOT_PARENT}/vendor/bin/phpunit -c ${WEB_ROOT}/core -v --debug --printer \Drupal\Tests\Listeners\HtmlOutputPrinter" - -# Do not exit if any PHPUnit test fails. -set +e - -# If no argument passed start the testrunner and start running ALL tests -# concurrently, otherwise pass them directly to PHPUnit. -if [[ $# -eq 0 ]]; then - sudo -u root -E sudo -u www-data -E ${TESTRUNNER} -verbose -threads=${THREADS} -root=${WEB_ROOT}/${TEST_ROOT} -command="$PHPUNIT" -else - sudo -u root -E sudo -u www-data -E ${PHPUNIT} ${@} -fi From ab85d2298805fb43a1e590f6b8f1ba0daf69eecf Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Fri, 14 Feb 2020 10:15:55 -0800 Subject: [PATCH 16/18] CircleCI: small tweak to trigger build. --- .circleci/config.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index 8e5f7a56..0359dfa9 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -118,8 +118,7 @@ functional_tests: &functional_tests - store_artifacts: path: /tmp/artifacts -# Run Drupal functional tests. This command invokes the test-functional-js.sh -# hook. +# Run Drupal functional tests. This command invokes test-functional-js.sh. functional_js_tests: &functional_js_tests <<: *defaults steps: From bc612d0099835e00dbf8ed638b070533289f981c Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Wed, 26 Feb 2020 12:16:55 -0800 Subject: [PATCH 17/18] CircleCI: adding back phpmd and phpmetrics. --- .circleci/RoboFile.php | 2 ++ .circleci/code-sniffer.sh | 3 +++ .circleci/config.yml | 2 +- phpcs.xml.dist | 3 --- 4 files changed, 6 insertions(+), 4 deletions(-) diff --git a/.circleci/RoboFile.php b/.circleci/RoboFile.php index 0f8bf68c..9adc0c6b 100644 --- a/.circleci/RoboFile.php +++ b/.circleci/RoboFile.php @@ -54,6 +54,8 @@ public function setupSkeleton() $this->taskFilesystemStack() ->mkdir('artifacts') ->mkdir('artifacts/phpcs') + ->mkdir('artifacts/phpmd') + ->mkdir('artifacts/phpmetrics') ->mkdir('/tmp/artifacts/phpunit') ->mkdir('/tmp/artifacts/phpmd') ->run(); diff --git a/.circleci/code-sniffer.sh b/.circleci/code-sniffer.sh index caa26dcf..97e0d8a7 100644 --- a/.circleci/code-sniffer.sh +++ b/.circleci/code-sniffer.sh @@ -10,5 +10,8 @@ fi # Install dependencies and configure phpcs vendor/bin/phpcs --config-set installed_paths vendor/drupal/coder/coder_sniffer +vendor/bin/phpmd modules/$1/src html cleancode,codesize,design,unusedcode --ignore-violations-on-exit --reportfile artifacts/phpmd/index.html +vendor/bin/phpmetrics --extensions=php,inc,module --report-html=artifacts/phpmetrics --git modules/$1 + # Check coding standards vendor/bin/phpcs -p -s -n --colors --standard=modules/apigee_edge/phpcs.xml.dist --report=junit --report-junit=artifacts/phpcs/phpcs.xml modules/$1 diff --git a/.circleci/config.yml b/.circleci/config.yml index 0359dfa9..d4b5044f 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -154,7 +154,7 @@ code_sniffer: &code_sniffer ./code-sniffer.sh apigee_edge - store_test_results: - path: /var/www/html/artifacts/phpcs + path: /var/www/html/artifacts - store_artifacts: path: /var/www/html/artifacts diff --git a/phpcs.xml.dist b/phpcs.xml.dist index 8b6666b1..51d7b0ae 100644 --- a/phpcs.xml.dist +++ b/phpcs.xml.dist @@ -25,8 +25,5 @@ 0 - - 0 - From ab7b5085a8fa947c7ef928dccded1fae0d996163 Mon Sep 17 00:00:00 2001 From: Arlina Espinoza Date: Wed, 26 Feb 2020 15:28:25 -0800 Subject: [PATCH 18/18] CircleCI: adding back "TypeHintMissing" code sniff. --- phpcs.xml.dist | 7 ------- 1 file changed, 7 deletions(-) diff --git a/phpcs.xml.dist b/phpcs.xml.dist index 51d7b0ae..b51537c9 100644 --- a/phpcs.xml.dist +++ b/phpcs.xml.dist @@ -18,12 +18,5 @@ 0 - - - 0 -