CircleCI configuration examples
Our custom CircleCI Orb is located here: https://github.com/wunderio/silta-circleci/tree/master/orb
Below is a list of examples for common needs.
All examples are meant to be used in the .circleci/.yml
file of your project.
npm install
from another location#
Run We recommend putting your package.json in the Drupal root folder (one level above the web root),
but many existing projects still have package.json in the theme folder.
You can specify the path to your frontend folder by adding a parameter to the
existing npm-install-build
command:
Note that this path is relative to the Drupal root, not to the project root.
#
Run a different command to build the frontendThe default command for building the frontend is npm run build
, assuming there will be a build
key
in the script
section of your package.json, which is recommended.
If you have another command that should be run you can specify it in the npm-install-build
step:
#
Use npm instead of yarnUsing npm
is preferred over the user of yarn
, and if it's not too much hassle it would be best to switch
for the sake of consistency.
In the meantime you can use the yarn-install-build
step which works the same as npm-install-build
#
Deploy sub-project from within the same repoHaving e.g. Storybook or other frontend application included in the base project codebase that require separate deployment can be easily done even using different chart. For simple application (static) the simple chart can be used. Refer to simple examples with the following additions:
Tell build process (under silta/simple-build-deploy
) where your application code can be found (related to repo root).
If the command to build your application isn't the default npm run build
you can define it with the build_command
parameter.
Next, you need to define the webroot of your application, e.g. where your application was built:
Finally, give the deployment a release-suffix:
The complete deployment workflow for the app should look something like this:
Note: you need to include the application specific silta_configs (here silta-storybook.yml and silta-storybook-prod.yml). You should also update the drupal specific deployment steps to include the appropriate silta-cms.yml files.
Note 2: Add nested silta configurations (i.e. web/themes/custom/yourtheme/silta/
) and non-public files located in web subdirectory to .dockerignore
file, to exclude them from nginx and php images.
See https://wunderio.github.io/silta/docs/silta-examples for example on how to split the silta configuration part for this kind of setup. There is also a more complex example in [https://github.com/wunderio/decoupled-project](decoupled-project -template)