Testing Your Database
To ensure that queries return the expected data, RLS policies are correctly applied and etc., we encourage you to write automated tests. There are essentially two approaches to testing:
- 
Firstly, you can write tests that interface with a Supabase client instance (same way you use Supabase client in your application code) in the programming language(s) you use in your application and using your favorite testing framework. 
- 
Secondly, you can test through the Supabase CLI, which is a more low-level approach where you write tests in SQL. 
Testing using the Supabase CLI
You can use the Supabase CLI to test your database. The minimum required version of the CLI is v1.11.4. To get started:
- Install the Supabase CLI on your local machine
Creating a test
Create a tests folder inside the supabase folder:
1mkdir -p ./supabase/tests/databaseCreate a new file with the .sql extension which will contain the test.
1touch ./supabase/tests/database/hello_world.test.sqlWriting tests
All sql files use pgTAP as the test runner.
Let's write a simple test to check that our auth.users table has an ID column. Open hello_world.test.sql and add the following code:
123456789101112begin;select plan(1); -- only one statement to runSELECT has_column(    'auth',    'users',    'id',    'id should exist');select * from finish();rollback;Running tests
To run the test, you can use:
1supabase test dbThis will produce the following output:
12345$ supabase test dbsupabase/tests/database/hello_world.test.sql .. okAll tests successful.Files=1, Tests=1,  1 wallclock secs ( 0.01 usr  0.00 sys +  0.04 cusr  0.02 csys =  0.07 CPU)Result: PASS