package sihl
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=49fe887d05083b37523cd6e7ca35239822c561fe7109dd383c30aeb4259a7b98
sha512=4135ad42a75fb9adc3e853a466b696d9ee6d7a9d8acf0cee9fd5f5485679a517f524ce704e2d153df4a7c4f1d14df9f94ab2a8fbe5b36e744b505daab1d40f3d
doc/sihl.data/Data/Repo/index.html
Module Data.Repo
Source
The repository service deals with cleaning repositories. This is useful for integration tests.
Installation
Use the provided Sihl.Data.Repo.Service.Make
to instantiate a repo service.
module Repo = Sihl.Data.Repo.Service.Make ()
Usage
You typically want to use the repo service in your own repositories in order to register repository cleaners. This allows Sihl to reset the state of your system after integration tests.
{ let cleaner = ... in Repo.register_cleaer cleaner; }
In order to clean all repositories that have registered cleaners you can call clean_all
:
{ open Lwt.Syntax let* () = Repo.clean_all ctx in .. }
Repositories can return meta data containing information like total rows affected. This can be useful for pagination.
This module can be used to assemble dynamic repository queries. This is typically used if you don't know the number of parameters at compile time because they are provided by the user, for instance as a filter or sort. http://paurkedal.github.io/ocaml-caqti/caqti/Caqti_request/index.html#how-to-dynamically-assemble-queries-and-parameters