Skip to content

Commit

Permalink
Add a setup for using docker compose to run a local database
Browse files Browse the repository at this point in the history
This will prefer a `DATABASE_URL` if it's set, otherwise, fall back
to checking for a running docker database via docker compose, and
only if that fails, fall back to a system postgres server

This adds `dotenv` to the requirements, to avoid duplicating the
authentication credentials for docker's postgres
  • Loading branch information
cflipse committed Nov 14, 2024
1 parent d707579 commit 0911b00
Show file tree
Hide file tree
Showing 4 changed files with 23 additions and 3 deletions.
4 changes: 4 additions & 0 deletions .postgres.env
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
POSTGRES_USER="rom"
POSTGRES_PASSWORD="password"
POSTGRES_DATABASE="rom_factory"
POSTGRES_HOST_AUTH_METHOD="trust"
2 changes: 2 additions & 0 deletions Gemfile
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ gem "faker", "~> 3.0"

gem "rspec", "~> 3.0"

gem "dotenv"

git "https://github.com/rom-rb/rom.git", branch: "release-5.3" do
gem "rom-core"
gem "rom-changeset"
Expand Down
7 changes: 7 additions & 0 deletions compose.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
services:
db:
image: postgres
ports:
- 5432
env_file: .postgres.env
13 changes: 10 additions & 3 deletions spec/spec_helper.rb
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# frozen_string_literal: true

require_relative "support/coverage"

Check failure on line 2 in spec/spec_helper.rb

View workflow job for this annotation

GitHub Actions / Layout

Layout/EmptyLineAfterMagicComment: Add an empty line after magic comments.
require "dotenv"
Dotenv.load(".postgres.env", ".env")

require "pathname"
SPEC_ROOT = root = Pathname(__FILE__).dirname
Expand All @@ -18,10 +19,16 @@
end

DB_URI = ENV.fetch("DATABASE_URL") do
auth = ENV.values_at("POSTGRES_USER", "POSTGRES_PASSWORD").join(":")
address = `docker compose port db 5432 2> /dev/null`.strip
address = [auth, address].join("@") if address

address ||= "localhost"

if defined? JRUBY_VERSION
"jdbc:postgresql://localhost/rom_factory"
"jdbc:postgresql://#{address}"
else
"postgres://localhost/rom_factory"
"postgres://#{address}"
end
end

Expand Down

0 comments on commit 0911b00

Please sign in to comment.