For the impatient:
- Get a suitable environment:
- Use VSCode (on your machine)
- Use a Docker Container
- Install prerequisites manually
- Run the application
This repository contains an example application written using Resemble.
The '.proto' files can be found in the api/
directory, grouped into
subdirectories by proto package, while backend specific code can be
found in backend/
and web specific code in web/
.
This repository includes a Dev Container that has all of the dependencies you need to build and run code in this repository already installed.
Note
The Dev Container's configuration for this repository is found in
.devcontainer/devcontainer.json
. You
may expand on it to customize your development environment to your
liking.
You can start the Dev Container in two different ways.
GitHub's Codespaces are machines that are hosted in the cloud for you.
Important
You must connect your local VSCode to the codespace, you can not use VSCode in a browser window.
(Right-Click to open in new tab or window)
If you haven't set your default editor to VSCode for codespaces, then the 'Open in GitHub Codespaces' button above will end up opening VSCode in the browser. You can close that browser tab because YOU MUST open the existing codespace using the VSCode on your machine. You can also go to https://github.com/codespaces and click the three dots next to the codespace you just created and then click Open in ...
then Open in Visual Studio Code
.
Now you're ready to run the application!
Important
Currently, our Dev Container at .devcontainer/devcontainer.json
only works on x86 CPU architectures.
If your machine meets the required specifications, you can start this repository's Dev Container with VSCode locally rather than using a GitHub Codespace.
Clone this repository:
git clone https://github.com/reboot-dev/resemble-hello-world.git
Open the Dev Container:
- In VSCode, open the
resemble-hello-world
folder you've cloned. - Press: Ctrl+Shift+P (Linux / Windows) or Command+Shift+P (Mac)
- Type/Select:
Dev Containers: Reopen In Container
VSCode will now start the Dev Container and restart VSCode to be running inside of that container.
Now you're ready to run the application!
We've created a Docker container that has all of the dependencies you need to build and run code in this repository already installed.
Important
The Docker container currently only works on x86 CPU architectures. Check back soon for more supported architectures.
Clone this repository:
git clone https://github.com/reboot-dev/resemble-hello-world.git
cd resemble-hello-world/
Run the container:
export HOST_WORKING_DIRECTORY="$(pwd)"
export CONTAINER_WORKSPACE_DIRECTORY="/workspaces/$(basename $HOST_WORKING_DIRECTORY)"
docker run \
--mount type=bind,source="$HOST_WORKING_DIRECTORY",target="$CONTAINER_WORKSPACE_DIRECTORY" \
--workdir "$CONTAINER_WORKSPACE_DIRECTORY" \
--env "HOST_UID=$(id -u)" \
--env "HOST_GID=$(id -g)" \
-p 127.0.0.1:3000:3000/tcp \
-p 127.0.0.1:9991:9991/tcp \
--privileged \
--interactive \
--tty \
ghcr.io/reboot-dev/resemble-standalone:latest \
/bin/bash
Explanation of flags:
- We --mount our --workdir (working directory), so we can work with it from the container.
- We tell the container about our user's UID and GID so that the container's user can match them, providing the same permissions inside and outside the container.
- We bind port 3000 so that we can access a React web front end (e.g., from a browser), and port 9991 so the web front end can access the Resemble backend.
--privileged
so that we can run Docker inside of the container.--interactive
and--tty
(often abbreviated-it
) lets us interact with the created container.ghcr.io/reboot-dev/resemble-standalone:latest
is the name of the container we'll be running./bin/bash
is the shell we'd like to run.
Now you're ready to run the application!
Important
Resemble backends currently can only run on x86 Linux machines with
glibc>=2.35
(Ubuntu Jammy and other equivalent-generation Linux
distributions). If you have a machine that doesn't fit this requirement, we
suggest using one of the approaches discussed above.
You must have the following tools installed:
- Python (including
pip
andvenv
) >= 3.10 - Node.js (including
npm
) - Docker
Clone this repository:
git clone https://github.com/reboot-dev/resemble-hello-world.git
cd resemble-hello-world/
Create a new Python virtual environment in which to install Resemble requirements and run an application:
python -m venv ./.resemble-hello-world-venv
source ./.resemble-hello-world-venv/bin/activate
To learn more about why virtual environments are a best practice for Python
projects, see the Python documentation for the venv
module.
Now you're ready to run the application!
Our backend is implemented in Python and we must install its dependencies before
running it. The most notable of those dependencies is the reboot-resemble
PyPI
distribution, which contains both the Resemble CLI (rsm
) and the resemble
Python package.
pip install -r backend/src/requirements.txt
To run the application, you can now use the Resemble CLI rsm
:
rsm dev
Running rsm dev
will watch for file modifications and restart the
application if necessary. See the .rsmrc
file for flags and
arguments that get expanded when running rsm dev
.
Similar to the backend, the front end has dependencies that need to be installed before running it. Open a separate terminal/shell and do:
cd web/
npm install
npm start
If using VSCode, the page will load automatically. If not using VSCode, visit http://127.0.0.1:3000`.
The application comes with backend tests.
Before you run the tests, you'll
need to ensure you've run rsm protoc
. If you've already run rsm dev
without modifying .rsmrc
, rsm protoc
will have been run for you as
part of that command.
Otherwise, you can do it manually.
rsm protoc
rsm protoc
will automatically make required Resemble '.proto'
dependencies like resemble/v1alpha1/options.proto
available on the
import path without you having to check them into your own repository.
Now you can run the tests using pytest
:
pytest backend/