This repository contains the default community health
files
for the alleyinteractive
organization.
This repository acts as a catch-all for Github organization-wide community files, such as CODE_OF_CONDUCT.md. These community health files will be used unless a repository has their own version.
The repository also contains reusable Github workflows for use on any public repository. These workflows are reused across the organization to perform continuous integration tests with Github Actions.
The following workflows are available to use:
- Built Branches/Tags and Other Deployment Workflows
- Built Branch
- Built Releases (
⚠️ Deprecated) - Built Tag (
⚠️ Deprecated) - Deploy to Remote Repository
- Dependabot Management
- Testing Workflows
Create a *-built
version of a branch for use in submodules.
Specify using
with
keyword.
- Specify the PHP version to use.
- Accepts a string.
- Defaults to
8.1
.
- Specify the Node version to use.
- Will not build front-end assets if none are found.
- Accepts a number.
- Defaults to
16
.
name: Create a -built branch
on:
push:
branches:
- main
jobs:
built-branch:
uses: alleyinteractive/.github/.github/workflows/built-branch.yml@main
ℹ️ Note: This action is deprecated in favor of the action-release.
Create built releases of a project based on the WordPress plugin Version
header in your main plugin file and then falling back to the version
property in
either composer.json
or package.json
. When the version is updated in either
file, the action will build the project, push a new tag up with the version, and
create a release. Optionally, the release can be drafted or published.
The most common use of this workflow is for WordPress plugins or other packages that require built assets (such as ones from Webpack or Gulp) to be included to work but we don't want to include those assets in version control.
When the plugin's version is incremented on
alleyinteractive/create-wordpress-plugin
-based plugins via npm run release
,
the action will push a built version of the plugin to the *-built
branch and
then create a release with the built assets. If the plugin's version was not
incremented, the action will still push the latest changes to the *-built
branch but will not create a release. This does mirror the
Built Branch workflow but is more flexible and allows for
publishing releases.
Specify using
with
keyword.
- Specify if the release should be drafted for a new release.
- Accepts a boolean.
- Defaults to
false
.
- Specify the Node version to use.
- Will not build front-end assets if none are found.
- Accepts a number.
- Defaults to
18
.
name: Built Release
on:
push:
branches:
- production
jobs:
built-asset:
uses: alleyinteractive/.github/.github/workflows/built-release.yml@main
ℹ️ Note: This action is deprecated in favor of the action-release. Built tags with the format of
v*.*.*-built
are not compatible with Composer and should be avoided.
Create a *-built
version of a tag for use in submodules.
Specify using
with
keyword.
- Specify the PHP version to use.
- Accepts a string.
- Defaults to
8.1
.
- Specify the Node version to use.
- Will not build front-end assets if none are found.
- Accepts a number.
- Defaults to
16
.
name: Create a -built tag
on:
push:
tags:
- 'v*.*.*'
- '!*-built'
jobs:
built-tag:
uses: alleyinteractive/.github/.github/workflows/built-tag.yml@main
Sets Dependabot pull requests to auto merge once they meet the requirements for merging (passes CI, approval, etc. as defined by the protected branch).
name: dependabot-auto-merge
on:
pull_request:
permissions:
pull-requests: write
contents: write
jobs:
dependabot:
uses: alleyinteractive/.github/.github/workflows/dependabot-auto-merge.yml@main
Automatically approves Dependabot pull requests for auto-merging when the default branch for a repository is protected.
name: dependabot-auto-approve
on:
pull_request:
permissions:
pull-requests: write
contents: write
jobs:
dependabot:
uses: alleyinteractive/.github/.github/workflows/dependabot-auto-approve.yml@main
Run automated Node tests against your repository. Assumes that your plugin will have the following commands available to it:
npm run lint
npm run test
npm run build
Specify using
with
keyword.
- Specify the Node version to use.
- Will not run if none are found.
- Accepts a number.
- Defaults to
16
.
- Specify if
npm ci
should be used versusnpm install
. - Accepts a boolean.
- Defaults to
false
.
- Specify the cache to use or otherwise disable.
- Will not cache if a
package-lock.json
is not found. - Accepts a boolean.
- Defaults to
true
.
- Specify if
npm audit --audit-level=high --production
should be run. - Accepts a boolean.
- Defaults to
false
.
- Specify if
npm run test
should be run. - Accepts a boolean.
- Defaults to
true
.
- Specify if
npm run lint
should be run. - Accepts a boolean.
- Defaults to
true
.
- Specify if
npm run build
should be run. - Accepts a boolean.
- Defaults to
true
.
- Specify the working directory to use.
- Accepts a string.
- Defaults to the root of the repository.
name: Node Tests
on:
pull_request:
jobs:
node-tests:
uses: alleyinteractive/.github/.github/workflows/node-tests.yml@main
Run a set of Composer scripts against your project. Assumes that composer run <command>
will run your tests. Supports multiple commands with a multi-line
command
input.
Note: This workflow does not setup MySQL for testing. Use the PHP Tests with MySQL workflow for that.
Specify using
with
keyword.
- Specify the Composer command to use for testing.
- Accepts a string.
- Required.
- Specify the PHP version to use.
- Accepts a string.
- Defaults to
8.1
.
- Specify the database image to use.
- Accepts a string.
- Defaults to
'mysql:8.0'
. Can be disabled by setting it to an empty string.
- Specify the working directory to use.
- Accepts a string.
- Defaults to the root of the repository.
name: Composer Tests
on:
push:
branches:
- main
pull_request:
schedule:
- cron: '0 0 * * *'
jobs:
composer-lint-phpunit:
uses: alleyinteractive/.github/.github/workflows/php-composer-command.yml@main
with:
command: |
lint
phpunit
Run PHPUnit tests against your project. Installs and configures MySQL for
WordPress unit testing. Assumes that composer run phpunit
will run your unit
tests.
Specify using
with
keyword.
- Specify the Composer action to use (install/update).
- Accepts a string.
- Defaults to
install
.
- Specify the Composer command to use for testing.
- Accepts a string.
- Defaults to
phpunit
.
- Specify the operation system to use.
- Accepts a string.
- Defaults to
ubuntu-latest
.
- Specify the PHP version to use.
- Accepts a string.
- Defaults to
8.1
.
- Specify the WordPress version to use.
- Accepts a string.
- Defaults to
latest
.
- Flag if WordPress should be installed with multisite. Sets the
WP_MULTISITE
flag. - Accepts a boolean.
- Defaults to
false
.
- Specify the database image to use.
- Accepts a string.
- Defaults to
mysql:8.0
. Can be disabled by setting it to an empty string.
- Specify the object to use.
- Valid values are
memcached
orredis
. - Defaults to not adding the service.
- Allows you to select whether the job should install the locked, highest, or lowest versions of Composer dependencies.
- Valid values are
locked
,highest
, orlowest
. - Defaults to
locked
.
- Flag if the WordPress core test suite should be installed.
- Accepts a boolean.
- Defaults to
false
- Specify the working directory to use.
- Accepts a string.
- Defaults to the root of the repository.
name: Testing Suite
on:
push:
branches:
- main
pull_request:
schedule:
- cron: '0 0 * * *'
jobs:
php-tests:
uses: alleyinteractive/.github/.github/workflows/php-tests.yml@main
You can also use the PHP tests inside a Github Action Matrix to test against multiple PHP/WordPress versions:
name: Testing Suite
on:
push:
branches:
- main
pull_request:
schedule:
- cron: '0 0 * * *'
jobs:
php-tests:
strategy:
matrix:
php: [8.1]
wordpress: ["latest"]
uses: alleyinteractive/.github/.github/workflows/php-tests.yml@main
with:
php: ${{ matrix.php }}
wordpress: ${{ matrix.wordpress }}
Uses rsync and git to deploy files/folders from a local GitHub action repository to a remote repository.
Notes:
- This workflow is available as a standalone action that can be used in a composite workflow with other custom steps.
- We do not leverage external actions to manage the SSH agent as we want to keep the code as simple/single-sourced as possible.
- We must manually manage the SSH keys for the remote repository. This is typically done by adding the private key to the GitHub action secrets and then adding the public key to the remote repository (eg. as a write deploy key).
Specify using
with
keyword.
- Specify the operation system to use.
- Accepts a string.
- Defaults to
ubuntu-latest
.
- Specify the remote repository to deploy to.
- Accepts a string.
- Required.
- Specify the remote branch to deploy to.
- Accepts a string.
- Defaults to the same branch name in the remote repo as the current running action.
- Specify the base directory to sync from.
- Accepts a string.
- Defaults to the root of the repository (
.
). NOTE You likely want a trailing slash if you're syncing a subdirectory. (eg.wp-content/
)
- Specify the destination directory to sync to.
- Accepts a string.
- Defaults to the root of the remote repository (
.
).
- Specify a comma-separated list of files and directories to exclude from sync.
- Accepts a string. (e.g.
.git, .gitmodules
) - Defaults to
.git, .gitmodules
.
Specify using
secrets
keyword.
- Specify the SSH key to use for the remote repository (requires write access).
- Required.
Example deploy to VIP:
name: Deploy to VIP repository
on:
push:
branches:
- production
- preprod
- develop
jobs:
sync-to-vip:
uses: alleyinteractive/.github/.github/workflows/deploy-to-remote-repository.yml@main
with:
remote_repo: 'git@github.com:wpcomvip/alley.git'
exclude_list: '.git, .gitmodules, .revision, .deployment-state, .node_modules, no-vip'
secrets:
REMOTE_REPO_SSH_KEY: ${{ secrets.REMOTE_REPO_SSH_KEY }}
Example Deploy to Pantheon multidev sites labeled preprod
and develop
:
name: Deploy to Pantheon repository
on:
push:
branches:
- preprod
- develop
jobs:
sync-to-pantheon:
uses: alleyinteractive/.github/.github/workflows/deploy-to-remote-repository.yml@main
with:
remote_repo: 'ssh://codeserver.dev.SOME-PANTHEON-SITE_ID@codeserver.dev.SOME-PANTHEON-SITE_ID.drush.in:2222/~/repository.git'
destination_directory: 'wp-content/'
exclude_list: '.git, pantheon-mu-plugin'
secrets:
REMOTE_REPO_SSH_KEY: ${{ secrets.REMOTE_REPO_SSH_KEY }}
Run phpstan
tests against your project. Assumes that composer run phpstan
will
run your tests.
ℹ️ Note: This action is deprecated in favor of the PHP Composer Script workflow.
Specify using
with
keyword.
- Specify the Composer command to use for testing.
- Accepts a string.
- Defaults to
phpstan
.
- Specify the PHP version to use.
- Accepts a string.
- Defaults to
8.1
.
- Allows you to select whether the job should install the locked, highest, or lowest versions of Composer dependencies.
- Accepts a string:
locked
,highest
, orlowest
. - Defaults to
locked
.
- Specify the working directory to use.
- Accepts a string.
- Defaults to the root of the repository.
name: Code Quality
on:
push:
branches:
- main
pull_request:
schedule:
- cron: '0 0 * * *'
jobs:
code-quality:
uses: alleyinteractive/.github/.github/workflows/php-code-quality.yml@main
Run phpcs
tests against your project. Assumes that composer run phpcs
will
run your tests.
ℹ️ Note: This action is deprecated in favor of the PHP Composer Script action.
Specify using
with
keyword.
- Specify the PHP version to use.
- Accepts a string.
- Defaults to
8.1
.
- Allows you to select whether the job should install the locked, highest, or lowest versions of Composer dependencies.
- Accepts a string:
locked
,highest
, orlowest
. - Defaults to
locked
.
- Specify the working directory to use.
- Accepts a string.
- Defaults to the root of the repository.
name: Coding Standards
on:
push:
branches:
- main
pull_request:
schedule:
- cron: '0 0 * * *'
jobs:
coding-standards:
uses: alleyinteractive/.github/.github/workflows/php-coding-standards.yml@main