Sha256: f4c16a8bd6b5462377e4c24fff6ea640d3c56e0d5a911018b17a5dccd21ff93d
Contents?: true
Size: 1.36 KB
Versions: 1
Compression:
Stored size: 1.36 KB
Contents
require "spec_helper" describe "Trigger migrations", :db do around do |example| connection.execute <<~EOS CREATE TABLE users ( id int PRIMARY KEY, name varchar(256), upper_name varchar(256) ); EOS Fx.database.create_function <<~EOS CREATE OR REPLACE FUNCTION uppercase_users_name() RETURNS trigger AS $$ BEGIN NEW.upper_name = UPPER(NEW.name); RETURN NEW; END; $$ LANGUAGE plpgsql; EOS sql_definition = <<~EOS CREATE TRIGGER uppercase_users_name BEFORE INSERT ON users FOR EACH ROW EXECUTE PROCEDURE uppercase_users_name(); EOS with_trigger_definition( name: :uppercase_users_name, sql_definition: sql_definition, ) do example.run end end it "can run migrations that create triggers" do migration = Class.new(ActiveRecord::Migration) do def up create_trigger :uppercase_users_name end end expect { run_migration(migration, :up) }.not_to raise_error end it "can run migrations that drop triggers" do connection.create_trigger(:uppercase_users_name) migration = Class.new(ActiveRecord::Migration) do def up drop_trigger :uppercase_users_name, on: :users end end expect { run_migration(migration, :up) }.not_to raise_error end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
fx-0.1.0 | spec/features/triggers/migrations_spec.rb |