sundbp-whenever 0.4.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,74 @@
1
+ require File.expand_path(File.dirname(__FILE__) + "/test_helper")
2
+
3
+ class OutputRakeTest < Test::Unit::TestCase
4
+
5
+ # Rake are generated in an almost identical way to runners so we
6
+ # only need some basic tests to ensure they are output correctly
7
+
8
+ context "A rake command with path set" do
9
+ setup do
10
+ @output = Whenever.cron \
11
+ <<-file
12
+ set :path, '/my/path'
13
+ every 2.hours do
14
+ rake "blahblah"
15
+ end
16
+ file
17
+ end
18
+
19
+ should "output the rake command using that path" do
20
+ assert_match two_hours + ' cd /my/path && RAILS_ENV=production /usr/bin/env rake blahblah', @output
21
+ end
22
+ end
23
+
24
+ context "A rake command that overrides the path set" do
25
+ setup do
26
+ @output = Whenever.cron \
27
+ <<-file
28
+ set :path, '/my/path'
29
+ every 2.hours do
30
+ rake "blahblah", :path => '/some/other/path'
31
+ end
32
+ file
33
+ end
34
+
35
+ should "output the rake command using that path" do
36
+ assert_match two_hours + ' cd /some/other/path && RAILS_ENV=production /usr/bin/env rake blahblah', @output
37
+ end
38
+ end
39
+
40
+ context "A rake command with environment set" do
41
+ setup do
42
+ @output = Whenever.cron \
43
+ <<-file
44
+ set :environment, :silly
45
+ set :path, '/my/path'
46
+ every 2.hours do
47
+ rake "blahblah"
48
+ end
49
+ file
50
+ end
51
+
52
+ should "output the rake command using that environment" do
53
+ assert_match two_hours + ' cd /my/path && RAILS_ENV=silly /usr/bin/env rake blahblah', @output
54
+ end
55
+ end
56
+
57
+ context "A rake command that overrides the environment set" do
58
+ setup do
59
+ @output = Whenever.cron \
60
+ <<-file
61
+ set :environment, :silly
62
+ set :path, '/my/path'
63
+ every 2.hours do
64
+ rake "blahblah", :environment => :serious
65
+ end
66
+ file
67
+ end
68
+
69
+ should "output the rake command using that environment" do
70
+ assert_match two_hours + ' cd /my/path && RAILS_ENV=serious /usr/bin/env rake blahblah', @output
71
+ end
72
+ end
73
+
74
+ end
@@ -0,0 +1,289 @@
1
+ require File.expand_path(File.dirname(__FILE__) + "/test_helper")
2
+
3
+ class OutputRedirectionTest < Test::Unit::TestCase
4
+
5
+ context "A command when the output is set to nil" do
6
+ setup do
7
+ @output = Whenever.cron \
8
+ <<-file
9
+ set :output, nil
10
+ every 2.hours do
11
+ command "blahblah"
12
+ end
13
+ file
14
+ end
15
+
16
+ should "output the command with the log syntax appended" do
17
+ assert_match /^.+ .+ .+ .+ blahblah >> \/dev\/null 2>&1$/, @output
18
+ end
19
+ end
20
+
21
+
22
+ context "A command when the output is set" do
23
+ setup do
24
+ @output = Whenever.cron \
25
+ <<-file
26
+ set :output, 'logfile.log'
27
+ every 2.hours do
28
+ command "blahblah"
29
+ end
30
+ file
31
+ end
32
+
33
+ should "output the command with the log syntax appended" do
34
+ assert_match /^.+ .+ .+ .+ blahblah >> logfile.log 2>&1$/, @output
35
+ end
36
+ end
37
+
38
+ context "A command when the error and standard output is set by the command" do
39
+ setup do
40
+ @output = Whenever.cron \
41
+ <<-file
42
+ every 2.hours do
43
+ command "blahblah", :output => {:standard => 'dev_null', :error => 'dev_err'}
44
+ end
45
+ file
46
+ end
47
+
48
+ should "output the command without the log syntax appended" do
49
+ assert_match /^.+ .+ .+ .+ blahblah >> dev_null 2> dev_err$/, @output
50
+ end
51
+ end
52
+
53
+ context "A command when the output is set and the comand overrides it" do
54
+ setup do
55
+ @output = Whenever.cron \
56
+ <<-file
57
+ set :output, 'logfile.log'
58
+ every 2.hours do
59
+ command "blahblah", :output => 'otherlog.log'
60
+ end
61
+ file
62
+ end
63
+
64
+ should "output the command with the command syntax appended" do
65
+ assert_no_match /.+ .+ .+ .+ blahblah >> logfile.log 2>&1/, @output
66
+ assert_match /^.+ .+ .+ .+ blahblah >> otherlog.log 2>&1$/, @output
67
+ end
68
+ end
69
+
70
+ context "A command when the output is set and the comand overrides with standard and error" do
71
+ setup do
72
+ @output = Whenever.cron \
73
+ <<-file
74
+ set :output, 'logfile.log'
75
+ every 2.hours do
76
+ command "blahblah", :output => {:error => 'dev_err', :standard => 'dev_null' }
77
+ end
78
+ file
79
+ end
80
+
81
+ should "output the command with the overridden redirection syntax appended" do
82
+ assert_no_match /.+ .+ .+ .+ blahblah >> logfile.log 2>&1/, @output
83
+ assert_match /^.+ .+ .+ .+ blahblah >> dev_null 2> dev_err$/, @output
84
+ end
85
+ end
86
+
87
+ context "A command when the output is set and the comand rejects it" do
88
+ setup do
89
+ @output = Whenever.cron \
90
+ <<-file
91
+ set :output, 'logfile.log'
92
+ every 2.hours do
93
+ command "blahblah", :output => false
94
+ end
95
+ file
96
+ end
97
+
98
+ should "output the command without the log syntax appended" do
99
+ assert_no_match /.+ .+ .+ .+ blahblah >> logfile.log 2>&1/, @output
100
+ assert_match /^.+ .+ .+ .+ blahblah$/, @output
101
+ end
102
+ end
103
+
104
+ context "A command when the output is set and is overridden by the :set option" do
105
+ setup do
106
+ @output = Whenever.cron :set => 'output=otherlog.log', :string => \
107
+ <<-file
108
+ set :output, 'logfile.log'
109
+ every 2.hours do
110
+ command "blahblah"
111
+ end
112
+ file
113
+ end
114
+
115
+ should "output the otherlog.log as the log file" do
116
+ assert_no_match /.+ .+ .+ .+ blahblah >> logfile.log 2>&1/, @output
117
+ assert_match /^.+ .+ .+ .+ blahblah >> otherlog.log 2>&1/, @output
118
+ end
119
+ end
120
+
121
+ context "A command when the error and standard output is set" do
122
+ setup do
123
+ @output = Whenever.cron \
124
+ <<-file
125
+ set :output, {:error => 'dev_err', :standard => 'dev_null' }
126
+ every 2.hours do
127
+ command "blahblah"
128
+ end
129
+ file
130
+ end
131
+
132
+ should "output the command without the redirection syntax appended" do
133
+ assert_match /^.+ .+ .+ .+ blahblah >> dev_null 2> dev_err$/, @output
134
+ end
135
+ end
136
+
137
+ context "A command when error output is set" do
138
+ setup do
139
+ @output = Whenever.cron \
140
+ <<-file
141
+ set :output, {:error => 'dev_null'}
142
+ every 2.hours do
143
+ command "blahblah"
144
+ end
145
+ file
146
+ end
147
+
148
+ should "output the command without the standard errror syntax appended" do
149
+ assert_match /^.+ .+ .+ .+ blahblah 2> dev_null$/, @output
150
+ end
151
+ end
152
+
153
+ context "A command when the standard output is set" do
154
+ setup do
155
+ @output = Whenever.cron \
156
+ <<-file
157
+ set :output, {:standard => 'dev_out'}
158
+ every 2.hours do
159
+ command "blahblah"
160
+ end
161
+ file
162
+ end
163
+
164
+ should "output the command with standard output syntax appended" do
165
+ assert_match /^.+ .+ .+ .+ blahblah >> dev_out$/, @output
166
+ end
167
+ end
168
+
169
+ context "A command when error output is set by the command" do
170
+ setup do
171
+ @output = Whenever.cron \
172
+ <<-file
173
+ every 2.hours do
174
+ command "blahblah", :output => {:error => 'dev_err'}
175
+ end
176
+ file
177
+ end
178
+
179
+ should "output the command without the log syntax appended" do
180
+ assert_match /^.+ .+ .+ .+ blahblah 2> dev_err$/, @output
181
+ end
182
+ end
183
+
184
+ context "A command when standard output is set by the command" do
185
+ setup do
186
+ @output = Whenever.cron \
187
+ <<-file
188
+ every 2.hours do
189
+ command "blahblah", :output => {:standard => 'dev_out'}
190
+ end
191
+ file
192
+ end
193
+
194
+ should "output the command without the log syntax appended" do
195
+ assert_match /^.+ .+ .+ .+ blahblah >> dev_out$/, @output
196
+ end
197
+ end
198
+
199
+ context "A command when standard output is set to nil" do
200
+ setup do
201
+ @output = Whenever.cron \
202
+ <<-file
203
+ every 2.hours do
204
+ command "blahblah", :output => {:standard => nil}
205
+ end
206
+ file
207
+ end
208
+
209
+ should "output the command with stdout directed to /dev/null" do
210
+ assert_match /^.+ .+ .+ .+ blahblah >> \/dev\/null$/, @output
211
+ end
212
+ end
213
+
214
+ context "A command when standard error is set to nil" do
215
+ setup do
216
+ @output = Whenever.cron \
217
+ <<-file
218
+ every 2.hours do
219
+ command "blahblah", :output => {:error => nil}
220
+ end
221
+ file
222
+ end
223
+
224
+ should "output the command with stderr directed to /dev/null" do
225
+ assert_match /^.+ .+ .+ .+ blahblah 2> \/dev\/null$/, @output
226
+ end
227
+ end
228
+
229
+ context "A command when standard output and standard error is set to nil" do
230
+ setup do
231
+ @output = Whenever.cron \
232
+ <<-file
233
+ every 2.hours do
234
+ command "blahblah", :output => {:error => nil, :standard => nil}
235
+ end
236
+ file
237
+ end
238
+
239
+ should "output the command with stderr directed to /dev/null" do
240
+ assert_match /^.+ .+ .+ .+ blahblah >> \/dev\/null 2>&1$/, @output
241
+ end
242
+ end
243
+
244
+ context "A command when standard output is set and standard error is set to nil" do
245
+ setup do
246
+ @output = Whenever.cron \
247
+ <<-file
248
+ every 2.hours do
249
+ command "blahblah", :output => {:error => nil, :standard => 'my.log'}
250
+ end
251
+ file
252
+ end
253
+
254
+ should "output the command with stderr directed to /dev/null" do
255
+ assert_match /^.+ .+ .+ .+ blahblah >> my.log 2> \/dev\/null$/, @output
256
+ end
257
+ end
258
+
259
+ context "A command when standard output is nil and standard error is set" do
260
+ setup do
261
+ @output = Whenever.cron \
262
+ <<-file
263
+ every 2.hours do
264
+ command "blahblah", :output => {:error => 'my_error.log', :standard => nil}
265
+ end
266
+ file
267
+ end
268
+
269
+ should "output the command with stderr directed to /dev/null" do
270
+ assert_match /^.+ .+ .+ .+ blahblah >> \/dev\/null 2> my_error.log$/, @output
271
+ end
272
+ end
273
+
274
+ context "A command when the deprecated :cron_log is set" do
275
+ setup do
276
+ @output = Whenever.cron \
277
+ <<-file
278
+ set :cron_log, "cron.log"
279
+ every 2.hours do
280
+ command "blahblah"
281
+ end
282
+ file
283
+ end
284
+
285
+ should "output the command with with the stdout and stderr going to the log" do
286
+ assert_match /^.+ .+ .+ .+ blahblah >> cron.log 2>&1$/, @output
287
+ end
288
+ end
289
+ end
@@ -0,0 +1,209 @@
1
+ require File.expand_path(File.dirname(__FILE__) + "/test_helper")
2
+
3
+ class OutputRunnerTest < Test::Unit::TestCase
4
+
5
+ context "A runner with path set" do
6
+ setup do
7
+ @output = Whenever.cron \
8
+ <<-file
9
+ set :path, '/my/path'
10
+ every 2.hours do
11
+ runner "blahblah"
12
+ end
13
+ file
14
+ end
15
+
16
+ should "output the runner using that path" do
17
+ assert_match two_hours + ' /my/path/script/runner -e production "blahblah"', @output
18
+ end
19
+ end
20
+
21
+ context "A runner that overrides the path set" do
22
+ setup do
23
+ @output = Whenever.cron \
24
+ <<-file
25
+ set :path, '/my/path'
26
+ every 2.hours do
27
+ runner "blahblah", :path => '/some/other/path'
28
+ end
29
+ file
30
+ end
31
+
32
+ should "output the runner using that path" do
33
+ assert_match two_hours + ' /some/other/path/script/runner -e production "blahblah"', @output
34
+ end
35
+ end
36
+
37
+ context "A runner with no path set and RAILS_ROOT defined" do
38
+ setup do
39
+ Whenever.stubs(:path).returns('/my/path')
40
+
41
+ @output = Whenever.cron \
42
+ <<-file
43
+ every 2.hours do
44
+ runner "blahblah"
45
+ end
46
+ file
47
+ end
48
+
49
+ should "output the runner using that path" do
50
+ assert_match two_hours + ' /my/path/script/runner -e production "blahblah"', @output
51
+ end
52
+ end
53
+
54
+ context "A runner with path set AND RAILS_ROOT defined" do
55
+ setup do
56
+ Whenever.stubs(:path).returns('/my/rails/path')
57
+
58
+ @output = Whenever.cron \
59
+ <<-file
60
+ set :path, '/my/path'
61
+ every 2.hours do
62
+ runner "blahblah"
63
+ end
64
+ file
65
+ end
66
+
67
+ should "use the path" do
68
+ assert_match two_hours + ' /my/path/script/runner -e production "blahblah"', @output
69
+ assert_no_match /\/rails\/path/, @output
70
+ end
71
+ end
72
+
73
+ context "A runner with no path set and no RAILS_ROOT defined" do
74
+ setup do
75
+ Whenever.stubs(:path).returns(nil)
76
+
77
+ @input = <<-file
78
+ every 2.hours do
79
+ runner "blahblah"
80
+ end
81
+ file
82
+ end
83
+
84
+ should "raise an exception" do
85
+ assert_raises ArgumentError do
86
+ Whenever.cron(@input)
87
+ end
88
+ end
89
+ end
90
+
91
+ context "A runner with an environment set" do
92
+ setup do
93
+ @output = Whenever.cron \
94
+ <<-file
95
+ set :environment, :silly
96
+ set :path, '/my/path'
97
+ every 2.hours do
98
+ runner "blahblah"
99
+ end
100
+ file
101
+ end
102
+
103
+ should "output the runner using that environment" do
104
+ assert_match two_hours + ' /my/path/script/runner -e silly "blahblah"', @output
105
+ end
106
+ end
107
+
108
+ context "A runner that overrides the environment set" do
109
+ setup do
110
+ @output = Whenever.cron \
111
+ <<-file
112
+ set :environment, :silly
113
+ set :path, '/my/path'
114
+ every 2.hours do
115
+ runner "blahblah", :environment => :serious
116
+ end
117
+ file
118
+ end
119
+
120
+ should "output the runner using that environment" do
121
+ assert_match two_hours + ' /my/path/script/runner -e serious "blahblah"', @output
122
+ end
123
+ end
124
+
125
+ context "A runner where the environment is overridden using the :set option" do
126
+ setup do
127
+ @output = Whenever.cron :set => 'environment=serious', :string => \
128
+ <<-file
129
+ set :environment, :silly
130
+ set :path, '/my/path'
131
+ every 2.hours do
132
+ runner "blahblah"
133
+ end
134
+ file
135
+ end
136
+
137
+ should "output the runner using the override environment" do
138
+ assert_match two_hours + ' /my/path/script/runner -e serious "blahblah"', @output
139
+ end
140
+ end
141
+
142
+ context "A runner where the environment and path are overridden using the :set option" do
143
+ setup do
144
+ @output = Whenever.cron :set => 'environment=serious&path=/serious/path', :string => \
145
+ <<-file
146
+ set :environment, :silly
147
+ set :path, '/silly/path'
148
+ every 2.hours do
149
+ runner "blahblah"
150
+ end
151
+ file
152
+ end
153
+
154
+ should "output the runner using the overridden path and environment" do
155
+ assert_match two_hours + ' /serious/path/script/runner -e serious "blahblah"', @output
156
+ end
157
+ end
158
+
159
+ context "A runner where the environment and path are overridden using the :set option with spaces in the string" do
160
+ setup do
161
+ @output = Whenever.cron :set => ' environment = serious& path =/serious/path', :string => \
162
+ <<-file
163
+ set :environment, :silly
164
+ set :path, '/silly/path'
165
+ every 2.hours do
166
+ runner "blahblah"
167
+ end
168
+ file
169
+ end
170
+
171
+ should "output the runner using the overridden path and environment" do
172
+ assert_match two_hours + ' /serious/path/script/runner -e serious "blahblah"', @output
173
+ end
174
+ end
175
+
176
+ context "A runner where the environment is overridden using the :set option but no value is given" do
177
+ setup do
178
+ @output = Whenever.cron :set => ' environment=', :string => \
179
+ <<-file
180
+ set :environment, :silly
181
+ set :path, '/silly/path'
182
+ every 2.hours do
183
+ runner "blahblah"
184
+ end
185
+ file
186
+ end
187
+
188
+ should "output the runner using the original environmnet" do
189
+ assert_match two_hours + ' /silly/path/script/runner -e silly "blahblah"', @output
190
+ end
191
+ end
192
+
193
+ context "A runner which makes use of double quotes" do
194
+ setup do
195
+ @output = Whenever.cron \
196
+ <<-file
197
+ set :path, '/my/path'
198
+ every 2.hours do
199
+ runner 'Product.import("http://example.com/product.xml")'
200
+ end
201
+ file
202
+ end
203
+
204
+ should "output the runner using the original environmnet" do
205
+ assert_match two_hours + ' /my/path/script/runner -e production "Product.import(\"http://example.com/product.xml\")"', @output
206
+ end
207
+ end
208
+
209
+ end