Skip to content

Commit

Permalink
update README.md
Browse files Browse the repository at this point in the history
  • Loading branch information
glihm authored Oct 26, 2023
1 parent 97a14e4 commit 0d8693b
Showing 1 changed file with 76 additions and 17 deletions.
93 changes: 76 additions & 17 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,16 +11,85 @@ When a user starts an instance, a new container is created and started.

The database trait `ProxifierDb` is for now targetting `Sqlite`, but may be reworked to support any backend supported by `sqlx` rust crate.

## Usage
## Server configuration

To quickly spin up `katana-ci` server, you can do the following:

0. Install docker on your machine.
1. Download the binary from the release here: https://github.com/ArkProjectNFTs/katana-ci/releases/tag/v0.1.0 (or build from source).
2. Add execution rights on the binary `chmod +x katana-ci`
3. Pull the docker image of katana (or use your own):
```bash
docker pull arkproject/katana:0.3.1
```
4. Setup environment file with initial users and docker image ID:
```bash
# .env
export KATANA_CI_IMAGE=<ID_OF_IMAGE>
export KATANA_CI_USERS_FILE=.users
```
The `.users` file contains a simple list of initial users with their name and API-KEY, for example:
```bash
user1,mykey
user2,1234
```
5. Run the binary to be ready to spawn katana instances from your CI:
```bash
# Create the database file for SQLite. In the current version, if you
# don't delete the file and restart the binary you will see an insertion error
# of the users, that's normal, users are still in the DB and we don't check for existence.
touch data.db
# Source environment variables.
source .env
# Let's run.
./katana-ci
```

## GitHub CI

To setup your action in the GitHub CI, you can check the full example in `.github/workflows/example.yml`, and you also have a test in `examples/e2e.rs` with
all basic actions on a contract with `starknet-rs` -> declare, deploy (which is an invoke with the UDC), call.

Basically, you call the action first to start the katana:
```yml
- name: Startup Katana CI instance
id: katanaci
uses: ArkProjectNFTs/katana-ci-action@v1
with:
api-url: ${{ secrets.KATANA_CI_URL }}
api-key: ${{ secrets.KATANA_CI_KEY }}
cmd: 'start'
```
You can then inject the URL of the spawned instance in your tests, in the example we use environment variable to pass it:
```yml
- name: Run cargo test
uses: actions-rs/cargo@v1
env:
STARKNET_RPC: ${{ steps.katanaci.outputs.katana-rpc }}
with:
command: run
args: --example e2e
```
And then you call it again to stop it:
```yml
- name: Terminate Katana CI instance
uses: ArkProjectNFTs/katana-ci-action@v1
with:
api-url: ${{ secrets.KATANA_CI_URL }}
api-key: ${{ secrets.KATANA_CI_KEY }}
cmd: 'stop'
name: ${{ steps.katanaci.outputs.katana-name }}
```
It can be a good refacto to use `js` actions, in order to leverage the `post` cleanup.

## Usage from the CLI

The idea is to have the least overhead possible to spawn and interact with a Katana instance. So no client is designed for now,
and you can use very common tools like `curl`.

1. Start an instance
```bash
curl -H 'Content-Type: application/json' \
-H 'Authorization: Bearer my-key' \
https://<your_backend_url>/start
curl -H 'Authorization: Bearer mykey' https://<your_backend_url>/start
# Returns a simple string with the name of the created instance.
4f2b3c60ae32
Expand All @@ -35,22 +104,12 @@ and you can use very common tools like `curl`.

3. To check the logs, you can hit the endpoint `/logs` of your instance, by default it returns `25` tail lines. You can use `all` or any number you like using the query parameter `n`.
```bash
curl -H 'Content-Type: application/json' \
-H 'Authorization: Bearer my-key' \
https://<your_backend_url>/<name>/logs
curl -H 'Authorization: Bearer mykey' https://<your_backend_url>/<name>/logs
curl -H 'Content-Type: application/json' \
-H 'Authorization: Bearer my-key' \
https://<your_backend_url>/<name>/logs?n=100
curl -H 'Authorization: Bearer mykey' https://<your_backend_url>/<name>/logs?n=100
```

4. Then, you can stop the instance if it's no longer needed.
```bash
curl -H 'Content-Type: application/json' \
-H 'Authorization: Bearer my-key' \
https://<your_backend_url>/<name>/stop
curl -H 'Authorization: Bearer mykey' https://<your_backend_url>/<name>/stop
```

## GitHub CI

Work in progress.

0 comments on commit 0d8693b

Please sign in to comment.