Full contribution guidelines
Contributing
Section titled “Contributing”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:
Submitting bug report
Section titled “ Submitting bug report”To report a bug or issue, please use our issue form “Bug: ”.
Submitting feature request
Section titled “ Submitting feature request”To request a feature, please use our issue form and start the title with “Feature Request: ”.
Providing feedback
Section titled “ Providing feedback”There are several ways you can provide feedback:
- You can add new ticket in Discussions.
- Mention me on BlueSky - @cliftonc.nl.
Contribution guidelines
Section titled “ Contribution guidelines”- Pre-contribution setup
- Commit message guidelines
- Contributing to the core library
- Contributing to examples
Pre-contribution setup
Section titled “ Pre-contribution setup”Installing Node via NVM (if needed)
Section titled “ Installing Node via NVM (if needed)”# https://github.com/nvm-sh/nvm#install--update-scriptcurl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.1/install.sh | bashnvm install 22nvm use 22Installing npm
Section titled “ Installing npm”Node.js comes with npm by default. We use npm for package management.
Installing Docker
Section titled “ Installing Docker”# https://docs.docker.com/get-docker/# Use Docker's guide to install Docker for your OS.Cloning the repository
Section titled “ Cloning the repository”git clone https://github.com/cliftonc/drizzle-cube.gitcd drizzle-cubeRepository structure
Section titled “ Repository structure”-
📂
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 exampledrizzle-cube-fastify/- Fastify exampledrizzle-cube-hono/- Hono exampledrizzle-cube-nextjs/- Next.js exampledrizzle-cube-try-site/- Interactive sandboxdrizzle-cube-help-site/- Main documentation site
Building the project
Section titled “ Building the project”Run the following script from the root folder to build the project:
npm install && npm run buildSetting up for development
Section titled “Setting up for development”The dev environment uses its own PostgreSQL instance (separate from test databases):
npm run dev:setup # Starts dev PostgreSQL (port 54821), runs migrations, seeds sample datanpm run dev # Starts concurrent dev servers (server + client with HMR)To tear down the dev database:
npm run dev:db:downSetting up for testing
Section titled “Setting up for testing”Tests require Docker for PostgreSQL and MySQL. SQLite and DuckDB use in-memory databases and don’t need Docker.
npm run test:setup # Starts test PostgreSQL (port 54333) and MySQL (port 33077) via Dockernpm test # Run all tests (default: PostgreSQL)npm run test:teardown # Stop and remove test database containers[!TIP] The dev server and test databases use completely separate Docker containers and ports, so you can run
npm run devandnpm testat the same time. This is useful for observing your changes in the browser while verifying they pass tests.
Commit message guidelines
Section titled “ Commit message guidelines”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 columnsfor more flexible analytics queries[!WARNING] All commits should be signed before submitting a PR. Please check the documentation on how to sign commits.
Contributing to the core library
Section titled “ Contributing to the core library”Project structure
Section titled “ Project structure”-
📂
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
Running tests
Section titled “ Running tests”Drizzle Cube has integration tests that run against real databases with different queries and responses. Tests use Docker containers for PostgreSQL and MySQL, and in-memory databases for SQLite and DuckDB.
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:
npm run test:setup # Starts PostgreSQL (port 54333) and MySQL (port 33077)Run server tests (semantic layer, executors, query planning):
# PostgreSQL (default)npm run test:postgres
# MySQLnpm run test:mysql
# SQLite (no Docker needed)npm run test:sqlite
# DuckDB (no Docker needed)npm run test:duckdb
# All databases sequentiallynpm run test:allRun client tests (React components, hooks, stores):
npm run test:clientRun all tests (server + client):
npm testWatch mode:
npm run test:watch # All testsnpm run test:server:watch # Server tests onlynpm run test:client:watch # Client tests onlyCoverage reports:
npm run test:coverage # Server coverage (default DB)npm run test:client:coverage # Client coveragenpm run test:coverage:all # Server coverage across all databasesnpm run test:coverage:complete # Full coverage (all server DBs + client)Teardown test databases:
npm run test:teardown # Stop and remove Docker containersEnvironment variables:
| Variable | Default | Description |
|---|---|---|
TEST_DB_TYPE | postgres | Database to test against (postgres, mysql, sqlite, duckdb) |
TEST_DATABASE_URL | postgresql://test:test@localhost:54333/drizzle_cube_test | PostgreSQL connection URL |
MYSQL_TEST_DATABASE_URL | mysql://test:test@localhost:33077/drizzle_cube_test | MySQL connection URL |
[!WARNING] All test database URLs must contain “test” as a safety check to prevent accidental use against production databases.
PR guidelines
Section titled “ PR guidelines”-
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 -
PRs should contain a detailed description of everything that was changed.
-
Commit messages should follow the message style guidelines.
-
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.
Contributing to examples
Section titled “ Contributing to examples”Example projects are located in separate github repositories and follow the same contribution guidelines:
- drizzle-cube-express - Express.js with React dashboard
- drizzle-cube-fastify - Fastify with React dashboard
- drizzle-cube-hono - Hono with React dashboard
- drizzle-cube-nextjs - Next.js full-stack application
When contributing to examples:
- Ensure examples use the latest version of the core library
- Update documentation if adding new features to examples
- Test examples work with multiple databases where applicable
- Keep examples simple and focused on demonstrating specific features
Development Workflow
Section titled “Development Workflow”- Fork and clone the repository
- Create a branch for your feature/fix
- Set up development environment:
Terminal window npm installnpm run buildnpm run test:setup # Start test database containers (PostgreSQL + MySQL)npm run dev:setup # Start dev database, run migrations, seed sample data - Start development servers:
Terminal window npm run dev # Server + client with HMR - Make your changes with appropriate tests
- Run the test suite:
Terminal window npm run typechecknpm run lintnpm test # Server + client tests - Create a pull request with a clear description
Architecture Guidelines
Section titled “Architecture Guidelines”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
Adding a New Chart Type: Chart types are used inside the AnalysisBuilder component. When adding a new chart type, verify it works end-to-end within the AnalysisBuilder — select it from the chart type picker, configure axes via the chart config panel, and confirm it renders correctly with real query results. See src/client/CLAUDE.md for the full registration steps (chart config, lazy loading, ChartLoader).
Getting Help
Section titled “Getting Help”- 📖 Check the documentation
- 🐛 Search existing issues
- 💬 Start a discussion
Thank you for contributing to Drizzle Cube! 🐲