postspec 0.5.0 → 0.5.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/postspec/frame.rb +2 -1
- data/lib/postspec/render.rb +2 -5
- data/lib/postspec/version.rb +1 -1
- data/lib/share/postspec_schema.sql +7 -0
- data/performance/performance_spec.rb +6 -6
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ea21b5a77ff6cb93cb75afe5319ce60f0bb41e20415e8e157a1ab3bf80798d31
|
4
|
+
data.tar.gz: a83e04fdf627affb446495e76f41f610bcfed5ef77d5d9a9f310d906961f569d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 18518d724e9b09ff3b5d145cf4e68398ea4f4e081508276438b579694bf373ce572b77d4835d124a08d35aab0e70a0bd47bab3b14b3f88180b50a8990c06489c
|
7
|
+
data.tar.gz: aed775cf5e81476f2e709cb51494b432f5eea41889093f5fc47bc70cf02c77fff3d9aeed0a6f1b3a72d6e90c502dbe056fe6473477c5b763df8627093a5e1c8a
|
data/lib/postspec/frame.rb
CHANGED
@@ -84,7 +84,8 @@ module Postspec
|
|
84
84
|
attr_reader :data
|
85
85
|
alias_method :sql, :push_sql
|
86
86
|
|
87
|
-
# Note FoxFrame::new computes the fox object
|
87
|
+
# Note FoxFrame::new computes the fox object. It has four arguments instead
|
88
|
+
# of the five below
|
88
89
|
def initialize(parent, search_path, fox, data, push_sql)
|
89
90
|
@fox = fox
|
90
91
|
@data = data
|
data/lib/postspec/render.rb
CHANGED
@@ -52,12 +52,9 @@ module Postspec
|
|
52
52
|
end
|
53
53
|
|
54
54
|
def drop_seed_triggers
|
55
|
-
p "DROP"
|
56
55
|
postspec.tables.map { |uid|
|
57
|
-
p "BING"
|
58
56
|
[SEED_BUD_TRIGGER_NAME, SEED_BT_TRIGGER_NAME].map { |trigger|
|
59
57
|
trigger_uid = "#{uid}.#{trigger}()"
|
60
|
-
p trigger_uid
|
61
58
|
postspec.meta.exist?(trigger_uid) ? "drop trigger #{trigger} on #{uid}" : nil
|
62
59
|
}.compact
|
63
60
|
}.flatten
|
@@ -76,13 +73,13 @@ module Postspec
|
|
76
73
|
create trigger #{SEED_BUD_TRIGGER_NAME}
|
77
74
|
before update or delete on #{uid}
|
78
75
|
for each row
|
79
|
-
when (
|
76
|
+
when (OLD.id <= #{id})
|
80
77
|
execute function postspec.readonly_failure('#{uid}')
|
81
78
|
EOS1
|
82
79
|
bt_sql = <<~EOS2
|
83
80
|
create trigger postspec_readonly_bt_trg
|
84
81
|
before truncate on #{uid}
|
85
|
-
execute function postspec.
|
82
|
+
execute function postspec.truncate_failure('#{uid}')
|
86
83
|
EOS2
|
87
84
|
[
|
88
85
|
bud_sql.chomp,
|
data/lib/postspec/version.rb
CHANGED
@@ -55,6 +55,13 @@ create or replace function readonly_failure() returns trigger as $$
|
|
55
55
|
end;
|
56
56
|
$$ language plpgsql immutable leakproof;
|
57
57
|
|
58
|
+
create or replace function truncate_failure() returns trigger as $$
|
59
|
+
begin
|
60
|
+
raise 'Postspec: Can''t truncate %.%', TG_TABLE_SCHEMA, TG_TABLE_NAME;
|
61
|
+
return null;
|
62
|
+
end;
|
63
|
+
$$ language plpgsql immutable leakproof;
|
64
|
+
|
58
65
|
-- :call-seq:
|
59
66
|
-- register_insert(record_id)
|
60
67
|
--
|
@@ -11,8 +11,8 @@ describe "'use' performance" do
|
|
11
11
|
describe "timing..." do
|
12
12
|
t0 = nil
|
13
13
|
|
14
|
-
before(:all) {
|
15
|
-
t0 = Time.now
|
14
|
+
before(:all) {
|
15
|
+
t0 = Time.now
|
16
16
|
}
|
17
17
|
|
18
18
|
after(:all) {
|
@@ -47,8 +47,8 @@ describe "'statement with #db' performance" do
|
|
47
47
|
|
48
48
|
describe "timing..." do
|
49
49
|
|
50
|
-
before(:all) {
|
51
|
-
t0 = Time.now
|
50
|
+
before(:all) {
|
51
|
+
t0 = Time.now
|
52
52
|
}
|
53
53
|
|
54
54
|
after(:all) {
|
@@ -84,8 +84,8 @@ describe "'statement with #data' performance" do
|
|
84
84
|
|
85
85
|
describe "timing..." do
|
86
86
|
|
87
|
-
before(:all) {
|
88
|
-
t0 = Time.now
|
87
|
+
before(:all) {
|
88
|
+
t0 = Time.now
|
89
89
|
}
|
90
90
|
|
91
91
|
after(:all) {
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: postspec
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.5.
|
4
|
+
version: 0.5.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Claus Rasmussen
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2025-01-11 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: dry-inflector
|