-
Notifications
You must be signed in to change notification settings - Fork 25
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
9 changed files
with
198 additions
and
121 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
32 changes: 0 additions & 32 deletions
32
.template/addons/github/.github/wiki/Getting-Started.md.tt
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,24 @@ | ||
use_source_path __dir__ | ||
|
||
directory '.github' | ||
|
||
# Split README.md file to multiple wiki pages | ||
original_readme = File.read 'README.md' | ||
|
||
create_file '.github/wiki/Getting-Started.md' do | ||
get_content_between(original_readme, "## Getting Started", "## Testing") | ||
end | ||
|
||
create_file '.github/wiki/Testing.md' do | ||
get_content_between(original_readme, "## Testing", "## CI/CD") | ||
end | ||
|
||
FileUtils.mv '.github/workflows/README.md', '.github/wiki/CI-CD.md' | ||
|
||
gsub_file 'README.md', /## Getting Started.*/m do | ||
<<~README | ||
## Documentation | ||
Please check out full documentation on the [wiki](link to github wiki goes here). | ||
README | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,6 +4,120 @@ | |
|
||
> *App introduction goes here ...* | ||
|
||
## Documentation | ||
## Getting Started | ||
|
||
Please check out full documentation on the [wiki](link to github wiki goes here). | ||
### Prerequisites | ||
|
||
- Ruby version: <%= RUBY_VERSION %> | ||
<%- if WEB_VARIANT -%> | ||
- Node version: <%= NODE_VERSION %> | ||
<%- end -%> | ||
|
||
### Docker | ||
|
||
- Install [Docker for Mac](https://docs.docker.com/docker-for-mac/install/) | ||
|
||
- Setup and boot the Docker containers: | ||
|
||
```sh | ||
./bin/envsetup.sh | ||
``` | ||
|
||
### Development | ||
|
||
- Setup the databases: | ||
|
||
- Postgres: | ||
|
||
```sh | ||
rake db:setup | ||
``` | ||
|
||
- Run the Rails app | ||
|
||
```sh | ||
./bin/dev | ||
``` | ||
|
||
## Testing | ||
|
||
### Docker-based tests on the CI server | ||
|
||
Add the following build settings to run the tests in the Docker environment via Docker Compose (configuration in `docker-compose.test.yml`): | ||
|
||
- Configure the environment variable `BRANCH_TAG` to tag Docker images per branch, e.g: | ||
|
||
```sh | ||
# a unique `BRANCH_TAG` value to tag the Docker image | ||
# e.g $SEMAPHORE_BRANCH_ID or using the | ||
# or using nimblehq/[email protected] Github action | ||
export BRANCH_TAG= # unique value for tagging Docker image | ||
``` | ||
|
||
Each branch needs to have its own Docker image to avoid build settings disparities and leverage Docker image caching. | ||
|
||
> BRANCH_TAG must not contain special characters (`/`) to be valid. So using $BRANCH_NAME will not work e.g. chore/setup-docker. | ||
An alternative is to use a unique identifier such as PR_ID or BRANCH_ID on the CI server. | ||
|
||
- Pull the latest version the Docker image for the branch: | ||
|
||
```sh | ||
docker pull $DOCKER_IMAGE:$BRANCH_TAG || true | ||
``` | ||
|
||
On each build, the CI environment does not contain yet a cached version of the image. Therefore, it is required to pull | ||
it first to leverage the `cache_from` settings of Docker Compose which avoids rebuilding the whole Docker image on subsequent test builds. | ||
|
||
- Build the Docker image: | ||
|
||
```sh | ||
./bin/docker-prepare && docker compose -f docker-compose.test.yml build | ||
``` | ||
|
||
Upon the first build, the whole Docker image is built from the ground up and tagged using `$BRANCH_TAG`. | ||
|
||
- Push the latest version of the Docker image for this branch: | ||
|
||
```sh | ||
docker push $DOCKER_IMAGE:$BRANCH_TAG | ||
``` | ||
|
||
- Setup the test database: | ||
|
||
```sh | ||
docker compose -f docker-compose.test.yml run test bin/bundle exec rake db:test:prepare | ||
``` | ||
|
||
### Test | ||
|
||
- Run all tests: | ||
|
||
```sh | ||
# Docker way | ||
docker compose -f docker-compose.test.yml run test | ||
|
||
# Non-Docker way | ||
rspec | ||
``` | ||
|
||
- Run a specific test: | ||
|
||
```sh | ||
# Docker way | ||
docker compose -f docker-compose.test.yml run test bin/bundle exec rspec [rspec-params] | ||
|
||
# Non-Docker way | ||
rspec [rspec-params] | ||
``` | ||
|
||
### Automated Code Review Setup | ||
- Add a bot (i.e. `team-nimblehq`) to this repository or to the organization. The bot requires permission level “Write” to be able to set a PR’s status. | ||
|
||
- Create a [Personal Access Token](https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token) | ||
from bot account with `public_repo` scope, and set it as `DANGER_GITHUB_API_TOKEN` secret on the CI Environment Settings. | ||
|
||
## CI/CD | ||
|
||
The project relies entirely on [Github Actions](https://github.com/features/actions) for CI/CD via multiple workflows located under the [`.github/workflows/`](.github/workflows) directory. | ||
|
||
Please check out the [`.github/workflows/README.md`](.github/workflows/README.md) file for further instructions. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters