First, please fork this repo and commit your changes to the forked repo. From there make a Pull Request with your notebook submission keeping the following in mind:
First, you should check whether this notebook can be run using a Free Shared Tier instance. This is ideal for scenarios requiring few tables (<10), pipelines (<10) and less than 1GB of compressed storage. See the limitations to determine if your notebook can be run on a Free Shared Tier database.
If your database can be run using the Free Shared Tier (Starter Workspace), you must:
- Mention this using a Markdown cell at the top of the notebook. See example. You should explicitly state that this notebook can run on both the Starter and Standard Workspaces.
- Add "starter" to the tags in the meta.toml file below.
- Use the following syntax when creating OR dropping your database. NOTE: When you create a Starter Workspace, a database is automatically created for it. Starter Workspaces are limited to one database. The only way you can drop the auto-created database linked to the Starter Workspace is by terminating the Workspace altogether.
shared_tier_check = %sql show variables like 'is_shared_tier'
if not shared_tier_check or shared_tier_check[0][1] == 'OFF':
%sql DROP DATABASE IF EXISTS your_database_name;
%sql CREATE DATABASE your_database_name
- At the end of the notebook, you should do the same check when cleaning up any databases created.
shared_tier_check = %sql show variables like 'is_shared_tier'
if not shared_tier_check or shared_tier_check[0][1] == 'OFF':
%sql DROP DATABASE IF EXISTS your_database_name;
If your database can only be run using Standard workspaces, you must:
- Mention this using a Markdown cell at the top of the notebook. See example. You should explicitly state that this notebook can run only on Standard Workspaces.
- Add "advanced" to the tags in the meta.toml file below.
To add a new space you should create a new folder inside /notebooks
.
Here are some requirements for the file structure:
- Folder name must use
kebab-case
- Folder must contain a Jupyter Notebook called
notebook.ipynb
- Folder must contain a
meta.toml
file which holds information about your SingleStore Space. See below for the structure of this file.
Your meta.toml
file should have a [meta]
section with the following keys:
- title: string
- description: string (optional)
- difficulty: "beginner", "intermediate" or "advanced"
- tags: string[] (optional)
- icon: string. You don't need to reference the extension. See full list of icon names here
- destinations: list of strings. For now set it to ["spaces"].
- minimum_tier: If this notebook can be run on our free shared tier, please use "free-shared". Else use "standard"
Example:
[meta]
title="Atlas & Kai for Mongo Side-by-Side"
description="Compare performance on same code from simple to more complex queries"
difficulty="beginner"
tags=["mongodb", "kai"]
destinations=["spaces"]
icon="database"
minimum_tier="free-shared"
The CI pipeline in this repo runs a bunch of validation checks and code reformatting with pre-commit checks. If you don't install those checks in your clone of the repo, the code will likely never pass. To install the pre-commit tool in your clone run the following from your clone directory. This will force the checks before you can push.
You will need to develop your notebooks using Python 3.11 or higher. By default, Notebooks developed on SingleStore will be using this version of Python. This is required for the pre-commit checks to run:
pip3 install pre-commit==3.7.1
pre-commit install
The checks run automatically when you attempt to commit, but you can run them manually as well with the following:
pre-commit run --all-files