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/changelog_entry_adder.rb,
lib/kettle/dev/open_collective_config.rb
Defined Under Namespace
Modules: CIHelpers, CIMonitor, CommitMsg, ExitAdapter, InputAdapter, OpenCollectiveConfig, Tasks, Version, Versioning Classes: BumpCLI, ChangelogCLI, ChangelogEntryAdder, 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
149 150 151 |
# File 'lib/kettle/dev.rb', line 149 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.
113 114 115 116 117 118 119 120 121 |
# File 'lib/kettle/dev.rb', line 113 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.
127 128 129 130 131 132 133 134 |
# File 'lib/kettle/dev.rb', line 127 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
170 171 172 |
# File 'lib/kettle/dev.rb', line 170 def default_registered?(task_name) defaults.include?(task_name.to_s) end |
.display_path(path) ⇒ Object
95 96 97 98 99 |
# File 'lib/kettle/dev.rb', line 95 def display_path(path) return path if path.nil? path.to_s.sub(VAR_HOME_PREFIX, "/home") end |
.display_text(text) ⇒ Object
101 102 103 104 105 |
# File 'lib/kettle/dev.rb', line 101 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.
141 142 143 144 145 |
# File 'lib/kettle/dev.rb', line 141 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.
155 156 157 158 159 160 161 162 163 164 165 166 167 168 |
# File 'lib/kettle/dev.rb', line 155 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 |