diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml deleted file mode 100644 index db1903dcc..000000000 --- a/.github/workflows/deploy.yml +++ /dev/null @@ -1,19 +0,0 @@ -name: Deploy -on: - workflow_dispatch: -jobs: - test: - name: Deploy to prod - runs-on: ubuntu-20.04 - steps: - - name: Checkout - uses: actions/checkout@v3 - with: - ref: stage - - - name: Merge stage -> prod - uses: devmasx/merge-branch@1.4.0 - with: - type: now - target_branch: prod - github_token: ${{ github.token }} \ No newline at end of file diff --git a/.github/workflows/release.yml b/.github/workflows/merge_dev_to_stage.yml similarity index 74% rename from .github/workflows/release.yml rename to .github/workflows/merge_dev_to_stage.yml index 456dfe219..49741615b 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/merge_dev_to_stage.yml @@ -1,15 +1,17 @@ -name: Release +name: Merge dev to stage on: workflow_dispatch: schedule: - cron: '15 14 * * *' jobs: - test: - name: Test - runs-on: ubuntu-20.04 + merge: + name: Merge + runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v3 + with: + ref: 'dev' - name: Merge dev to stage uses: devmasx/merge-branch@1.4.0 diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 745a79448..959eba119 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -58,6 +58,14 @@ jobs: ${{ github.ref == 'refs/heads/dev' && vars.NETLIFY_STORYBOOK_ID != '' }} + - name: Merge release to prod (silverback-template only) + uses: devmasx/merge-branch@1.4.0 + if: ${{ github.repository == 'AmazeeLabs/silverback-template' && github.ref == 'refs/heads/release'}} + with: + type: now + target_branch: prod + github_token: ${{ github.token }} + docker_build: name: Docker Build if: startsWith(github.ref_name, 'test-all/') diff --git a/.idea/.gitignore b/.idea/.gitignore index 13566b81b..03d7c2646 100644 --- a/.idea/.gitignore +++ b/.idea/.gitignore @@ -6,3 +6,4 @@ # Datasource local storage ignored files /dataSources/ /dataSources.local.xml +/markdown.xml diff --git a/.lagoon.yml b/.lagoon.yml index e3bbb709a..3167013c3 100644 --- a/.lagoon.yml +++ b/.lagoon.yml @@ -21,7 +21,7 @@ tasks: command: drush scr scripts/translations-import.php service: cli environments: - dev: + prod: routes: - nginx: - example.cms.amazeelabs.dev @@ -32,3 +32,25 @@ environments: schedule: '*/15 * * * *' command: drush cron service: cli + stage: + routes: + - nginx: + - stage-example.cms.amazeelabs.dev + - build: + - stage-example.build.amazeelabs.dev + cronjobs: + - name: drush cron + schedule: '*/15 * * * *' + command: drush cron + service: cli + dev: + routes: + - nginx: + - dev-example.cms.amazeelabs.dev + - build: + - dev-example.build.amazeelabs.dev + cronjobs: + - name: drush cron + schedule: '*/15 * * * *' + command: drush cron + service: cli diff --git a/INIT.md b/INIT.md index 8cf4f4a04..699a974c9 100644 --- a/INIT.md +++ b/INIT.md @@ -37,7 +37,8 @@ Adjust project machine name in the repo. ```ts await prompt('PROJECT_NAME_MACHINE', { type: 'text', - message: 'Project name for machines:', + message: + 'Project name for machines (usually a lowercase version of Jira project code):', validate: (name) => !/^[a-z][a-z\d_]*$/.test(name) ? 'Must start with a lowercase letter and contain lowercase letters, numbers and underscores only.' @@ -60,6 +61,18 @@ replace( '@amazeelabs/silverback-template', process.env.PROJECT_NAME_MACHINE, ); +// Template's prod domain is special. +replace( + '.lagoon.yml', + '- example.', + '- prod-' + process.env.PROJECT_NAME_MACHINE + '.', +); +// The rest of domains are standard. +replace( + '.lagoon.yml', + '-example.', + '-' + process.env.PROJECT_NAME_MACHINE + '.', +); ``` Update the auth key for Gatsby user. diff --git a/README.md b/README.md index eca93c2d8..19e4a7a88 100644 --- a/README.md +++ b/README.md @@ -20,16 +20,62 @@ - [Create a new Netlify project](https://amazeelabs.atlassian.net/wiki/spaces/ALU/pages/368017428/Create+a+new+Netlify+project) - Check the [Environment overrides](#environment-overrides) section below -## Release and deployment - -Development happens in pull requests against the `dev` branch. There is a github -"Release" workflow that will merge the current state of `dev` into the `stage`. -This workflow can be triggered from the github UI and will run automatically -once a day. - -The "Deploy" workflow has to be triggered manually from the github UI, and will -merge the current state of `stage` into `prod` and therefore trigger a -production deployment. +## Branches and environments + +
Branch name | +Connected environment | +Purpose | +|
---|---|---|---|
Pre Go Live | +Post Go Live | +||
release | +(none) | +Contains everything that is approved for PROD deployment | +|
prod | +PROD | +The production environment | +|
dev | +DEV | +Sandbox/playground, no client data, anyone can merge anything | +Sandbox/playground, with client data, main testing environment. | +
stage | +STAGE | +Second sandbox with client data and automated merge from dev to stage, regular data sync | +Second sandbox for bigger features that need a clean set up or would prevent other normal tasks from being performed while working on it. With client data. No automated merges from dev. |
+
lagoon-* | +(same as branch name) | +Can be created for big, long-term feature developments. Use wisely as it creates additional costs. |
+