{"id":29119987,"url":"https://github.com/dcramer/vitest-drizzle-postgres","last_synced_at":"2025-08-27T01:54:48.414Z","repository":{"id":297413510,"uuid":"991719964","full_name":"dcramer/vitest-drizzle-postgres","owner":"dcramer","description":null,"archived":false,"fork":false,"pushed_at":"2025-05-28T06:49:29.000Z","size":84,"stargazers_count":3,"open_issues_count":0,"forks_count":1,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-06-29T11:49:18.014Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/dcramer.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2025-05-28T03:57:38.000Z","updated_at":"2025-05-28T20:41:43.000Z","dependencies_parsed_at":"2025-06-05T10:54:55.870Z","dependency_job_id":"afca58a0-2bfc-4320-b638-51755367c950","html_url":"https://github.com/dcramer/vitest-drizzle-postgres","commit_stats":null,"previous_names":["dcramer/vitest-drizzle-postgres"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/dcramer/vitest-drizzle-postgres","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dcramer%2Fvitest-drizzle-postgres","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dcramer%2Fvitest-drizzle-postgres/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dcramer%2Fvitest-drizzle-postgres/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dcramer%2Fvitest-drizzle-postgres/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/dcramer","download_url":"https://codeload.github.com/dcramer/vitest-drizzle-postgres/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dcramer%2Fvitest-drizzle-postgres/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":262605511,"owners_count":23335881,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-06-29T14:05:42.411Z","updated_at":"2025-06-29T14:05:47.245Z","avatar_url":"https://github.com/dcramer.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# vitest-drizzle-postgres\n\nVitest + Drizzle.\n\n## Quick Start\n\n```bash\nnpm install vitest-drizzle-postgres\n```\n\n```typescript\n// vitest.setup.ts\n/// \u003creference types=\"vitest-drizzle-postgres/types\" /\u003e\n\nimport { setupTestDb, useTestDb, cleanupTestDb, teardownTestDb } from 'vitest-drizzle-postgres';\nimport { beforeAll, beforeEach, afterEach } from 'vitest';\n\nimport { db } from './src/db'; // Your existing database connection\nimport * as schema from './src/schema';\n\nbeforeAll(async () =\u003e {\n  await setupTestDb({\n    schema,\n    db,\n    migrationsFolder: \"./migrations\", // optional\n  });\n\n  return async () =\u003e {\n    await teardownTestDb();\n  }\n});\n\nbeforeEach(async (ctx) =\u003e {\n  await useTestDb(ctx);\n\n  return async () =\u003e {\n    await cleanupTestDb();\n  };\n});\n```\n\n```typescript\n// user.test.ts\nimport { describe, test, expect } from 'vitest';\nimport { users } from './schema';\n\nimport { db } from './src/db'; // Your existing database connection\n\ndescribe('User tests', () =\u003e {\n  test('should create and find user', async () =\u003e {\n    const [user] = await db\n      .insert(users)\n      .values({ name: 'John', email: 'john@example.com' })\n      .returning();\n\n    expect(user.name).toBe('John');\n    \n    const foundUsers = await db.select().from(users);\n    expect(foundUsers).toHaveLength(1);\n  });\n\n  test('should not see data from previous test', async () =\u003e {\n    const users = await db.select().from(users);\n    expect(users).toHaveLength(0); // Clean slate\n  });\n});\n```\n\n## Features\n\n- Uses PostgreSQL savepoints for fast test isolation\n- Schema change detection and caching\n- Works with your existing Drizzle database connection\n- Supports both savepoint and truncate modes\n- Minimal setup required\n\n## Packages\n\n- `packages/vitest-drizzle-postgres` - Core library\n- `packages/vitest-drizzle-postgres-tests` - Test suite\n\n## Development\n\nThis is a pnpm monorepo with Turborepo for build orchestration:\n\n- `packages/vitest-drizzle-postgres` - Core library\n- `packages/vitest-drizzle-postgres-tests` - Test suite\n\n```bash\npnpm install\npnpm build\npnpm test\n```\n\n## Publishing\n\nThis project uses [Changesets](https://github.com/changesets/changesets) for version management and publishing. See [PUBLISHING.md](./PUBLISHING.md) for detailed instructions.\n\nQuick workflow:\n\n```bash\npnpm changeset              # Create a changeset\npnpm changeset:version      # Update versions\npnpm changeset:publish      # Publish to npm\n```\n\nSee individual package READMEs for detailed documentation. \n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdcramer%2Fvitest-drizzle-postgres","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdcramer%2Fvitest-drizzle-postgres","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdcramer%2Fvitest-drizzle-postgres/lists"}