sqldef-rails 0.1.0 → 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +7 -0
- data/README.md +42 -1
- data/lib/sqldef/rails/tasks/sqldef.rake +3 -3
- data/lib/sqldef/rails/version.rb +1 -1
- data/lib/sqldef/rails.rb +14 -0
- metadata +4 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: da03c8c4850ca52ac66618b69afd3c546dfdd8e60a7c96a5d3bb95138d2b4d26
|
4
|
+
data.tar.gz: 8ba2d8ebab8bdb16a0e4c10b388d86177f9320f909edb17d47d09333d5bdc83f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: aacc8b25e4316708e86a319aaa20ca83e81c78f53d244e41fa13b90e5f924b7d0c07d23c67b7dee48a9cf664c4f1d66abcfb89d3e6500a4938e0170cb866ac03
|
7
|
+
data.tar.gz: 29abdebd2754214f94bbef3c10479c56f53b79d7f0f7b3f05a66f8cae2ed849a6245f74e3263bb4fc862a915605e7fbeba3eb5c533793d4e99ea1c411f91ae70
|
data/CHANGELOG.md
ADDED
data/README.md
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
# sqldef-rails
|
2
2
|
|
3
|
-
Run [sqldef](https://github.com/k0kubun/sqldef)
|
3
|
+
Run [sqldef](https://github.com/k0kubun/sqldef) on Rails.
|
4
4
|
|
5
5
|
## Installation
|
6
6
|
|
@@ -9,6 +9,47 @@ gem 'sqldef-rails'
|
|
9
9
|
```
|
10
10
|
|
11
11
|
## Usage
|
12
|
+
### Configuration
|
13
|
+
|
14
|
+
Just configure `config/database.yml` normally.
|
15
|
+
|
16
|
+
```yml
|
17
|
+
default: &default
|
18
|
+
adapter: postgresql
|
19
|
+
username: postgres
|
20
|
+
password:
|
21
|
+
host: 127.0.0.1
|
22
|
+
|
23
|
+
development:
|
24
|
+
<<: *default
|
25
|
+
database: sqldef_development
|
26
|
+
|
27
|
+
test:
|
28
|
+
<<: *default
|
29
|
+
database: sqldef_test
|
30
|
+
```
|
31
|
+
|
32
|
+
### Export
|
33
|
+
|
34
|
+
Dump the current schema to `db/schema.sql`.
|
35
|
+
|
36
|
+
```bash
|
37
|
+
bundle exec rake db:schema:dump
|
38
|
+
```
|
39
|
+
|
40
|
+
You may use `bin/rails` instead of `bundle exec rake` too.
|
41
|
+
|
42
|
+
### Dry Run
|
43
|
+
|
44
|
+
You can show DDLs to be executed to match `db/schema.sql`.
|
45
|
+
|
46
|
+
```bash
|
47
|
+
bundle exec rake db:migrate:status
|
48
|
+
```
|
49
|
+
|
50
|
+
### Aplly
|
51
|
+
|
52
|
+
You can run DDLs to match `db/schema.sql`.
|
12
53
|
|
13
54
|
```bash
|
14
55
|
bundle exec rake db:migrate
|
@@ -9,7 +9,7 @@ namespace :sqldef do
|
|
9
9
|
|
10
10
|
desc 'Export the database'
|
11
11
|
task export: [:environment] do
|
12
|
-
database = Rails.
|
12
|
+
database = Sqldef::Rails.database_config
|
13
13
|
Sqldef.export(
|
14
14
|
host: database.fetch(:host),
|
15
15
|
port: database[:port],
|
@@ -23,7 +23,7 @@ namespace :sqldef do
|
|
23
23
|
|
24
24
|
desc 'Dry-run the database'
|
25
25
|
task 'dry-run': [:environment] do
|
26
|
-
database = Rails.
|
26
|
+
database = Sqldef::Rails.database_config
|
27
27
|
Sqldef.dry_run(
|
28
28
|
host: database.fetch(:host),
|
29
29
|
port: database[:port],
|
@@ -37,7 +37,7 @@ namespace :sqldef do
|
|
37
37
|
|
38
38
|
desc 'Apply the database'
|
39
39
|
task apply: [:environment] do
|
40
|
-
database = Rails.
|
40
|
+
database = Sqldef::Rails.database_config
|
41
41
|
Sqldef.apply(
|
42
42
|
host: database.fetch(:host),
|
43
43
|
port: database[:port],
|
data/lib/sqldef/rails/version.rb
CHANGED
data/lib/sqldef/rails.rb
CHANGED
@@ -2,3 +2,17 @@
|
|
2
2
|
require 'sqldef'
|
3
3
|
require 'sqldef/rails/version'
|
4
4
|
require 'sqldef/rails/railtie'
|
5
|
+
|
6
|
+
module Sqldef
|
7
|
+
module Rails
|
8
|
+
def self.database_config
|
9
|
+
database = ::Rails.application.config_for(:database)
|
10
|
+
if ENV.key?('DATABASE_URL')
|
11
|
+
database = database.merge(
|
12
|
+
ActiveRecord::DatabaseConfigurations::ConnectionUrlResolver.new(ENV['DATABASE_URL']).to_hash
|
13
|
+
)
|
14
|
+
end
|
15
|
+
database
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sqldef-rails
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Takashi Kokubun
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2022-03-09 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: sqldef
|
@@ -33,6 +33,7 @@ extra_rdoc_files: []
|
|
33
33
|
files:
|
34
34
|
- ".github/workflows/main.yml"
|
35
35
|
- ".gitignore"
|
36
|
+
- CHANGELOG.md
|
36
37
|
- Gemfile
|
37
38
|
- LICENSE.txt
|
38
39
|
- README.md
|
@@ -66,7 +67,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
66
67
|
- !ruby/object:Gem::Version
|
67
68
|
version: '0'
|
68
69
|
requirements: []
|
69
|
-
rubygems_version: 3.
|
70
|
+
rubygems_version: 3.3.7
|
70
71
|
signing_key:
|
71
72
|
specification_version: 4
|
72
73
|
summary: Idempotent MySQL/PostgreSQL schema management by SQL
|