-
Notifications
You must be signed in to change notification settings - Fork 1
Node.js Cody Tutorial
InspectIO can connect to a coding bot called Cody. With its help you can generate working code from an event map. Check out the slide deck From Event Storming to Working Code for a quick overview. This tutorial guides you through the first steps. You'll learn the basics as well as customizing code generation to suit your needs.
This tutorial is also available for our PHP Cody Bot
We've prepared a repository containing some exercises.
Please make sure you have installed Docker and Docker Compose to execute the exercises. Jest is used to validate the results.
It's important to follow each setup step. The exercises require a specific folder structure to function correctly!
- Create a new folder (f.e. in your home directory) that will contain the exercises as well as the coding bot.
mkdir cody-tutorial
cd cody-tutorial
- Clone exercises from Github
git clone https://github.com/event-engine/ts-iio-cody-tutorial.git exercises
- Install exercises dependencies
cd exercises
cp .env.dist .env # Adjust UID if needed
docker-compose run --rm exercises npm install
- Setup coding bot
# Change back to root directory cody-tutorial
cd ..
# Install Cody Server
git clone https://github.com/event-engine/nodejs-inspectio-cody.git cody-bot
cd cody-bot
cp .env.dist .env # Adjust UID if needed
docker-compose run --rm cody npm install
docker-compose up -d --no-recreate
- Create cody tutorial board on InspectIO and test connection
You can use InspectIO free version for the tutorial (no login required).
InspectIO is a modeling tool specifically designed for remote Event Storming. It ships with realtime collaboration features for teams (only available in paid version). The free version is a standalone variant without any backend connection. Your work is stored in local storage and can be exported. It is hosted on Github Pages and has the same code generation capabilities as the SaaS version.
Create a new board called "Cody Tutorial". You'll be redirected to the fresh board. Choose "Cody" from top menu to open the Cody Console. Just hit ENTER in the console to connect to the default Cody server that we've setup and started in the previous step.
Finally type "/help" in the console to let Cody explain the basic functionality.
- Mount exercises to Cody Bot
The Cody Server (coding bot) runs in a docker container. To be able to generate source code it needs access to a code repository. In our case this is the exercises
repository. We can mount the directory to the server by modifying docker-compose.yml
located in the server repository cody-bot
:
version: '2'
services:
exercises:
image: sandrokeil/typescript
volumes:
- .:/app
# ADD THE FOLLOWING LINE:
- ../exercises:/exercises
user: ${UID}
- Prepare codyconfig
Cody is a proxy to your own code generation logic. More on that in a second. A central codyconfig.ts
file tells Cody what to do when it receives tasks from InspectIO. As a first step we register the newly mounted /exercises
directory in a context object as a base path for all generated code files. Open cody-bot/codyconfig.ts
and modify it like this:
const CodyConfig = {
context: {
srcFolder: '/exercises/src',
},
hooks: {
// onCommand: onCommandHook,
// onAggregate: onAggregateHook,
// onEvent: onEventHook,
// onPolicy: onPolicyHook,
// onDocument: onDocumentHook,
}
};
module.exports = CodyConfig;
- Restart Cody
Finally let's restart Cody so that our changes take effect:
docker-compose stop && docker-compose up -d
Please Note: Restarting the docker container is only needed because we've added a volume mount in docker-compose.yml. When adding or changing something in the Cody Bot source code a file watcher takes care of restarting the server.
Cody is a http server running in a docker container on your local machine. InspectIO can connect to it using /connect [server address]
in the Cody Console. codyconfig.ts
is the central place to configure code generation. Generated code needs to be written to a target repository. We can use a docker volume mount to give Cody access to our project repository. In the tutorial our project is represented by exercises
, which contains a Jest test case for each exercise to validate that generated code looks like the expected one.
Join the community chat on Gitter.
No beta user yet? Request access in the community chat.