ci
904 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#!/usr/bin/env ruby
tasks = %w[
test:api
test:units
test:functionals
test:integration
cucumber
selenium
test:noosfero_plugins
]
data = []
failed = []
tasks.each do |task|
puts task
puts task.gsub(/./, '*')
puts
t0 = Time.now.to_i
if system('rake', task)
status = 'PASS'
else
failed << task
status = 'FAIL'
end
t1 = Time.now.to_i
duration = t1 - t0
data << { :name => task, :status => status, :duration => Time.at(duration).utc.strftime("%H:%M:%S") }
end
puts
puts
printf "%-30s %-6s %s\n", '-' * 30, '-' * 6, '--------'
printf "%-30s %-6s %s\n", 'Task', 'Status', 'Duration'
printf "%-30s %-6s %s\n", '-' * 30, '-' * 6, '--------'
data.each do |entry|
printf "%-30s %-6s %s\n", entry[:name], entry[:status], entry[:duration]
end
printf "%-30s %-6s %s\n", '-' * 30, '-' * 6, '--------'
puts
abort "Errors running #{failed.join(', ')}!" if failed.any?