Page MenuHomeDevCentral

Don't require PostgreSQL schema at build time
ClosedPublic

Authored by dereckson on Jan 18 2023, 20:24.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Dec 11, 02:21
Unknown Object (File)
Mon, Dec 9, 21:53
Unknown Object (File)
Mon, Dec 9, 10:44
Unknown Object (File)
Sun, Dec 8, 11:06
Unknown Object (File)
Sun, Dec 8, 01:50
Unknown Object (File)
Sat, Dec 7, 19:22
Unknown Object (File)
Wed, Dec 4, 08:45
Unknown Object (File)
Tue, Dec 3, 06:39
Subscribers
None

Details

Summary

The sqlx crate offers macros like sqlx::query_as! to validate
the query at build time and infer from the table column the return type.

If it's convenient, it requires a PostgreSQL view (or table) fantoir
to exists when building fantoir-datasource. This is a chichen egg issue,
as the tool is intended to prepare the schema too with -c flags.

This change switches from sqlx::query_as! to sqlx_query_as
and sqlx_query_scalar, without his requirement.

Note we lost the validation against SQL schema by the sqlx macros
as a trade-off.

Ref T1750.

Test Plan

Call the service from CLI:

  • fantoir-datasource query chaos
  • `fantoir-datasource query --code-insee 77246 --code-voie B015

Diff Detail

Repository
rDS Nasqueron Datasources
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

dereckson created this revision.
dereckson retitled this revision from Improve query service not to require pgsql at build time to Don't require PostgreSQL schema at build time.Jan 18 2023, 20:25
dereckson edited the test plan for this revision. (Show Details)
dereckson added a reviewer: dereckson.
dereckson edited the test plan for this revision. (Show Details)

Simplify

This revision is now accepted and ready to land.Jan 18 2023, 23:21