Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jasperfx/weasel
Database Development Made Easy for .Net
https://github.com/jasperfx/weasel
database mssql postgresql sql
Last synced: 6 days ago
JSON representation
Database Development Made Easy for .Net
- Host: GitHub
- URL: https://github.com/jasperfx/weasel
- Owner: JasperFx
- License: mit
- Created: 2020-05-16T21:37:32.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2025-01-14T17:47:30.000Z (13 days ago)
- Last Synced: 2025-01-15T00:07:34.351Z (13 days ago)
- Topics: database, mssql, postgresql, sql
- Language: C#
- Homepage:
- Size: 1.03 MB
- Stars: 69
- Watchers: 6
- Forks: 23
- Open Issues: 28
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Weasel
[![Nuget Package](https://badgen.net/nuget/v/weasel.core)](https://www.nuget.org/packages/Weasel.Core/)
[![Nuget](https://img.shields.io/nuget/dt/weasel.core)](https://www.nuget.org/packages/Weasel.Core/)Weasel is a library for low level database development with Postgresql and Sql Server. Weasel is in the process of being extracted from [Marten](https://martendb.io) with the goal of making this code reusable in other projects.
Read also more in [Introducing Weasel for Database Development](https://jeremydmiller.com/2023/08/15/introducing-weasel-for-database-development/) by [Jeremy D. Miller](https://github.com/jeremydmiller).
## Support Plans
While Weasel is open source, [JasperFx Software offers paid support and consulting contracts](https://bit.ly/3szhwT2) for Weasel.
## Running tests locally
To run tests, you need to set up databases locally. The easiest option is to do it by running Docker images. You can use [predefined Docker Compose setup](./docker-compose.yml) by calling in your terminal:
```bash
docker compose up
```It'll spin up PostgreSQL and MSSQL databases.
Then, you can run tests from the terminal:
```bash
dotnet test
```Or your favourite IDE.
### Test Config Customization
Some of our tests are run against a particular PostgreSQL version. If you'd like to run different database versions, you can do it by setting `POSTGRES_IMAGE` or `MSSQL_IMAGE` env variables, for instance:
```bash
POSTGRES_IMAGE=postgres:15.3-alpine MSSQL_IMAGE=mcr.microsoft.com/mssql/server:2022-latest docker compose up
```Tests explorer should be able to detect database version automatically, but if it's not able to do it, you can enforce it by setting `postgresql_version` to a specific one (e.g.)
```shell
postgresql_version=15.3
```By default Postgres tests are run with case insensitive names. To run tests against case sensitive, set environment variable:
```
USE_CASE_SENSITIVE_QUALIFIED_NAMES=true
```