Build Status Join the chat at https://gitter.im/crecto/Lobby
Robust database wrapper for Crystal. Inspired by Ecto for Elixir language.
With built in query composer, associations, transactions, validations, constraints, and more.
Website with guides and examples - https://www.crecto.dev/
user = User.new user.name = "Shakira" changeset = Repo.insert(user) changeset.errors.any? inserted_user = changeset.instance inserted_user.name = "Keanu" changeset = Repo.update(user) changeset.errors.any? updated_user = changeset.instance changeset = Repo.delete(updated_user)
New website and API docs coming soon!
Specs are located in the spec
directory. Since this is an ORM, running specs requires a database connection.
The project comes pre-configured with SQLite support. Simply run:
crystal spec
This will create a local SQLite database (./crecto_test.db
) and run all 223 tests.
To test with PostgreSQL or MySQL:
-
Copy the example configuration:
cp spec/repo.example.cr spec/repo.cr
-
Edit
spec/repo.cr
to uncomment and configure your preferred database:# For PostgreSQL: config do |conf| conf.adapter = Crecto::Adapters::Postgres conf.uri = "postgres://localhost/crecto_test" end # For MySQL: config do |conf| conf.adapter = Crecto::Adapters::MySQL conf.uri = "mysql://localhost/crecto_test" end
-
Run the tests:
crystal spec
To test all three supported database types using Docker:
docker-compose up
This will start PostgreSQL and MySQL containers and run the test suite against all database adapters.
The database must exist prior to testing. Migrations for each database type are available in spec/migrations/
.
When contributing, please test against all supported databases before submitting a pull request.
- Fork it ( https://github.com/Crecto/crecto/fork )
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
When developing against crecto, the database must exist prior to
testing. There are migrations for each database type in spec/migrations
,
and references on how to migrate then in the .travis.yml
file.
Create a new file spec/repo.cr
and create a module name Repo
to use for testing.
There are example repos for each database type in the spec folder: travis_pg_repo.cr
,
travis_mysql_repo.cr
, and travis_sqlite_repo.cr
When submitting a pull request, please test against all 3 databases.