Skip to content

Commit

Permalink
Always pull latest from main in dev
Browse files Browse the repository at this point in the history
  • Loading branch information
minottic authored Sep 25, 2023
1 parent f95728a commit 1b1e12b
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 6 deletions.
16 changes: 10 additions & 6 deletions dev/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,17 @@

```bash
git clone [email protected]:paulscherrerinstitute/scicat-ci.git
git submodule update --recursive --init
git submodule update --init --recursive --remote
```

## Run docker-compose

### :warning: IMPORTANT
The docker-compose builds the containers from the Dockerfile of each submodule, thus using the submodule checked out to a particular commit. To build a container basing it on a different commit, e.g. the latest on main, one has to checkout first the submodule to the commit (or branch) of interest.
The docker-compose builds the containers from the Dockerfile of each submodule, thus using the submodule checked out to a particular commit.
It is often the case that when setting up the environment one wants the components to be checked out automatically to the latest on main. The command above (`git submodule update --init --recursive --remote`) does that but might break any component where a non-backwards compatible change was applied.
We reference in the config of each components the latest commit (.git-commit-sha) of the submodule where the docker-compose was run and worked the last time, whenever the submodule commit is different from the one referenced in the scicat-ci repo.

To build a container based on a different commit one has to checkout first the submodule to the commit (or branch) of interest.

Build the docker containers with the suitable [profiles](https://docs.docker.com/compose/profiles/):

Expand All @@ -19,11 +23,11 @@ export COMPOSE_PROFILES=<MY_PROFILES>
docker-compose -f docker-compose.yaml up -d --force-recreate --build --no-deps
```

All the application containers (excluding the db -mongo- and the db_seeding -mongo_seed-) are meant to be used for development so docker-compose starts, rather the applications, environments where the development environment of each applications is set up. This means that, to run the application, one has to attach to the container and start it.
All the application containers (excluding the db -mongo- and the db_seeding -mongo_seed-) are meant to be used for development so docker-compose starts, rather than the applications, environments where the development environment of each application is set up. This means that, to run the application, one has to attach to the container and start it.

### Example

Here are covered the two most common use case, spinning up the backend and fronted; the new backend and the frontend.
Here are the two most common use cases, spinning up the backend and fronted; the new backend and the frontend.

#### BE and FE

Expand All @@ -36,7 +40,7 @@ export COMPOSE_PROFILES=be,fe
docker-compose -f docker-compose.yaml up --force-recreate --build --no-deps -d
```

This will start four containers: the be container, the fe one, the mongodb database and a short lived one, called mongodb_seed_be that puts some example data into the be db of mongo.
This will start four containers: the be container, the fe one, the mongodb database and a short-lived one, called mongodb_seed_be that puts some example data into the be db of mongo.

#### New BE and FE

Expand All @@ -49,6 +53,6 @@ export COMPOSE_PROFILES=be_next,fe
docker-compose -f docker-compose.yaml up --force-recreate --build --no-deps -d
```

As before, this will start four containers: the be_next container, the fe one, the mongo database and a short lived one, called mongodb_seed_be_next that puts some example data into the be_next db of mongo.
As before, this will start four containers: the be_next container, the fe one, the mongo database and a short-lived one, called mongodb_seed_be_next that puts some example data into the be_next db of mongo.

Since the configuration of the frontend with the new backend has slightly changed, remember to set the `accessTokenPrefix` value to "Bearer " in the [config.json](./config/frontend/config.json#L3) file of the fe, before starting the frontend application.
1 change: 1 addition & 0 deletions dev/config/backend_next/.git-commit-sha
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
e4e9849b8285b37ee7c46bf9221d41393c5775b1

0 comments on commit 1b1e12b

Please sign in to comment.