70 lines
1.7 KiB
Ruby
70 lines
1.7 KiB
Ruby
|
require 'test_helper'
|
||
|
|
||
|
class OutputCommandTest < Test::Unit::TestCase
|
||
|
|
||
|
context "A plain command" do
|
||
|
setup do
|
||
|
@output = load_whenever_output \
|
||
|
<<-file
|
||
|
every 2.hours do
|
||
|
command "blahblah"
|
||
|
end
|
||
|
file
|
||
|
end
|
||
|
|
||
|
should "output the command" do
|
||
|
assert_match /^.+ .+ .+ .+ blahblah$/, @output
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "A command when the cron_log is set" do
|
||
|
setup do
|
||
|
@output = load_whenever_output \
|
||
|
<<-file
|
||
|
set :cron_log, 'logfile.log'
|
||
|
every 2.hours do
|
||
|
command "blahblah"
|
||
|
end
|
||
|
file
|
||
|
end
|
||
|
|
||
|
should "output the command with the log syntax appended" do
|
||
|
assert_match /^.+ .+ .+ .+ blahblah >> logfile.log 2>&1$/, @output
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "A command when the cron_log is set and the comand overrides it" do
|
||
|
setup do
|
||
|
@output = load_whenever_output \
|
||
|
<<-file
|
||
|
set :cron_log, 'logfile.log'
|
||
|
every 2.hours do
|
||
|
command "blahblah", :cron_log => 'otherlog.log'
|
||
|
end
|
||
|
file
|
||
|
end
|
||
|
|
||
|
should "output the command with the log syntax appended" do
|
||
|
assert_no_match /.+ .+ .+ .+ blahblah >> logfile.log 2>&1/, @output
|
||
|
assert_match /^.+ .+ .+ .+ blahblah >> otherlog.log 2>&1$/, @output
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "A command when the cron_log is set and the comand rejects it" do
|
||
|
setup do
|
||
|
@output = load_whenever_output \
|
||
|
<<-file
|
||
|
set :cron_log, 'logfile.log'
|
||
|
every 2.hours do
|
||
|
command "blahblah", :cron_log => false
|
||
|
end
|
||
|
file
|
||
|
end
|
||
|
|
||
|
should "output the command without the log syntax appended" do
|
||
|
assert_no_match /.+ .+ .+ .+ blahblah >> logfile.log 2>&1/, @output
|
||
|
assert_match /^.+ .+ .+ .+ blahblah$/, @output
|
||
|
end
|
||
|
end
|
||
|
|
||
|
end
|