graphql-engine/server/src-lib/Hasura/GraphQL/Execute
Brandon Simmons 4d2dbe68fa
Use AssertNF for leak prophylaxis when doing mutable writes. Closes #3937 (#4097)
Writing to a mutable var is a particularly potent source of leaks since
it mostly defeats GHC's analysis. Here we add assertions to all mutable
writes, and fix a couple spots where we wrote some thunks to a mutable
var (compiled with -O2).

Some of these thunks were probably benign, but others looked liked they
might be retaining big args. Didn't do much analysis, just fixed.

Actually pretty happy with how easy this was to use and as a diagnostic,
once I sorted out some issues. We should consider using it elsewhere,
and maybe extending so that we can use it with tests, enable when
`-fenable-assertsions` etc.

Relates #3388

Also simplified codepaths that use `AcceptWith`, which has unnecessary
`Maybe` fields.
2020-03-17 20:31:22 -05:00
..
LiveQuery Use AssertNF for leak prophylaxis when doing mutable writes. Closes #3937 (#4097) 2020-03-17 20:31:22 -05:00
LiveQuery.hs Parameterize all SQL values when multiplexing subscription queries (#2942) 2019-09-30 14:50:57 -05:00
Plan.hs allow specifying an upper limit on the query plan cache size (#3012) 2019-11-25 11:12:23 -06:00
Query.hs refactor some internal components (#3414) 2019-11-26 17:44:21 +05:30