Scraped version of Build Zip Archive with no support for WordPress.org or any settings. All it does is generate zip file based on build commands and .distignore or .gitignore..
This Action will build a zip archive of your WordPress plugin and attach that archive as an artifact, allowing you to download and test prior to deploying any changes to WordPress.org. This gives you the peace of mind knowing you've tested exactly what will be deployed.
Recommended to be used in conjunction with our WordPress.org Plugin Deploy Action as both Actions create the archive in the same way. An ideal workflow is to run this Action first and test the zip archive it provides. Once testing passes, then run our deploy Action to push changes to WordPress.org.
Note: while this Action will checkout your plugin code from the WordPress.org SVN repo it does not commit any code to that repo.
☞ Check out our collection of WordPress-focused GitHub Actions
retention-days
- How many days should the zip archive be kept. Defaults to 5.
If there are files or directories to be excluded from the archive, such as tests or editor config files, they can be specified in either a .distignore
file or a .gitattributes
file using the export-ignore
directive. If a .distignore
file is present, it will be used; if not, the Action will look for a .gitattributes
file and barring that, will write a basic temporary .gitattributes
into place before proceeding so that no Git/GitHub-specific files are included.
The recommened approach is to use a .distignore
file, especially when there are built files that are in .gitignore
that should be in the final archive. .gitattributes
is useful for plugins that don't run a build step as a part of the Actions workflow and also allows for GitHub's generated ZIP files to contain the same contents as what is committed to WordPress.org.
/.wordpress-org
/.git
/.github
/node_modules
.distignore
.gitignore
# Directories
/.wordpress-org export-ignore
/.github export-ignore
# Files
/.gitattributes export-ignore
/.gitignore export-ignore
To get started, you will want to copy the contents of one of these examples into .github/workflows/build-zip.yml
and push that to your repository. You are welcome to name the file something else, but it must be in that directory. The usage of ubuntu-latest
is recommended for compatibility with required dependencies in this Action.
name: Build release zip
on:
push:
branches:
- trunk
jobs:
build:
name: Build release zip
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Build plugin # Remove or modify this step as needed
run: |
composer install --no-dev
npm install
npm run build
- name: Generate zip
uses: 10up/action-wordpress-plugin-build-zip@stable
name: Build release zip
on:
workflow_dispatch
jobs:
build:
name: Build release zip
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Build plugin # Remove or modify this step as needed
run: |
composer install --no-dev
npm install
npm run build
- name: Generate zip
uses: 10up/action-wordpress-plugin-build-zip@stable
with:
retention-days: 1 # Optional; defaults to 5
Want to help? Check out our contributing guidelines to get started.
Our GitHub Actions are available for use and remix under the MIT license.
Active: 10up is actively working on this, and we expect to continue work for the foreseeable future including keeping tested up to the most recent version of WordPress. Bug reports, feature requests, questions, and pull requests are welcome.