“How is the code organized, and why?”
The repository architecture is driven by a set of core principles:
- Project dependencies should never be committed directly to the repository
- The code that is deployed to production should be fully validated, tested, sanitized, and free of non-production tools
- Common project tasks should be fully automated and repeatable, independent of environment
Consequently, there are a few aspects of this project’s architecture and workflow that may be unfamiliar to you.
- Drupal core, contrib modules, themes, and third parties libraries are not committed to the repository. Contrib directories .gitignored and populated during build artifact generation.
- The repository is never pushed directly to the cloud. Instead, changes to the repository on GitHub trigger tests to be run via Continuous Integration. Changes that pass testing will automatically cause a build artifact to be created and deployed to the cloud.
- Common project tasks are executed via a build tool (Phing) so that they can be executed exactly the same in all circumstances.
The following is an overview of the purpose of each top level directory in the project template:
root
├── blt - Contains custom build config files for CI solutions. E.g., Phing configuration.
├── drush - Contain drush configuration that is not site or environment specific.
├── docroot - The drupal docroot.
├── hooks - Contains Acquia Cloud hooks.
├── modules - Contains custom and contrib modules.
├── patches - Contains private patches to be used by composer.json.
├── profiles - Contains contrib and custom profiles.
├── readme - Contains high level project documentation.
├── reports - Contains output of automated tests; is .gitignored.
├── scripts - Contains a variety of utility scripts.
├── sites - Contains sites.
├── tests - Contains project-level test files and configuration.
├── themes - Contains custom and contrib themes.
├── vendor - Contains built composer dependencies; is .gitignored.
All project and Drupal (module, themes, libraries) dependencies are managed via Composer. The management strategy is based on The Drupal Project.
Modules, themes, and other contributed drupal projects can be added as dependencies in the root composer.json file.
For step-by-step instructions on how to update dependencies, see Project Tasks.