# ******************************************************************************* # OpenStudio(R), Copyright (c) Alliance for Sustainable Energy, LLC. # See also https://openstudio.net/license # ******************************************************************************* # insert your copyright here require 'openstudio' require 'openstudio/measure/ShowRunnerOutput' require 'minitest/autorun' require_relative '../measure.rb' require 'fileutils' require 'json' class ReduceDomesticHotWaterUseForPeakHoursTest < Minitest::Test # def setup # end # def teardown # end def test_good_argument_values # create an instance of the measure measure = ReduceDomesticHotWaterUseForPeakHours.new # create runner with empty OSW osw = OpenStudio::WorkflowJSON.new runner = OpenStudio::Measure::OSRunner.new(osw) # load the test model translator = OpenStudio::OSVersion::VersionTranslator.new path = "#{File.dirname(__FILE__)}/MediumOffice-90.1-2010-ASHRAE 169-2013-5A-HPWH.osm" model = translator.loadModel(path) assert(!model.empty?) model = model.get # get arguments arguments = measure.arguments(model) argument_map = OpenStudio::Measure.convertOSArgumentVectorToMap(arguments) # create hash of argument values. # If the argument has a default that you want to use, you don't need it in the hash args_hash = {} args_hash['water_use_reduce_percent'] = 20 args_hash['start_time'] = '16:00:00' args_hash['end_time'] = '21:00:00' # populate argument with specified hash value if specified arguments.each do |arg| temp_arg_var = arg.clone if args_hash.key?(arg.name) assert(temp_arg_var.setValue(args_hash[arg.name])) end argument_map[arg.name] = temp_arg_var end puts argument_map.values.inspect # run the measure measure.run(model, runner, argument_map) result = runner.result # show the output show_output(result) # assert that it ran correctly assert_equal('Success', result.value.valueName) assert(result.warnings.empty?) # save the model to test output directory output_file_path = "#{File.dirname(__FILE__)}//output/test_output.osm" model.save(output_file_path, true) # test run the modified model osw = {} osw["weather_file"] = File.join(File.dirname(__FILE__ ), "CZ06RV2.epw") osw["seed_file"] = output_file_path osw_path = "#{File.dirname(__FILE__)}//output/test_output.osw" File.open(osw_path, 'w') do |f| f << JSON.pretty_generate(osw) end cli_path = OpenStudio.getOpenStudioCLI cmd = "\"#{cli_path}\" run -w \"#{osw_path}\"" puts cmd system(cmd) end end