module Rails::Generators::Testing::Behavior
Public instance methods
Create a Rails::Generators::GeneratedAttribute by supplying the attribute type and, optionally, the attribute name:
create_generated_attribute(:string, "name")
Source code GitHub
# File railties/lib/rails/generators/testing/behavior.rb, line 86
def create_generated_attribute(attribute_type, name = "test", index = nil)
Rails::Generators::GeneratedAttribute.parse([name, attribute_type, index].compact.join(":"))
end
Instantiate the generator.
Source code GitHub
# File railties/lib/rails/generators/testing/behavior.rb, line 78
def generator(args = default_arguments, options = {}, config = {})
@generator ||= generator_class.new(args, options, config.reverse_merge(destination_root: destination_root))
end
Runs the generator configured for this class. The first argument is an array like command line arguments:
class AppGeneratorTest < Rails::Generators::TestCase
tests AppGenerator
destination File.expand_path("../tmp", __dir__)
setup :prepare_destination
test "database.yml is not created when skipping Active Record" do
run_generator %w(myapp --skip-active-record)
assert_no_file "config/database.yml"
end
end
You can provide a configuration hash as second argument. This method returns the output printed by the generator.
Source code GitHub
# File railties/lib/rails/generators/testing/behavior.rb, line 64
def run_generator(args = default_arguments, config = {})
args += ["--skip-bundle"] unless args.include?("--no-skip-bundle") || args.include?("--dev")
args += ["--skip-bootsnap"] unless args.include?("--no-skip-bootsnap") || args.include?("--skip-bootsnap")
if ENV["RAILS_LOG_TO_STDOUT"] == "true"
generator_class.start(args, config.reverse_merge(destination_root: destination_root))
else
capture(:stdout) do
generator_class.start(args, config.reverse_merge(destination_root: destination_root))
end
end
end
Private instance methods
Clears all files and directories in destination.
Source code GitHub
# File railties/lib/rails/generators/testing/behavior.rb, line 100
def prepare_destination # :doc:
rm_rf(destination_root)
mkdir_p(destination_root)
end