You can find the full set of configuration options for artifacts under the 'artifact' property in the defaults.yml file.
In order to use the artifact build, you must set the artifact.git.remote
property in your project's file to the git repository for the artifact. This is typically an Acquia or Pantheon git URL:
artifact:
git:
remote: [email protected]:example.git
All artifact configuration should be in your project's base properties file, .the-build/build.yml
.
artifact.result
- Value should bepush
,keep
, ordiscard
. When this flag is provided, it will bypass the "Push artifact changes?" prompt.
$> phing artifact -Dartifact.result=keep
- Configure the artifact in the
.the-build/build.yml
file of your project:
# Acquia git URL
[email protected]:example.git
# The Acquia web root must be 'docroot'
# This must also be configured in your composer.json, and reflected in your repository
drupal.root=docroot
- Build the artifact by running this command:
$> phing artifact
- Configure the artifact in the
.the-build/build.yml
file of your project:
# Pantheon git URL
artifact.git.remote=ssh://codeserver.dev.*@codeserver.dev.*.drush.in:2222/~/repository.git
# All artifacts go to the master branch
artifact.git.remote_branch=master
- Build the artifact by running this command:
$> phing artifact
- Build to a Pantheon multidev environment (multidev branch names must be 11 characters or shorter):
$> phing artifact -Dartifact.git.remote_branch=TICKET-999
Alternatively, you may chose to not set the artifact.git.remote_branch
property, and instead, and then merge the default artifact branch (generally artifact-develop
) to master
within the Pantheon UI.
This section describes a generalized artifact build process. This is the process implemented in targets/artifact.xml, and usage is described above.
- build artifact: a copy of a project codebase at a particular point in time, with all dependencies and configuration files required to run the site on a staging or production environment.
- artifact repository: a git repository where build artifacts are committed.
- development repository: a git repository where development happens and custom code and configuration are committed.
- integrated artifact: when a project has all project dependencies and configuration files committed to the development repository.
- For Acquia and Pantheon, the artifact is checked into the host's git repository
- For Platform.sh, the artifact is built and managed by Platform.sh
When hosting a site on Platform.sh, you do not need to use the-build's artifact process, since the artifact build process is fully managed by Platform.sh. Instead, you can run just the build target as part of Platform.sh's build hook:
vendor/bin/phing build -Dbuild.env=platformsh
(Note that this is included in the default .platform.app.yaml configuration, which is added when you install the-build and tell it you're hosting with Platform.sh.)
Different tools can be used to create a build artifact, including:
- palantirnet/the-build
- acquia/blt
- Custom scripts
When all project dependencies and configuration files are committed to the development repository, we call it an "integrated artifact". When using an integrated artifact, consider:
- The project may have merge conflicts in dependency code during development
- Development dependencies will be deployed to production
- Settings and configuration files will need to have PHP logic to manage varying configurations per environment. Because of Drupal's permissions on the
settings.php
file, this can prevent easily switching branches when this file is modified. - The "development repository" === the "artifact repository". This relationship can be more straightforward to understand for developers unfamiliar with composer and build processes
- It's easy to modify core and contrib code that should not be within our area of responsibility
This section describes the requirements for creating an artifact, but doesn't dictate the tool itself.
Contents:
- The foundation of the artifact is the
composer.json
file, plus any files checked in to the development repository. - Run
composer install --no-interaction --no-dev
. Note that after running this, development requirements like phing, Drupal coder, Drush, or Drupal console won't be available. This is why artifacts are frequently built separately from the current working directory, e.g. in a subdirectory calledartifacts/acquia/
that is excluded from git. - Recursively remove
.git
directories (below the root directory) from the artifact. Composer will install some dependencies from source, which means that it will check out git repositories for you. If these.git
subdirectories are not removed, git will treat them as sub-repositories and the files themselves will not be checked into the artifact, which will mean that the files are not available on the destination environments. - Compile
settings.php
with environment-specific values. Alternatively, you can take the "integrated artifact" approach and use a singlesettings.php
file containing logic for each separate environment. - Compile
services.yml
with environment-specific values. If you're using a singlesettings.php
file, you can also use environment logic there to switch between several different, environment-specificservices.yml
files. - Use a different
.gitignore
file for the artifact. The development repository should exclude thevendor/
directory, thesettings.php
file, and a few other resources; the artifact repository should include thevendor/
directory, thesettings.php
file, and a few other resources. Both repositories should exclude the Drupal public, private, and temporary files directories.
Commits:
- Artifact commit messages should reference the commit id on the development repository. They should also note whether the repository was "dirty" (had local changes) when the artifact was built.
- Artifact commits should be tagged with a corresponding (but not identical) tag to the development repository, if available. e.g. if the development repository is tagged
1.0.2
, the artifact repository may be taggedartifact-1.0.2
Safeguards:
- Artifact builds shouldn't change the current working directory
- Users should be able to review manual builds before pushing changes
Copyright 2018 Palantir.net, Inc.