Skip to content

Linter that confirms that DB rows and stats are closed properly.

License

Notifications You must be signed in to change notification settings

instruqt/sqlclosecheck

 
 

Repository files navigation

sqlclosecheck

Linter that checks if SQL rows/statements are closed. Unclosed rows and statements may cause DB connection pool exhaustion. Included in golangci-lint as sqlclosecheck.

Analyzers

  • defer-only - require that Close be deferred
  • closed - require that Close be called (EXPERIMENTAL)

Running

make build
make install

In your project directory:

go vet -vettool=$(which sqlclosecheck) ./...

Developers

Start by creating a test that should pass/fail. Test are located at pkg/analyzer/testdata. All PRs that modify the analyzer should include a test. Negative tests are just as important as positive tests.

Make changes to the analyzer (pkg/analyzer) and run the tests:

make test

CI

GitHub Actions that runs on push to main and PRs.

About

Linter that confirms that DB rows and stats are closed properly.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 91.2%
  • Makefile 8.8%