Module: Kettle::Dev
- Defined in:
- lib/kettle/dev.rb,
lib/kettle/dev/version.rb,
lib/kettle/dev/bump_cli.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/gha_sha_pins_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: BumpCLI, ChangelogCLI, DvcsCLI, Error, GemSpecReader, GhaShaPinsCLI, 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
148 149 150 |
# File 'lib/kettle/dev.rb', line 148 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.
112 113 114 115 116 117 118 119 120 |
# File 'lib/kettle/dev.rb', line 112 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 # 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.
126 127 128 129 130 131 132 133 |
# File 'lib/kettle/dev.rb', line 126 def debug_log(msg, context = nil) return unless DEBUGGING ctx = context ? context.to_s : "KETTLE-DEV-DEBUG" Kernel.warn("[#{ctx}] #{msg}") rescue # never raise from debug logging end |
.default_registered?(task_name) ⇒ Boolean
169 170 171 |
# File 'lib/kettle/dev.rb', line 169 def default_registered?(task_name) defaults.include?(task_name.to_s) end |
.display_path(path) ⇒ Object
94 95 96 97 98 |
# File 'lib/kettle/dev.rb', line 94 def display_path(path) return path if path.nil? path.to_s.sub(VAR_HOME_PREFIX, "/home") end |
.display_text(text) ⇒ Object
100 101 102 103 104 |
# File 'lib/kettle/dev.rb', line 100 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.
140 141 142 143 144 |
# File 'lib/kettle/dev.rb', line 140 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.
154 155 156 157 158 159 160 161 162 163 164 165 166 167 |
# File 'lib/kettle/dev.rb', line 154 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 => e Kernel.warn("kettle-dev: failed to enhance :default with #{task_name}: #{e.}") if DEBUGGING end end end defaults end |