Skip to content

Latest commit

 

History

History
75 lines (58 loc) · 2.85 KB

README.md

File metadata and controls

75 lines (58 loc) · 2.85 KB

skeletor Install Profile

Build Status Selenium Test Status

This is the D7 install profile for the skeletor project, to set up an appropriate layout for a build-based development strategy, striving toward continuous delivery and great good.

Layout

We will be attempting to follow the drush make guidelines laid out for packaging distributions on drupal.org:

http://drupal.org/node/1476014

The rationale being that when we layout our projects according to these guidelines, we don't need to document as much, and we will also know how to package our own distribution for drupal.org in the future.

Here's the additional suggested folder structure for the install profile:

+-modules/
| +-contrib/  (gitignored - all contrib modules should go here via makefile)
| +-custom/   (custom modules for the site)
| +-features/ (all feature modules)
+-themes/
| +-contrib/  (gitignored - any contrib themes should go here via makefile)
| +-custom/   (custom themes for the site)
+-libraries/  (gitignored - any libraries should go here via makefile)
+-tmp/        (for things that don't fit in standard install profile structure)
  +-conf/
  +-docs/     (project-specific docs)
  +-patches/
  +-scripts/  (any scripts related to project)
  +-snippets/ (settings.php and htaccess snippets)
  | +-htaccess/
  | +-settings.php/
  +-tests/

The tmp/ directory is intended to be removed before pushing to Acquia.

  • If you'd like any code to be appended to settings.php, simply add a snippet as tmp/snippets/settings.php/mysnippetname.settings.php. These snippets will be appended in alphabetical order during the build script.

To Build

To build the site in full, run the following command:

bash kickstart.sh path/to/build/docroot

Note: For the above script to work, it must be run within a project path without whitespace. You may run pwd in the project repo path to ensure that no parent directories have spaces.

To Utilize Inception

Inception is a Jenkins-based project used to coordinate deployment via build pipeline. It is used to set up and manage a remote Jenkins server that will me maximally accessible and configurable by team members.

git submodule update --init --recursive
cd tmp/tools/jenkins-inception
# Tell Inception to create and look for config file in project repo.
# (Remember: Exported environment variables must be reset in each new shell.)
export INCEPTION_CONFIG=$PWD/../../conf/inception-config.yml
bundle install
# View all tasks. See Inception README for details.
bundle exec rake -D