Skip to content

Full contribution guidelines

Welcome! We’re glad you’re interested in Drizzle Cube and want to help us make it better.

Drizzle Cube is maintained by Clifton Cunningham and community contributors. All contributions are reviewed and approved by the maintainer.


There are many ways you can contribute to the Drizzle Cube project:

To report a bug or issue, please use our issue form “Bug: ”.

To request a feature, please use our issue form and start the title with “Feature Request: ”.

There are several ways you can provide feedback:

Terminal window
# https://github.com/nvm-sh/nvm#install--update-script
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.1/install.sh | bash
nvm install 22
nvm use 22

Node.js comes with npm by default. We use npm for package management.

Terminal window
# https://docs.docker.com/get-docker/
# Use Docker's guide to install Docker for your OS.
Terminal window
git clone https://github.com/cliftonc/drizzle-cube.git
cd drizzle-cube
  • 📂 src/

    Core library source code

    • 📂 server/ - Server-side semantic layer implementation
    • 📂 client/ - React components and hooks for analytics UI
    • 📂 adapters/ - Framework adapters (Hono, Express, Fastify, Next.js)
  • 📂 tests/

    Comprehensive test suite with multi-database support

  • 📂 dev/

    Development environment with example implementation, so you can test your changes with HMR.

  • 📂 docs/

    Documentation and implementation plans when using tools like Claude Code (we encourage this).

  • 📂 ../drizzle-cube-*/

    Example projects demonstrating different framework integrations are in separate github repositories.

    • drizzle-cube-express/ - Express.js example
    • drizzle-cube-fastify/ - Fastify example
    • drizzle-cube-hono/ - Hono example
    • drizzle-cube-nextjs/ - Next.js example
    • drizzle-cube-try-site/ - Interactive sandbox
    • drizzle-cube-help-site/ - Main documentation site

Run the following script from the root folder to build the project:

Terminal window
npm install && npm run build

To setup postgres and seed with sample data:

npm run dev:setup

Then for development

Terminal window
npm run dev

Then to run the tests (default uses Postgres):

Terminal window
npm t

We have specific rules on how commit messages should be structured.

It’s important to make sure your commit messages are clear, concise, and informative to make it easier for others to understand the changes you are making.

All commit messages should follow the pattern below:

<subject>
<BLANK LINE>
<body>

Example:

Add PostgreSQL array support to measures
Enables aggregation functions on PostgreSQL array columns
for more flexible analytics queries

[!WARNING] All commits should be signed before submitting a PR. Please check the documentation on how to sign commits.

  • 📂 src/server/

    Server-side semantic layer with type-safe query building, SQL generation, and security

  • 📂 src/client/

    React components, hooks, and utilities for building analytics dashboards

  • 📂 src/adapters/

    Framework-specific adapters that integrate the semantic layer with web frameworks

All tests for Drizzle Cube are integration tests that simulate real databases with different queries and responses. Each test file covers different scenarios for different dialects and drivers. Tests create Docker containers with the needed databases and run test cases there. After every test is run, the Docker container is deleted.

If you have added additional logic to the core library, make sure that all tests complete without any failures.

[!NOTE] If you have added data types, query features, or new functionality, you need to create additional test cases using the new API to ensure it works properly.

Setup test databases via docker:

Terminal window
npm run test:setup

Run default postgres tests:

Terminal window
npm test

Run database-specific tests:

Terminal window
# PostgreSQL (default)
npm run test:postgres
# MySQL
npm run test:mysql
# SQLite
npm run test:sqlite
# All databases
npm run test:all

Run tests in watch mode:

Terminal window
npm run test:watch

Teardown test databases:

Terminal window
npm run test:teardown
  1. PR titles should follow the pattern below:

    [<area>]: <subject>

    Examples:

    [Server] Add MySQL JSON field support
    [Client] Improve chart type selection UX
    [Adapters] Add Fastify CORS configuration
  2. PRs should contain a detailed description of everything that was changed.

  3. Commit messages should follow the message style guidelines.

  4. PRs should implement:

    • Tests for features that were added.
    • Tests for bugs that were fixed.
    • Type checking with npm run typecheck
    • Linting with npm run lint

[!NOTE] To understand how tests should be created and run, please check the Running tests section.

Example projects are located in separate github repositories and follow the same contribution guidelines:

When contributing to examples:

  1. Ensure examples use the latest version of the core library
  2. Update documentation if adding new features to examples
  3. Test examples work with multiple databases where applicable
  4. Keep examples simple and focused on demonstrating specific features
  1. Fork and clone the repository
  2. Create a branch for your feature/fix
  3. Set up development environment:
    Terminal window
    npm install
    npm run dev:setup # Sets up dev database
  4. Make your changes with appropriate tests
  5. Run the test suite:
    Terminal window
    npm run typecheck
    npm run lint
    npm run test:all
  6. Create a pull request with a clear description

Drizzle-First Design: This project is built around Drizzle ORM as the core:

  • All SQL generation must use Drizzle query builder
  • Never use string concatenation for SQL
  • All database operations go through Drizzle
  • Type safety is enforced through Drizzle schema definitions

Security: SQL injection prevention is paramount:

  • Use parameterized queries only
  • Leverage Drizzle’s type safety
  • Include security context in all cube definitions
  • Test multi-tenant isolation

Thank you for contributing to Drizzle Cube! 🐲