Drag & Drop WordPress Responsive Form Builder
Requires: git, npm, Grunt.
- Clone repo to plugin directory
git clone git@github.com:CalderaWP/Caldera-Forms.git
- Switch directory
cd Caldera-Forms.git
- If you are using your own local development environment:
npm i && composer install
- If you are wish to use the provided local development environment
composer dev:install
To create a build to ship to WordPress.org:
npm run package
This creates /build/<version>
where <version>
is the current version set in package.json
. This creates a directory you can ZIP up for testing or whatever.
See "Release To WordPress.org" section below for more details on pushing this build to WordPress.org.
Run watcher for development to auto-compile JavaScript and CSS.
This is the new stuff, built with webpack. Eventually everything UI will be here.
-
Clients:
- pro - The Caldera Forms Pro admin page and tab in the editor.
- blocks - The Gutenberg block(s).
- admin - The main admin page. Work in progress, not used in plugin.
- viewer - The entry viewer. Work not in progress, not used in plugin.
- editor - Theoretical.
-
Build for development and start watcher.
npm run dev
-
Build for production
npm run build:webpack
This is the old stuff, built with grunt.
- Build for development and start watcher.
npm run dev:grunt
- Build for production
npm run build:grunt
composer test:php
- Run PHP tests -- isolated unit tests and the WordPress integration tests.composer dev:install
- Installs dependencies, Docker-based test environment and sets up test forms.composer dev:destroy
- Deletes dependencies and the Docker-based test environment.composer wp:install
- Installs Docker-based test environment.composer wp:start
- Starts Docker-based test environment and echos the server's url.composer wp:server-start
- Starts Docker-based test environment.composer wp:server-url
- Echos the Docker-based test environment's server url.composer wp:activate
- Activate plugins in Docker-based environment.composer wp:tests
- Runs the PHP integration tests using phpunit inside Docker-based environment.composer wp:stop
- Stops Docker-based test environment, without destroying containers.composer wp:destroy
- Removes (including the database) the test environment and destroys containers.composer test:unit
- Run php unit tests.composer test:setup
- Adds test forms and puts them on pages.composer test:delete
- Delete test forms and pages the are on.composer nuke
- Deletes dependencies, including lock files -- NPM and Composer.
npm test
- Run JavaScript test watchernpm run test:once
- Run JavaScript unit tests oncenpm run test:e2e
- Start Cypress e2e test runner.npm run test:e2e:ci
- Trigger Cypress.io test record.
Probably don't use these directly. They will change. Must be prefaced with docker-compose run --rm cli
wp cf import-test-forms
- Import test formswp cf delete-test-forms
- Delete test formswp cf create-test-pages
- Import test pageswp cf delete-test-pages
- Delete test pages
- svn
- npm
- Grunt
npm install -g grunt-cli
- Have commit access to Caldera Forms svn
- Build release file
npm run package
- Push Tag to WordPress.org
cd bin
bash deploy-wp-org-tag.sh 12345 christiechirinos
- Install tag using WP Rollback on QA site and re-run Ghost Inspector tests.
- Copy tag to trunk
bash deploy-wp-org-trunk.sh 12345 christiechirinos
- This assumes your WordPress.org username is
christiechirinos
, and your password is12345
. - The first argument is password, which is required. The second argument is username, which defaults to
Shelob9
, which is Josh's username.