chore: Initial database scaffolding (#2)

* chore: Initial database scaffolding

This implements migrations and code generation for interfacing with a PostgreSQL database.

A dependency is added for the "postgres" binary on the host, but that seems like an acceptable requirement considering it's our primary database.

An in-memory database object can be created for simple cross-OS and fast testing.

* Run tests in CI

* Use Docker instead of binaries on the host

* Skip database tests on non-Linux operating systems

* chore: Add golangci-lint and codecov

* Use consistent file names
This commit is contained in:
Kyle Carberry
2022-01-05 09:20:56 -06:00
committed by GitHub
parent a6b2dd76a0
commit 025b55f7be
23 changed files with 2017 additions and 4 deletions

17
database/query.sql.go Normal file
View File

@ -0,0 +1,17 @@
// Code generated by sqlc. DO NOT EDIT.
// source: query.sql
package database
import (
"context"
)
const exampleQuery = `-- name: ExampleQuery :exec
SELECT 'example query'
`
func (q *sqlQuerier) ExampleQuery(ctx context.Context) error {
_, err := q.db.ExecContext(ctx, exampleQuery)
return err
}