Thanks for your interest in contributing to Omi! We very much look forward to your suggestions, bug reports, and pull requests.
Have a look at our issue tracker. If you can't find an issue (open or closed) describing your problem (or a very similar one) there, please open a new issue with the following details:
- Which versions of Rust and Omi are you using?
- Which feature flags are you using?
- What are you trying to accomplish?
- What is the full error you are seeing?
- How can we reproduce this?
- Please quote as much of your code as needed to reproduce (best link to a public repository or Gist)
- Please post as much of your database schema as is relevant to your error
Thank you! We'll try to respond as quickly as possible.
Omi's issue tracker is meant to represent our current roadmap. An open issue represents either a bug, or a new feature that a member of the Omi team is actively working on.
This means that you should not submit a feature request to our issue tracker, unless you were asked to do so by a member of the Omi team. Feature requests should instead be posted in our discussion forum.
If you can't find thread describing your idea on our forum, create a new one. Adding answers to the following questions in your description is +1:
- What do you want to do, and how do you expect Omi to support you with that?
- How might this be added to Omi?
- What are possible alternatives?
- Are there any disadvantages?
Thank you! We'll try to respond as quickly as possible.
-
Install Rust using rustup, which allows you to easily switch between Rust versions. Omi currently supports Rust Stable, Nightly, Rust Beta.
-
Install the system libraries needed to interface with the database systems you wish to use.
These are the same as when compiling Omi. It's generally a good idea to install all drivers so you can run all tests locally.
Shortcut: On macOS, you don't need to install anything to work with SQLite. For PostgreSQL, you'll only need the server (
libpq
is installed by default). To get started,brew install postgresql mysql
and follow the instructions shown to set up the database servers. -
Clone this repository and open it in your favorite editor.
-
Create a
.env
file in this directory, and add the connection details for your databases.Additional note: The MySQL tests currently fail when running on MySQL 5.6 or lower. If you have 5.6 or lower installed locally and cannot upgrade for some reason, you may want to consider setting up Docker as mentioned below.
See .env.sample for an example that works with a trivial local setup.
Note: If you didn't specify the MySQL user to be one with elevated permissions, you'll want to run a command like
mysql -c "GRANT ALL ON `omi_%`.* TO ''@'localhost';" -uroot
, or something similar for the user that you've specified.If you have Docker, the following snippet might help you to get Postgres and MySQL running (with the above
.env
file):#!/usr/bin/env sh set -e docker run -d --name omi.mysql -p 3306:3306 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql while sleep 1; ! echo 'CREATE DATABASE omi_test; CREATE DATABASE omi_unit_test;' | docker exec -i omi.mysql mysql do sleep 1; done docker run -d --name omi.postgres -p 5432:5432 -e POSTGRES_PASSWORD=postgres postgres while sleep 1; ! echo 'CREATE DATABASE omi_test;' | docker exec -i omi.postgres psql -U postgres do :; done
If you want to use docker-compose, you can execute docker-compose command like this.
$ docker-compose up
-
Now, try running the test suite to confirm everything works for you locally by executing
Cargo test
. (Initially, this will take a while to compile everything.)
We follow the Rust Style Guide, enforced using rustfmt.
To run rustfmt tests locally:
-
Use rustup to set rust toolchain to the version specified in the rust-toolchain file.
-
Install the rustfmt and clippy by running
rustup component add rustfmt-preview rustup component add clippy-preview
-
Run clippy using cargo from the root of your omi repo.
cargo clippy --all
Each PR needs to compile without warning.
-
Run rustfmt using cargo from the root of your omi repo.
To see changes that need to be made, run
cargo fmt --all -- --check
If all code is properly formatted (e.g. if you have not made any changes), this should run without error or output. If your code needs to be reformatted, you will see a diff between your code and properly formatted code. If you see code here that you didn't make any changes to then you are probably running the wrong version of rustfmt. Once you are ready to apply the formatting changes, run
cargo fmt --all
You won't see any output, but all your files will be corrected.
You can also use rustfmt to make corrections or highlight issues in your editor. Check out their README for details.