2019-12-09 16:28:15 +01:00
|
|
|
# Developer Guide #
|
|
|
|
|
2020-10-28 09:34:47 +01:00
|
|
|
This is a generic "getting started" guide for the Penpot platform. It
|
2019-12-09 16:28:15 +01:00
|
|
|
intends to explain how to get the development environment up and
|
|
|
|
running with many additional tips.
|
|
|
|
|
|
|
|
The main development environment consists in a docker compose
|
|
|
|
configuration that starts the external services and the development
|
|
|
|
container (called **devenv**).
|
|
|
|
|
2020-03-08 13:13:32 +01:00
|
|
|
We use tmux script in order to multiplex the single terminal and run
|
2019-12-09 16:28:15 +01:00
|
|
|
both the backend and frontend in the same container.
|
|
|
|
|
|
|
|
|
|
|
|
## System requirements ##
|
|
|
|
|
|
|
|
You should have `docker` and `docker-compose` installed in your system
|
|
|
|
in order to set up properly the development enviroment.
|
|
|
|
|
|
|
|
In debian like linux distributions you can install it executing:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo apt-get install docker docker-compose
|
|
|
|
```
|
|
|
|
|
2020-06-19 14:02:16 +02:00
|
|
|
Start and enable docker environment:
|
|
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo systemctl start docker
|
|
|
|
sudo systemctl enable docker
|
|
|
|
```
|
|
|
|
|
|
|
|
Add your user to the docker group:
|
|
|
|
|
|
|
|
```basb
|
|
|
|
sudo usermod -aG docker $USER
|
|
|
|
```
|
|
|
|
|
|
|
|
And finally, increment user watches:
|
|
|
|
|
|
|
|
```
|
|
|
|
echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p
|
|
|
|
```
|
|
|
|
|
|
|
|
NOTE: you probably need to login again for group change take the effect.
|
|
|
|
|
|
|
|
|
2019-12-09 16:28:15 +01:00
|
|
|
## Start the devenv ##
|
|
|
|
|
|
|
|
**Requires a minimum knowledge of tmux usage in order to use that
|
|
|
|
development environment.**
|
|
|
|
|
|
|
|
For start it, staying in this repository, execute:
|
|
|
|
|
|
|
|
```bash
|
2020-12-02 23:31:25 +01:00
|
|
|
./manage.sh pull-devenv
|
2019-12-09 16:28:15 +01:00
|
|
|
./manage.sh run-devenv
|
|
|
|
```
|
|
|
|
|
|
|
|
This will do the following:
|
|
|
|
|
2020-12-02 23:31:25 +01:00
|
|
|
- Pulls the latest devenv image.
|
2019-12-09 16:28:15 +01:00
|
|
|
- Starts all the containers in the background.
|
|
|
|
- Attaches to the **devenv** container and executes the tmux session.
|
|
|
|
- The tmux session automatically starts all the necessary services.
|
|
|
|
|
2020-09-09 15:49:06 +02:00
|
|
|
You can execute the individual steps manully if you want:
|
2019-12-09 16:28:15 +01:00
|
|
|
|
2020-09-09 15:49:06 +02:00
|
|
|
```bash
|
2020-12-02 23:31:25 +01:00
|
|
|
./manage.sh build-devenv # builds the devenv docker image (not necessary in normal sircumstances)
|
2020-09-09 15:49:06 +02:00
|
|
|
./manage.sh start-devenv # starts background running containers
|
|
|
|
./manage.sh run-devenv # enters to new tmux session inside of one of the running containers
|
|
|
|
./manage.sh stop-devenv # stops background running containers
|
|
|
|
./manage.sh drop-devenv # removes all the volumes, containers and networks used by the devenv
|
|
|
|
```
|
2019-12-09 16:28:15 +01:00
|
|
|
|
|
|
|
Now having the the container running and tmux open inside the
|
|
|
|
container, you are free to execute any commands and open many shells
|
|
|
|
as you want.
|
|
|
|
|
|
|
|
You can create a new shell just pressing the **Ctr+b c** shortcut. And
|
|
|
|
**Ctrl+b w** for switch between windows, **Ctrl+b &** for kill the
|
|
|
|
current window.
|
|
|
|
|
|
|
|
For more info: https://tmuxcheatsheet.com/
|
|
|
|
|
|
|
|
|
2020-09-09 15:49:06 +02:00
|
|
|
### Inside the tmux session
|
2019-12-09 16:28:15 +01:00
|
|
|
|
2020-09-09 15:49:06 +02:00
|
|
|
#### gulp
|
2019-12-09 16:28:15 +01:00
|
|
|
|
|
|
|
The styles and many related tasks are executed thanks to gulp and they are
|
|
|
|
executed in the tmux **window 0**. This is a normal gulp watcher with some
|
|
|
|
additional tasks.
|
|
|
|
|
|
|
|
|
2020-09-09 15:49:06 +02:00
|
|
|
#### shadow-cljs
|
2019-12-09 16:28:15 +01:00
|
|
|
|
2020-08-17 15:04:21 +02:00
|
|
|
The frontend build process is located on the tmux **window 1**.
|
|
|
|
**Shadow-cljs** is used for build and serve the frontend code. For
|
|
|
|
more information, please refer to `02-Frontend-Developer-Guide.md`.
|
2020-04-02 12:21:46 +02:00
|
|
|
|
2020-08-17 15:04:21 +02:00
|
|
|
By default the **window 1** executes the shadow-cljs watch process,
|
|
|
|
that starts a new JVM/Clojure instance if there is no one running.
|
2020-04-02 12:21:46 +02:00
|
|
|
|
2020-08-17 15:04:21 +02:00
|
|
|
Finally, you can start a REPL linked to the instance and the current
|
|
|
|
connected browser, by opening a third window with `Ctrl+c` and running
|
|
|
|
`npx shadow-cljs cljs-repl main`.
|
|
|
|
|
|
|
|
|
2020-09-09 15:49:06 +02:00
|
|
|
#### exporter
|
2020-08-17 15:04:21 +02:00
|
|
|
|
|
|
|
The exporter app (clojurescript app running in nodejs) is located in
|
|
|
|
**window 2**, and you can go directly to it using `ctrl+b 2` shortcut.
|
|
|
|
|
|
|
|
There you will found the window split in two slices. On the top slice
|
|
|
|
you will have the build process (using shadow-cljs in the same way as
|
|
|
|
frontend application), and on the bot slice the script that launeches
|
|
|
|
the node process.
|
|
|
|
|
|
|
|
If some reason scripts does not stars correctly, you can manually
|
|
|
|
execute `node target/app.js ` to start the exporter app.
|
2019-12-09 16:28:15 +01:00
|
|
|
|
|
|
|
|
2020-09-09 15:49:06 +02:00
|
|
|
#### backend
|
2019-12-09 16:28:15 +01:00
|
|
|
|
2020-08-17 15:04:21 +02:00
|
|
|
The backend related environment is located in the tmux **window 3**,
|
2019-12-09 16:28:15 +01:00
|
|
|
and you can go directly to it using `ctrl+b 2` shortcut.
|
|
|
|
|
|
|
|
By default the backend will be started in non-interactive mode for
|
2020-08-17 15:04:21 +02:00
|
|
|
convenience but you can just press `Ctrl+c` and execute `./scripts/repl`
|
2020-03-08 13:13:32 +01:00
|
|
|
for start the repl.
|
2019-12-09 16:28:15 +01:00
|
|
|
|
|
|
|
On the REPL you have this helper functions:
|
|
|
|
- `(start)`: start all the environment
|
|
|
|
- `(stop)`: stops the environment
|
|
|
|
- `(restart)`: stops, reload and start again.
|
|
|
|
|
2020-03-08 13:13:32 +01:00
|
|
|
And many other that are defined in the `tests/user.clj` file.
|
|
|
|
|
2019-12-09 16:28:15 +01:00
|
|
|
If some exception is raised when code is reloaded, just use
|
|
|
|
`(repl/refresh-all)` in order to finish correctly the code swaping and
|
|
|
|
later use `(restart)` again.
|
|
|
|
|
|
|
|
For more information, please refer to: `03-Backend-Guide.md`.
|