Skip to content
This repository has been archived by the owner on Dec 1, 2021. It is now read-only.

Latest commit

 

History

History
299 lines (230 loc) · 14.6 KB

CONTRIBUTING.md

File metadata and controls

299 lines (230 loc) · 14.6 KB

Contributing to Move.mil

Anyone is welcome to contribute code changes and additions to this project. If you'd like your changes merged into the dev branch, please read the following document before opening a pull request.

There are several ways in which you can help improve this project:

  1. Fix an existing issue and submit a pull request.
  2. Review open pull requests.
  3. Report a new issue. Only do this after you've made sure the behavior or problem you're observing isn't already documented in an open issue.

Table of Contents

Getting Started

Move.mil is a Drupal (version 8.8.x) content management system with a MariaDB database version (version 10.2). Development dependencies are managed using Composer.

How is this site laid out?

When installing the given composer.json some tasks are taken care of:

  • Drupal will be installed in the web-directory.
  • Autoloader is implemented to use the generated composer autoloader in vendor/autoload.php, instead of the one provided by Drupal (web/vendor/autoload.php).
  • Modules (packages of type drupal-module) will be placed in web/modules/contrib/
  • Theme (packages of type drupal-theme) will be placed in web/themes/contrib/
  • Profiles (packages of type drupal-profile) will be placed in web/profiles/contrib/
  • Creates default writable versions of settings.php and services.yml.
  • Creates web/sites/default/files-directory.
  • Latest version of drush is installed locally for use at vendor/bin/drush.
  • Latest version of DrupalConsole is installed locally for use at vendor/bin/drupal.
  • Creates environment variables based on your .env file. See .env.docker.example.

Usage

First you need to install docker.

Clone this repo in your desired directory (move.mil by default):

git clone [email protected]:transcom/move.mil.git move.mil
cd move.mil

Set default environment variables:

cp .env.docker.example .env

Setup Move.mil:

Note: You don't have to execute the commands below if you have a db dump file(s) in your mariadb-init folder. In that case execute make setup and skip to step 4.

  1. Initialize the docker containers with Ngnix, Drupal app, and MariaDB:
docker-compose up -d
docker-compose run php composer install
  1. Install a standard Drupal application:
docker-compose run php drupal site:install --force --no-interaction
  1. Import Drupal configuration:
docker-compose run php drupal config:import --no-interaction

See this article for more information about configuration management

Note: To stop the containers execute: make stop. If you want to know more available commands, please review the following document Makefile

  1. Redirect move.mil.localhost to your localhost:
sudo sh -c "echo '127.0.0.1 move.mil.localhost' >> /etc/hosts"
  1. Lastly, navigate to move.mil.localhost:8000 in your Web browser of choice.

Database Import

Instead of installing the site, you can choose to place a .sql or .sql.gz file in mariadb-init. All files in this folder will be imported, in alphabetical order. .sql and .sql.gz files are gitignored so you do not have to worry about them getting committed.

  1. Save your file on mariadb-init folder.
  2. Execute make prune.
  3. Execute make up. This step will pick up your db dumps and execute them.

Making Changes

  1. Clone the project's repo.
  2. Place an updated db dump (.sql or .sql.gz) file in mariadb-init.
  3. Create a feature branch for the code changes you're looking to make: git checkout -b your-descriptive-branch-name origin/1.x-dev.
  4. Setup move.mil: make setup.
  5. Write some code!
  6. Run the application and verify that your changes function as intended. Remember to run make cr if you are not seeing your changes.
  7. If your changes would benefit from testing, add the necessary tests and verify everything passes.
  8. Export the configuration with your changes: make cex.
  9. Commit your changes: git commit -am 'Add some new feature or fix some issue'. (See this excellent article for tips on writing useful Git commit messages.)
  10. Push the branch to move.mil repository: git push -u origin your-descriptive-branch-name.
  11. Wait until al checks are passed.
  12. Create a new pull request and we'll review your changes.

Update Menu items

On May 19th, 2020 the web/modules/custom/custom_move_mil_menus module was unistalled, and from then on, the menu started being only content. To update menu items please go to the site and make the modifications there. You would need an admin role to do so. You can unistall and remove the custom_move_mil_menus.

Verifying Changes

We use a number of tools to evaluate the quality and security of this project's code:

CircleCI is the test runner for this project and testing can be run inside a container.

  • Install CircleCI Cli
  • circleci build --job behat
  • circleci build --job code-sniffer
  • circleci build --job code-coverage

Locally run tests will have notices that creating a local artifact is not supported. This is a limitation to the circleci cli. This is not any of the Drupal tests failing.

e.g -

   Error &errors.errorString{s:"not supported"}

Updating Drupal Core

This project will attempt to keep all of your Drupal Core files up-to-date; the project drupal-composer/drupal-scaffold is used to ensure that your scaffold files are updated every time drupal/core is updated. If you customize any of the "scaffolding" files (commonly .htaccess), you may need to merge conflicts if any of your modified files are updated in a new release of Drupal core.

Follow the steps below to update your core files.

  1. Run composer update drupal/core webflo/drupal-core-require-dev symfony/* --with-dependencies to update Drupal Core and its dependencies.
  2. Run git diff to determine if any of the scaffolding files have changed. Review the files for any changes and restore any customizations to .htaccess or robots.txt.
  3. Commit everything all together in a single commit, so web will remain in sync with the core when checking out branches or running git bisect.
  4. In the event that there are non-trivial conflicts in step 2, you may wish to perform these steps on a branch, and use git merge to combine the updated core files with your customized files. This facilitates the use of a three-way merge tool such as kdiff3. This setup is not necessary if your changes are simple; keeping all of your modifications at the beginning or end of the file is a good strategy to keep merges easy.

Deploying to Elastic Beanstalk

Prepare staging (the next production env)

  1. Copy production database to staging. Staging must have the most up to date content changes.
  2. Copy producton /drupalfiles to staging. Staging must have all the files uploaded to production.

SSH to the EB environent

eb ssh <application-name>

Get docker container name

sudo docker ps

DB dump on ec2

sudo docker exec -it [container name] vendor/bin/drush sql:dump > /home/ec2-user/file.sql

DB restore on ec2

cat /home/ec2-user/20180710.sql | sudo docker exec -i [container name] vendor/bin/drush sqlc

Copy files (replace with the EC2 IP address, your local path, and EB ssh key)

tar -czvf livefiles.tar.gz /drupalfiles/*
scp -i ~/.ssh/movemil-eb-stage.pem [email protected]:/home/ec2-user/livefiles.tar.gz ~/move.mil/

Restore files (replace with the EC2 IP address, your local path, and EB ssh key)

 scp -i ~/.ssh/movemil-eb-stage.pem ~/move.mil.db/livefiles.tar.gz [email protected]:/home/ec2-user/
tar -xzvf livefiles.tar.gz -C /drupalfiles/
sudo cp -r /drupalfiles/drupalfiles/* /drupalfiles/
sudo rm -r /drupalfiles/drupalfiles

Merge code and build Docker image

Merge the changes into 1.x-dev branch to deploy to staging. This will build (on CircleCI) the docker image for staging, and it will push it to AWS. Merge the changes into master branch to deploy to production. This will build (on CircleCI) the docker image for production, and it will push it to AWS.

If you want to build the docker image locally, you can run ./scripts/build-docker-image.sh just make sure it has the tag that you want. As it is right now, it is the tag is 'test'.

Deploy

Create a branch out of 1.x-dev for staging or checkout master. For staging, edit the file Dockerrun.aws.json and make sure the tag of the image is stage, by setting the value of the Image to: "328180890751.dkr.ecr.us-east-1.amazonaws.com/movemil:stage" and commit that change. The 'eb deploy' command will only take commited changes. You don't need to push the change to github though, since the deploy will happen from your local. For production you can skip that step, since by default it says production.

Make sure you have installed the EB CLI. Go to your command line, on the root of the project. Execute eb deploy eb-environment-name and that will start the deployment process. The current EB environments are move-mil-green and move-mil-blue. One is for staging and the other for production, so make sure the tag, and eb env matches with the environment that you want to update.

Normally, you will always deploy to staging to avoid production outages, and then swap the DNSs between staging and production.

In summary, eb deploy command tells what EB environment to use, and the commited file Dockerrun.aws.json tells how and what to deploy.

Running Post Deploy Script

The script post-deploy.sh in the project root contains commands that often want to be after deploying a new version of the site to Elastic Beanstalk. This includes update configuration, update the database, rebuild the cache and more.

To run:

  1. eb ssh <application-name> to the application that was deployed to.
  2. sudo docker ps to get the container id or name.
  3. sudo docker exec -it <container-id|name> /bin/bash /var/www/html/post-deploy.sh to run the script.

Swap DNS

Since the DNS belong to DDS, once you have finished your production deployment, send a request to DDS to swap the DNS between stage.move.mil and move.mil and that would conclude the production deployment.

Common Drupal commands on EC2

  • Clear Drupal cache sudo docker exec -it [container name] vendor/bin/drupal cr
  • Import Drupal configuration to DB: sudo docker exec -it [container name] vendor/bin/drupal config:import. This command will override the configuration saved on the DB.
  • Connect to DB: sudo docker exec -it [container name] vendor/bin/drush sqlc
  • List Drush commands: sudo docker exec -it [container name] vendor/bin/drush help
  • List Drupal console commands: sudo docker exec -it [container name] vendor/bin/drupal help

Code Style

Pending

Your bug fix or feature addition won't be rejected if it runs afoul of any (or all) of these guidelines, but following the guidelines will definitely make everyone's lives a little easier.

Legalese

Before submitting a pull request to this repository for the first time, you'll need to sign a Developer Certificate of Origin (DCO). To read and agree to the DCO, you'll add your name and email address to CONTRIBUTORS.md. At a high level, this tells us that you have the right to submit the work you're contributing in your pull request and says that you consent to us treating the contribution in a way consistent with the license associated with this software (as described in LICENSE.md) and its documentation ("Project").

You may submit contributions anonymously or under a pseudonym if you'd like, but we need to be able to reach you at the email address you provide when agreeing to the DCO. Contributions you make to this public Department of Defense repository are completely voluntary. When you submit a pull request, you're offering your contribution without expectation of payment and you expressly waive any future pay claims against the U.S. Federal Government related to your contribution.

FAQ

Should I commit the contrib modules I download?

Composer recommends no. They provide argumentation against but also workrounds if a project decides to do it anyway.

Should I commit the scaffolding files?

The drupal-scaffold plugin can download the scaffold files (like index.php, update.php, …) to the web/ directory of your project. If you have not customized those files you could choose to not check them into your version control system (e.g. git). If that is the case for your project it might be convenient to automatically run the drupal-scaffold plugin after every install or update of your project. You can achieve that by registering @drupal-scaffold as post-install and post-update command in your composer.json:

"scripts": {
    "drupal-scaffold": "DrupalComposer\\DrupalScaffold\\Plugin::scaffold",
    "post-install-cmd": [
        "@drupal-scaffold",
        "..."
    ],
    "post-update-cmd": [
        "@drupal-scaffold",
        "..."
    ]
},

How can I apply patches to downloaded modules?

If you need to apply patches (depending on the project being modified, a pull request is often a better solution), you can do so with the composer-patches plugin.

To add a patch to drupal module foobar insert the patches section in the extra section of composer.json:

"extra": {
    "patches": {
        "drupal/foobar": {
            "Patch description": "URL or local path to patch"
        }
    }
}