From 7ca1245e9ced07eec632ed36ac6ae985662a9850 Mon Sep 17 00:00:00 2001 From: Simon Claessens Date: Mon, 25 Jan 2021 10:42:37 +0100 Subject: [PATCH] allow to configure definition path fix #261 --- lib/generators/scenic/view/view_generator.rb | 29 +++++---------- lib/scenic.rb | 1 - lib/scenic/configuration.rb | 11 +++++- lib/scenic/definition.rb | 4 +-- lib/scenic/definitions.rb | 38 ++++++++++++++++++++ lib/scenic/statements.rb | 1 + 6 files changed, 60 insertions(+), 24 deletions(-) create mode 100644 lib/scenic/definitions.rb diff --git a/lib/generators/scenic/view/view_generator.rb b/lib/generators/scenic/view/view_generator.rb index 496035f8..12b3b73a 100644 --- a/lib/generators/scenic/view/view_generator.rb +++ b/lib/generators/scenic/view/view_generator.rb @@ -1,6 +1,8 @@ require "rails/generators" require "rails/generators/active_record" require "generators/scenic/materializable" +require "scenic/definition" +require "scenic/definitions" module Scenic module Generators @@ -11,8 +13,8 @@ class ViewGenerator < Rails::Generators::NamedBase source_root File.expand_path("templates", __dir__) def create_views_directory - unless views_directory_path.exist? - empty_directory(views_directory_path) + unless Scenic.configuration.definitions_path.exist? + empty_directory(Scenic.configuration.definitions_path) end end @@ -44,10 +46,7 @@ def self.next_migration_number(dir) no_tasks do def previous_version - @previous_version ||= - Dir.entries(views_directory_path) - .map { |name| version_regex.match(name).try(:[], "version").to_i } - .max + @previous_version ||= previous_definition.version end def version @@ -73,22 +72,12 @@ def activerecord_migration_class private - alias singular_name file_name - - def file_name - super.tr(".", "_") - end - - def views_directory_path - @views_directory_path ||= Rails.root.join("db", "views") - end - - def version_regex - /\A#{plural_file_name}_v(?\d+)\.sql\z/ + def definitions + @definitions ||= Scenic::Definitions.new(plural_file_name) end def creating_new_view? - previous_version.zero? + definitions.none? end def definition @@ -96,7 +85,7 @@ def definition end def previous_definition - Scenic::Definition.new(plural_file_name, previous_version) + definitions.max || Scenic::Definition.new(plural_file_name, 0) end def destroying? diff --git a/lib/scenic.rb b/lib/scenic.rb index 8adcb2ee..c1637ac0 100644 --- a/lib/scenic.rb +++ b/lib/scenic.rb @@ -1,7 +1,6 @@ require "scenic/configuration" require "scenic/adapters/postgres" require "scenic/command_recorder" -require "scenic/definition" require "scenic/railtie" require "scenic/schema_dumper" require "scenic/statements" diff --git a/lib/scenic/configuration.rb b/lib/scenic/configuration.rb index aec067fa..905cde30 100644 --- a/lib/scenic/configuration.rb +++ b/lib/scenic/configuration.rb @@ -1,3 +1,5 @@ +require_relative "adapters/postgres" + module Scenic class Configuration # The Scenic database adapter instance to use when executing SQL. @@ -6,8 +8,15 @@ class Configuration # @return Scenic adapter attr_accessor :database + # The path where is stored views definition sql files. + # + # Defaults to an instance of {Pathname} to rails_root/db/views + # @return the path + attr_accessor :definitions_path + def initialize - @database = Scenic::Adapters::Postgres.new + self.database = Scenic::Adapters::Postgres.new + self.definitions_path = Rails.root end end diff --git a/lib/scenic/definition.rb b/lib/scenic/definition.rb index dac137cd..edac63b0 100644 --- a/lib/scenic/definition.rb +++ b/lib/scenic/definition.rb @@ -15,11 +15,11 @@ def to_sql end def full_path - Rails.root.join(path) + Scenic.configuration.definitions_path.join(filename) end def path - File.join("db", "views", filename) + full_path.relative_path_from(Rails.root).to_s end def version diff --git a/lib/scenic/definitions.rb b/lib/scenic/definitions.rb new file mode 100644 index 00000000..1211d7ef --- /dev/null +++ b/lib/scenic/definitions.rb @@ -0,0 +1,38 @@ +require_relative "definition" + +module Scenic + # @api private + class Definitions + include Enumerable + include Comparable + + attr_reader :name, :views_directory_path + + def initialize(name) + @name = name + end + + def each + versions.each do |version| + yield Scenic::Definition.new(plural_file_name, version) + end + end + + def <=>(definition_a, definition_b) + definition_a.version <=> definition_b.version + end + + def versions + @versions ||= Dir.entries(Scenic.configuration.definitions_path) + .map { |name| version_regex.match(name).try(:[], "version").try(:to_i) } + .compact + .sort + end + + private + + def version_regex + /\A#{name}_v(?\d+)\.sql\z/ + end + end +end diff --git a/lib/scenic/statements.rb b/lib/scenic/statements.rb index 84bf24b0..9989ead2 100644 --- a/lib/scenic/statements.rb +++ b/lib/scenic/statements.rb @@ -1,3 +1,4 @@ +require_relative "definition" module Scenic # Methods that are made available in migrations for managing Scenic views. module Statements