Evaluate run control file when present
This commit is contained in:
parent
8165a1d4f5
commit
7493ab3284
10
features/run_control/evaluation.feature
Normal file
10
features/run_control/evaluation.feature
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
@mocked_home_directory
|
||||||
|
Feature: run control file evaluation
|
||||||
|
|
||||||
|
Scenario: evaluates the default run control file when it exists
|
||||||
|
Given a file named .uhwmrc.rb with:
|
||||||
|
"""
|
||||||
|
puts 'run control evaluation'
|
||||||
|
"""
|
||||||
|
When I start uhwm
|
||||||
|
Then the output must contain "run control evaluation"
|
@ -19,6 +19,10 @@ Then /^the output must contain:$/ do |content|
|
|||||||
uhwm_wait_output content.to_s
|
uhwm_wait_output content.to_s
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Then /^the output must contain "([^"]+)"$/ do |content|
|
||||||
|
uhwm_wait_output content.to_s
|
||||||
|
end
|
||||||
|
|
||||||
Then /^the output must contain current display$/ do
|
Then /^the output must contain current display$/ do
|
||||||
uhwm_wait_output ENV['DISPLAY']
|
uhwm_wait_output ENV['DISPLAY']
|
||||||
end
|
end
|
||||||
|
@ -4,6 +4,7 @@ module Uh
|
|||||||
class << self
|
class << self
|
||||||
def run env, **options
|
def run env, **options
|
||||||
runner = new env, **options
|
runner = new env, **options
|
||||||
|
runner.evaluate_run_control
|
||||||
runner.register_event_hooks
|
runner.register_event_hooks
|
||||||
runner.connect_manager
|
runner.connect_manager
|
||||||
runner.run_until { runner.stopped? }
|
runner.run_until { runner.stopped? }
|
||||||
@ -30,6 +31,11 @@ module Uh
|
|||||||
@stopped = true
|
@stopped = true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def evaluate_run_control
|
||||||
|
rc_path = File.expand_path(@env.rc_path)
|
||||||
|
eval File.read(rc_path) if File.exist?(rc_path)
|
||||||
|
end
|
||||||
|
|
||||||
def register_event_hooks
|
def register_event_hooks
|
||||||
register_manager_hooks
|
register_manager_hooks
|
||||||
register_layout_event_hooks
|
register_layout_event_hooks
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
require 'support/filesystem_helpers'
|
||||||
|
|
||||||
SomeLayout = Class.new do
|
SomeLayout = Class.new do
|
||||||
define_method(:register) { |*args| }
|
define_method(:register) { |*args| }
|
||||||
end
|
end
|
||||||
@ -5,10 +7,15 @@ end
|
|||||||
module Uh
|
module Uh
|
||||||
module WM
|
module WM
|
||||||
RSpec.describe Runner do
|
RSpec.describe Runner do
|
||||||
let(:env) do
|
include FileSystemHelpers
|
||||||
Env.new(StringIO.new).tap { |o| o.layout_class = SomeLayout }
|
|
||||||
|
let(:env) { Env.new(StringIO.new) }
|
||||||
|
subject(:runner) { described_class.new env }
|
||||||
|
|
||||||
|
before do
|
||||||
|
env.layout_class = SomeLayout
|
||||||
|
env.rc_path = 'non_existent_run_control.rb'
|
||||||
end
|
end
|
||||||
subject(:runner) { described_class.new env }
|
|
||||||
|
|
||||||
describe '#initialize' do
|
describe '#initialize' do
|
||||||
it 'assigns the env' do
|
it 'assigns the env' do
|
||||||
@ -52,6 +59,23 @@ module Uh
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '#evaluate_run_control' do
|
||||||
|
context 'when run control file exists' do
|
||||||
|
it 'evaluates the run control file' do
|
||||||
|
with_file 'throw :run_control' do |f|
|
||||||
|
env.rc_path = f.path
|
||||||
|
expect { runner.evaluate_run_control }.to throw_symbol :run_control
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when run control file does not exist' do
|
||||||
|
it 'does not raise any error' do
|
||||||
|
expect { runner.evaluate_run_control }.not_to raise_error
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe '#register_event_hooks' do
|
describe '#register_event_hooks' do
|
||||||
it 'registers manager event hooks for logging' do
|
it 'registers manager event hooks for logging' do
|
||||||
runner.register_event_hooks
|
runner.register_event_hooks
|
||||||
|
Loading…
x
Reference in New Issue
Block a user