Module: Kettle::Dev
- Defined in:
- lib/kettle/dev.rb,
lib/kettle/dev/version.rb,
lib/kettle/dev/dvcs_cli.rb,
lib/kettle/dev/ci_helpers.rb,
lib/kettle/dev/ci_monitor.rb,
lib/kettle/dev/commit_msg.rb,
lib/kettle/dev/versioning.rb,
lib/kettle/dev/git_adapter.rb,
lib/kettle/dev/release_cli.rb,
lib/kettle/dev/exit_adapter.rb,
lib/kettle/dev/changelog_cli.rb,
lib/kettle/dev/input_adapter.rb,
lib/kettle/dev/tasks/ci_task.rb,
lib/kettle/dev/readme_backers.rb,
lib/kettle/dev/gem_spec_reader.rb,
lib/kettle/dev/pre_release_cli.rb,
lib/kettle/dev/git_commit_footer.rb,
lib/kettle/dev/open_collective_config.rb
Defined Under Namespace
Modules: CIHelpers, CIMonitor, CommitMsg, ExitAdapter, InputAdapter, OpenCollectiveConfig, Tasks, Version, Versioning Classes: ChangelogCLI, DvcsCLI, Error, GemSpecReader, GitAdapter, GitCommitFooter, PreReleaseCLI, ReadmeBackers, ReleaseCLI
Constant Summary collapse
- DEBUGGING =
Whether debug logging is enabled for kettle-dev internals. Controlled by KETTLE_DEV_DEBUG=true.
ENV.fetch("KETTLE_DEV_DEBUG", "false").casecmp("true").zero?
- IS_CI =
Whether we are running on CI.
ENV.fetch("CI", "false").casecmp("true") == 0
- REQUIRE_BENCH =
Whether to benchmark requires with require_bench.
ENV.fetch("REQUIRE_BENCH", "false").casecmp("true").zero?
- RUNNING_AS =
The current program name (e.g., “rake”, “rspec”). Used to decide whether to auto-load rake tasks at the bottom of this file. Normally tasks are loaded in the host project’s Rakefile, but when running under this gem’s own test suite we need precise coverage; so we only auto-install tasks when invoked via the rake executable.
File.basename($PROGRAM_NAME)
- ENV_TRUE_RE =
A case-insensitive regular expression that matches common truthy ENV values. Accepts 1, true, y, yes (any case).
/\A(1|true|y|yes)\z/i- ENV_FALSE_RE =
A case-insensitive regular expression that matches common falsy ENV values. Accepts false, n, no, 0 (any case).
/\A(false|n|no|0)\z/i- GEM_ROOT =
Absolute path to the root of the kettle-dev gem (repository root when working from source)
File.("../..", __dir__)
- VAR_HOME_PREFIX =
%r{\A/var/home(?=/|\z)}- VAR_HOME_TEXT =
%r{/var/home(?=/|\z)}- VERSION =
Traditional Constant Location
Version::VERSION
Class Attribute Summary collapse
-
.defaults ⇒ Array<String>
readonly
Registry for tasks that should be prerequisites of the default task.
Class Method Summary collapse
-
.debug_error(error, context = nil, backtrace: true) ⇒ void
Emit a debug warning for rescued errors when kettle-dev debugging is enabled.
-
.debug_log(msg, context = nil) ⇒ void
Emit a debug log line when kettle-dev debugging is enabled.
- .default_registered?(task_name) ⇒ Boolean
- .display_path(path) ⇒ Object
- .display_text(text) ⇒ Object
-
.install_tasks ⇒ void
Install Rake tasks useful for development and tests.
-
.register_default(task_name) ⇒ Array<String>
Register a task name to be run by the default task.
Class Attribute Details
.defaults ⇒ Array<String> (readonly)
Registry for tasks that should be prerequisites of the default task
136 137 138 |
# File 'lib/kettle/dev.rb', line 136 def defaults @defaults end |
Class Method Details
.debug_error(error, context = nil, backtrace: true) ⇒ void
This method returns an undefined value.
Emit a debug warning for rescued errors when kettle-dev debugging is enabled. Controlled by KETTLE_DEV_DEBUG=true.
100 101 102 103 104 105 106 107 108 |
# File 'lib/kettle/dev.rb', line 100 def debug_error(error, context = nil, backtrace: true) return unless DEBUGGING ctx = context ? context.to_s : "KETTLE-DEV-RESCUE" Kernel.warn("[#{ctx}] #{error.class}: #{error.}") Kernel.warn(Array(error.backtrace).first(5).join("\n")) if backtrace && error.respond_to?(:backtrace) && error.backtrace rescue StandardError # never raise from debug logging end |
.debug_log(msg, context = nil) ⇒ void
This method returns an undefined value.
Emit a debug log line when kettle-dev debugging is enabled. Controlled by KETTLE_DEV_DEBUG=true.
114 115 116 117 118 119 120 121 |
# File 'lib/kettle/dev.rb', line 114 def debug_log(msg, context = nil) return unless DEBUGGING ctx = context ? context.to_s : "KETTLE-DEV-DEBUG" Kernel.warn("[#{ctx}] #{msg}") rescue StandardError # never raise from debug logging end |
.default_registered?(task_name) ⇒ Boolean
157 158 159 |
# File 'lib/kettle/dev.rb', line 157 def default_registered?(task_name) defaults.include?(task_name.to_s) end |
.display_path(path) ⇒ Object
82 83 84 85 86 |
# File 'lib/kettle/dev.rb', line 82 def display_path(path) return path if path.nil? path.to_s.sub(VAR_HOME_PREFIX, "/home") end |
.display_text(text) ⇒ Object
88 89 90 91 92 |
# File 'lib/kettle/dev.rb', line 88 def display_text(text) return text if text.nil? text.to_s.gsub(VAR_HOME_TEXT, "/home") end |
.install_tasks ⇒ void
This method returns an undefined value.
Install Rake tasks useful for development and tests.
Adds RuboCop-LTS tasks, coverage tasks, and loads the gem-shipped rakelib directory so host projects get tasks from this gem.
128 129 130 131 132 |
# File 'lib/kettle/dev.rb', line 128 def install_tasks linting_tasks coverage_tasks load("kettle/dev/tasks.rb") end |
.register_default(task_name) ⇒ Array<String>
Register a task name to be run by the default task. Also enhances the :default task immediately if it exists.
142 143 144 145 146 147 148 149 150 151 152 153 154 155 |
# File 'lib/kettle/dev.rb', line 142 def register_default(task_name) task_name = task_name.to_s unless defaults.include?(task_name) @defaults = (defaults + [task_name]).freeze # rubocop:disable ThreadSafety/ClassInstanceVariable if defined?(Rake) && Rake::Task.task_defined?(:default) begin Rake::Task[:default].enhance([task_name]) rescue StandardError => e Kernel.warn("kettle-dev: failed to enhance :default with #{task_name}: #{e.}") if DEBUGGING end end end defaults end |