forked from NREL/openstudio-standards
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Rakefile
250 lines (222 loc) · 7.9 KB
/
Rakefile
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
require 'bundler/gem_tasks'
require 'json'
require 'fileutils'
begin
Bundler.setup
rescue Bundler::BundlerError => e
warn e.message
warn 'Run `bundle install` to install missing gems'
exit e.status_code
end
require 'rake/testtask'
namespace :test do
full_file_list = nil
if File.exist?('test/circleci_tests.txt')
# load test files from file.
full_file_list = FileList.new(File.readlines('test/circleci_tests.txt'))
# Select only .rb files that exist
full_file_list.select! { |item| item.include?('rb') && File.exist?(File.absolute_path("test/#{item.strip}")) }
full_file_list.map! { |item| File.absolute_path("test/#{item.strip}") }
File.open('test/circleci_tests.json', 'w') do |f|
f.write(JSON.pretty_generate(full_file_list.to_a))
end
else
puts 'Could not find list of files to test at test/circleci_tests.txt'
return false
end
desc 'parallel_run_all_tests_locally'
Rake::TestTask.new('parallel_run_all_tests_locally') do |t|
# Make an empty test/reports directory
report_dir = 'test/reports'
FileUtils.rm_rf(report_dir) if Dir.exist?(report_dir)
Dir.mkdir(report_dir)
file_list = FileList.new('test/parallel_run_all_tests_locally.rb')
t.libs << 'test'
t.test_files = file_list
t.verbose = false
end
# These tests only available in the CI environment
if ENV['CI'] == 'true'
desc 'Run CircleCI tests'
Rake::TestTask.new('circleci') do |t|
# Create a FileList for this task
test_list = FileList.new
# Read the parallelized list of tests
# created by the circleci CLI in config.yml
if File.exist?('node_tests.txt')
File.open('node_tests.txt', 'r') do |f|
f.each_line do |line|
# Skip comments the CLI may have included
next unless line.include?('.rb')
# Remove whitespaces
line = line.strip
# Ensure the file exists
pth = File.absolute_path("test/#{line}")
unless File.exist?(pth)
puts "Skipped #{line} because this file doesn't exist"
next
end
# Add this test to the list
test_list.add(pth)
end
end
# Assign the tests to this task
t.test_files = test_list
else
puts 'Could not find parallelized list of CI tests.'
end
end
desc 'Summarize the test timing'
task 'times' do |t|
require 'nokogiri'
files_to_times = {}
tests_to_times = {}
Dir['test/reports/*.xml'].each do |xml|
doc = File.open(xml) { |f| Nokogiri::XML(f) }
doc.css('testcase').each do |testcase|
time = testcase.attr('time').to_f
file = testcase.attr('file')
name = testcase.attr('name')
# Add to total for this file
if files_to_times[file].nil?
files_to_times[file] = time
else
files_to_times[file] += time
end
# Record for this test itself
if tests_to_times[name].nil?
tests_to_times[name] = time
else
tests_to_times[name] += time
end
end
end
# Write out the test results to file
folder = "#{Dir.pwd}/timing"
Dir.mkdir(folder) unless File.exist?(folder)
# By file
File.open("#{Dir.pwd}/timing/test_by_file.html", 'w') do |html|
html.puts '<table><tr><th>File Name</th><th>Time (min)</th></tr>'
files_to_times.each do |f, time_s|
s = (time_s / 60).round(1) # convert time from sec to min
html.puts "<tr><td>#{f}</td><td>#{s}</td></tr>"
end
html.puts '</table>'
end
# By name
File.open("#{Dir.pwd}/timing/test_by_name.html", 'w') do |html|
html.puts '<table><tr><th>Test Name</th><th>Time (min)</th></tr>'
tests_to_times.each do |f, time_s|
s = (time_s / 60).round(1) # convert time from sec to min
html.puts "<tr><td>#{f}</td><td>#{s}</td></tr>"
end
html.puts '</table>'
end
end
end
end
# Tasks to manage the spreadsheet data
namespace :data do
require "#{File.dirname(__FILE__)}/data/standards/manage_OpenStudio_Standards.rb"
# OpenStudio Standards spreadsheet names
# Order matters: most general/shared must be first,
# as data may be overwritten when parsing later spreadsheets.
spreadsheets_ashrae = [
'OpenStudio_Standards-ashrae_90_1',
'OpenStudio_Standards-ashrae_90_1(space_types)',
'OpenStudio_Standards-ashrae_90_1_prm',
'OpenStudio_Standards-ashrae_90_1_prm(space_types)'
]
spreadsheets_deer = [
'OpenStudio_Standards-deer',
'OpenStudio_Standards-deer(space_types)'
]
spreadsheets_comstock = [
'OpenStudio_Standards-ashrae_90_1',
'OpenStudio_Standards-ashrae_90_1-ALL-comstock(space_types)',
'OpenStudio_Standards-deer',
'OpenStudio_Standards-deer-ALL-comstock(space_types)'
]
spreadsheets_cbes = [
'OpenStudio_Standards-cbes',
'OpenStudio_Standards-cbes(space_types)'
]
spreadsheet_titles = spreadsheets_ashrae + spreadsheets_deer + spreadsheets_comstock + spreadsheets_cbes
spreadsheet_titles = spreadsheet_titles.uniq
desc 'Check Google Drive configuration'
task 'apicheck' do
check_google_drive_configuration
end
desc 'Download OpenStudio_Standards spreadsheets from Google Drive'
task 'download' do
download_google_spreadsheets(spreadsheet_titles)
end
desc 'Download OpenStudio_Standards spreadsheets and generate JSONs'
task 'update' do
download_google_spreadsheets(spreadsheet_titles)
export_spreadsheet_to_json(spreadsheet_titles)
end
desc 'Generate JSONs from OpenStudio_Standards spreadsheets'
task 'update:manual' do
export_spreadsheet_to_json(spreadsheet_titles)
end
desc 'Export JSONs from OpenStudio_Standards to data library'
task 'export:jsons' do
export_spreadsheet_to_json(spreadsheets_ashrae, dataset_type: 'data_lib')
end
end
# Tasks to export libraries packaged with
# the OpenStudio installer
namespace :library do
require "#{File.dirname(__FILE__)}/data/standards/export_OpenStudio_libraries.rb"
desc 'Export libraries for OpenStudio installer'
task 'export' do
export_openstudio_libraries
end
end
require 'yard'
desc 'Generate the documentation'
YARD::Rake::YardocTask.new(:doc) do |t|
require_relative 'lib/openstudio-standards/prototypes/common/prototype_metaprogramming.rb'
# Generate temporary building type class files so that
# the documentation shows these classes
save_meta_classes_to_file
t.stats_options = ['--list-undoc']
end
desc 'Show the documentation in a web browser'
task 'doc:show' => [:doc] do
link = "#{Dir.pwd}/doc/index.html"
if RbConfig::CONFIG['host_os'] =~ /mswin|mingw|cygwin/
system "start #{link}"
elsif RbConfig::CONFIG['host_os'] =~ /darwin/
system "open #{link}"
elsif RbConfig::CONFIG['host_os'] =~ /linux|bsd/
system "xdg-open #{link}"
end
# Remove the generated temporary files
remove_meta_class_file
end
require 'rubocop/rake_task'
desc 'Check the code for style consistency'
RuboCop::RakeTask.new(:rubocop) do |t|
# Make a folder for the output
out_dir = '.rubocop'
Dir.mkdir(out_dir) unless File.exist?(out_dir)
# Output both XML (CheckStyle format) and HTML
t.options = ["--out=#{out_dir}/rubocop-results.xml", '--format=h', "--out=#{out_dir}/rubocop-results.html", '--format=offenses', "--out=#{out_dir}/rubocop-summary.txt"]
t.requires = ['rubocop/formatter/checkstyle_formatter']
t.formatters = ['RuboCop::Formatter::CheckstyleFormatter']
# don't abort rake on failure
t.fail_on_error = false
end
desc 'Show the rubocop output in a web browser'
task 'rubocop:show' => [:rubocop] do
link = "#{Dir.pwd}/.rubocop/rubocop-results.html"
if RbConfig::CONFIG['host_os'] =~ /mswin|mingw|cygwin/
system "start #{link}"
elsif RbConfig::CONFIG['host_os'] =~ /darwin/
system "open #{link}"
elsif RbConfig::CONFIG['host_os'] =~ /linux|bsd/
system "xdg-open #{link}"
end
end