未验证 提交 f3fe56c7 编写于 作者: R Rafael França 提交者: GitHub

Merge pull request #33743 from steakknife/steakknife/improve-template-generator-actions

add github to template actions, template actions minor refactor
......@@ -7,7 +7,7 @@ module Generators
module Actions
def initialize(*) # :nodoc:
super
@in_group = nil
@indentation = 0
@after_bundle_callbacks = []
end
......@@ -36,13 +36,11 @@ def gem(*args)
log :gemfile, message
options.each do |option, value|
parts << "#{option}: #{quote(value)}"
end
parts << quote(options) unless options.empty?
in_root do
str = "gem #{parts.join(", ")}"
str = " " + str if @in_group
str = indentation + str
str = "\n" + str
append_file "Gemfile", str, verbose: false
end
......@@ -54,17 +52,29 @@ def gem(*args)
# gem "rspec-rails"
# end
def gem_group(*names, &block)
name = names.map(&:inspect).join(", ")
log :gemfile, "group #{name}"
options = names.extract_options!
str = names.map(&:inspect)
str << quote(options) unless options.empty?
str = str.join(", ")
log :gemfile, "group #{str}"
in_root do
append_file "Gemfile", "\ngroup #{name} do", force: true
append_file "Gemfile", "\ngroup #{str} do", force: true
with_indentation(&block)
append_file "Gemfile", "\nend\n", force: true
end
end
@in_group = true
instance_eval(&block)
@in_group = false
def github(repo, options = {}, &block)
str = [quote(repo)]
str << quote(options) unless options.empty?
str = str.join(", ")
log :github, "github #{str}"
append_file "Gemfile", "\nend\n", force: true
in_root do
append_file "Gemfile", "\n#{indentation}github #{str} do", force: true
with_indentation(&block)
append_file "Gemfile", "\n#{indentation}end", force: true
end
end
......@@ -83,9 +93,7 @@ def add_source(source, options = {}, &block)
in_root do
if block
append_file "Gemfile", "\nsource #{quote(source)} do", force: true
@in_group = true
instance_eval(&block)
@in_group = false
with_indentation(&block)
append_file "Gemfile", "\nend\n", force: true
else
prepend_file "Gemfile", "source #{quote(source)}\n", verbose: false
......@@ -315,6 +323,11 @@ def extify(name) # :doc:
# Surround string with single quotes if there is no quotes.
# Otherwise fall back to double quotes
def quote(value) # :doc:
if value.respond_to? :each_pair
return value.map do |k, v|
"#{k}: #{quote(v)}"
end.join(", ")
end
return value.inspect unless value.is_a? String
if value.include?("'")
......@@ -334,6 +347,19 @@ def optimize_indentation(value, amount = 0) # :doc:
"#{value.strip.indent(amount)}\n"
end
end
# Indent the +Gemfile+ to the depth of @indentation
def indentation # :doc:
" " * @indentation
end
# Manage +Gemfile+ indentation for a DSL action block
def with_indentation(&block) # :doc:
@indentation += 1
instance_eval(&block)
ensure
@indentation -= 1
end
end
end
end
......@@ -144,6 +144,44 @@ def test_gem_group_should_wrap_gems_in_a_group
assert_file "Gemfile", /\ngroup :development, :test do\n gem 'rspec-rails'\nend\n\ngroup :test do\n gem 'fakeweb'\nend/
end
def test_github_should_create_an_indented_block
run_generator
action :github, "user/repo" do
gem "foo"
gem "bar"
gem "baz"
end
assert_file "Gemfile", /\ngithub 'user\/repo' do\n gem 'foo'\n gem 'bar'\n gem 'baz'\nend/
end
def test_github_should_create_an_indented_block_with_options
run_generator
action :github, "user/repo", a: "correct", other: true do
gem "foo"
gem "bar"
gem "baz"
end
assert_file "Gemfile", /\ngithub 'user\/repo', a: 'correct', other: true do\n gem 'foo'\n gem 'bar'\n gem 'baz'\nend/
end
def test_github_should_create_an_indented_block_within_a_group
run_generator
action :gem_group, :magic do
github "user/repo", a: "correct", other: true do
gem "foo"
gem "bar"
gem "baz"
end
end
assert_file "Gemfile", /\ngroup :magic do\n github 'user\/repo', a: 'correct', other: true do\n gem 'foo'\n gem 'bar'\n gem 'baz'\n end\nend\n/
end
def test_environment_should_include_data_in_environment_initializer_block
run_generator
autoload_paths = 'config.autoload_paths += %w["#{Rails.root}/app/extras"]'
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册