class Aruba::Platforms::Announcer
Aruba.announcer.announce(:my_channel, ‘my message’)
end
end
aruba.announcer.activate :my_channel
if current_example.metadata[:announce_my_channel]
current_example = context.example
before do
@example Activate your you own channel in rspec > 3
end
aruba.announcer.activate :my_channel
Before(‘@announce-my-channel’) do
@example Activate your you own channel in cucumber
@private
Announcer
def activate(*chns)
-
chns
(Symbol
) --
def activate(*chns) chns.flatten.each { |c| channels[c.to_sym] = true } self end
def activated?(channel)
-
channel
(Symbol
) --
def activated?(channel) channels[channel.to_sym] == true end
def after_init
def after_init output_format :changed_configuration, proc { |n, v| format("# %s = %s", n, v) } output_format :changed_environment, proc { |n, v| format("$ export %s=%s", n, Shellwords.escape(v)) } output_format :command, "$ %s" output_format :directory, "$ cd %s" output_format :environment, proc { |n, v| format("$ export %s=%s", n, Shellwords.escape(v)) } output_format :full_environment, proc { |h| format("<<-ENVIRONMENT\n%s\nENVIRONMENT", Aruba.platform.simple_table(h)) } output_format :modified_environment, proc { |n, v| format("$ export %s=%s", n, Shellwords.escape(v)) } output_format :stderr, "<<-STDERR\n%s\nSTDERR" output_format :stdout, "<<-STDOUT\n%s\nSTDOUT" output_format :command_content, "<<-COMMAND\n%s\nCOMMAND" output_format :stop_signal, proc { |p, s| format("Command will be stopped with `kill -%s %s`", s, p) } output_format :timeout, "# %s-timeout: %s seconds" output_format :wait_time, "# %s: %s seconds" output_format :command_filesystem_status, proc { |status| format("<<-COMMAND FILESYSTEM STATUS\n%s\nCOMMAND FILESYSTEM STATUS", Aruba.platform.simple_table(status.to_h, sort: false)) } end
def announce(channel, *args)
- Yield: -
Parameters:
-
args
(Array
) -- -
channel
(Symbol
) --
def announce(channel, *args) channel = channel.to_sym the_output_format = if output_formats.key? channel output_formats[channel] else proc { |v| format("%s", v) } end return unless activated?(channel) begin if block_given? value = yield args << value end message = the_output_format.call(*args) message += "\n" message = colorizer.cyan(message) rescue NotImplementedError => e message = "Error fetching announced value for #{channel}: #{e.message}" end announcer.announce(message) nil end
def initialize
def initialize @announcers = [] @announcers << PutsAnnouncer.new @announcers << KernelPutsAnnouncer.new @colorizer = Aruba::Colorizer.new @announcer = @announcers.first @channels = {} @output_formats = {} after_init end
def mode
-
(Symbol)
- The current announcer mode
def mode @announcer.mode end
def mode=(m)
-
m
(Symbol
) --
def mode=(m) @announcer = @announcers.find { |a| a.mode? m.to_sym } end
def output_format(channel, string = "%s", &block)
def output_format(channel, string = "%s", &block) output_formats[channel.to_sym] = if block block elsif string.is_a?(Proc) string else proc { |*args| format(string, *args) } end end
def reset
def reset @announcer = @announcers.first end