- Please report any issues you encounter during operations.
- Feel free to create a pull request, preferably with a test or five.
- Clojure 1.11+
- OpenJDK 21
- Node.js 20.x
- Yarn
For testing: Docker Compose
Please refer to the extensive documentation available on the Metabase website: Guide to writing a Metabase driver
Materialize driver's code should be inside the main Metabase repository checkout in modules/drivers/materialize
directory.
The easiest way to set up a development environment is as follows (mostly the same as in the CI):
- Clone Metabase and Materialize driver repositories
git clone https://github.com/metabase/metabase.git
cd metabase
git checkout v0.52.6
git clone https://github.com/MaterializeInc/metabase-materialize-driver.git modules/drivers/materialize
- Create custom Clojure profiles, you can get it using the following command:
cat modules/drivers/materialize/.github/deps.edn | sed -e "s|PWD|$PWD|g" | tr -d '\n'
Modifying ~/.clojure/deps.edn
will create two useful profiles: user/materialize
that adds driver's sources to the classpath, and user/test
that includes all the Metabase tests that are guaranteed to work with the driver.
- Install the Metabase dependencies:
clojure -X:deps:drivers prep
- Build the frontend:
yarn && yarn build-static-viz
- Add
/etc/hosts
entry
Required for TLS tests.
sudo -- sh -c "echo 127.0.0.1 materialize >> /etc/hosts"
- Start Materialize as a Docker container
docker compose -f modules/drivers/materialize/docker-compose.yml up -d materialize
- To use a specific Java version, you can set the
JAVA_HOME
environment variable:
export JAVA_HOME=$(/usr/libexec/java_home -v 21) ; export PATH=$JAVA_HOME/bin:$PATH
Now, you should be able to run the tests:
mz_deps=$(cat modules/drivers/materialize/.github/deps.edn | sed -e "s|PWD|$PWD|g" | tr -d '\n')
DRIVERS=materialize clojure -Sdeps ${mz_deps} -X:dev:drivers:drivers-dev:test:user/materialize
you can see that we have our profiles :user/materialize:user/test
added to the command above, and with DRIVERS=materialize
we instruct Metabase to run the tests only for Materialize.
Note Omitting
DRIVERS
will run the tests for all the built-in database drivers.
If you want to run tests for only a specific test:
mz_deps=$(cat modules/drivers/materialize/.github/deps.edn | sed -e "s|PWD|$PWD|g" | tr -d '\n')
DRIVERS=materialize clojure -Sdeps ${mz_deps} -X:dev:drivers:drivers-dev:test:user/materialize :only metabase.query-processor.middleware.parameters.mbql-test
Some tests are not applicable to Materialize, and you can exclude them by adding the following to the test command:
git apply modules/drivers/materialize/scripts/exclude_tests.diff
The diff file contains the list of tests that are excluded from the Materialize driver. This often needs to be updated as new tests are added to new Metabase versions.
You need to add an entry for Materialize in modules/drivers/deps.edn
{:deps
{...
metabase/materialize {:local/root "materialize"}
...}}
or just run this from the root Metabase directory, overwriting the entire file:
echo "{:deps {metabase/materialize {:local/root \"materialize\" }}}" > modules/drivers/deps.edn
Now, you should be able to build the final jar:
bin/build-driver.sh materialize
As the result, resources/modules/materialize.metabase-driver.jar
should be created. You can copy it to the Metabase plugins
directory and start Metabase.
For smoke testing, there is a Metabase with the link to the driver available as a Docker container:
docker compose -f modules/drivers/materialize/docker-compose.yml up -d metabase
It should pick up the driver jar as a volume.
Once the driver is ready to be released and tests are passing, you need to create a tag in the Metabase repository:
git tag -a vX.Y.Z -m vX.Y.Z
git push origin vX.Y.Z
Once the tag is pushed, the CI will build the driver and create a release including the jar file. You can manually edit the release description to include any additional release notes.