# ********************************************************************************* # URBANopt, Copyright (c) 2019-2020, Alliance for Sustainable Energy, LLC, and other # contributors. All rights reserved. # # Redistribution and use in source and binary forms, with or without modification, # are permitted provided that the following conditions are met: # # Redistributions of source code must retain the above copyright notice, this list # of conditions and the following disclaimer. # # Redistributions in binary form must reproduce the above copyright notice, this # list of conditions and the following disclaimer in the documentation and/or other # materials provided with the distribution. # # Neither the name of the copyright holder nor the names of its contributors may be # used to endorse or promote products derived from this software without specific # prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. # IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, # INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF # LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE # OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED # OF THE POSSIBILITY OF SUCH DAMAGE. # ********************************************************************************* require 'openstudio' require 'openstudio/ruleset/ShowRunnerOutput' require 'urbanopt/geojson' require 'minitest/autorun' require_relative '../measure.rb' require 'fileutils' class UrbanGeometryCreationTest < MiniTest::Unit::TestCase def test_one_building # create an instance of the measure measure = UrbanGeometryCreation.new # create an empty model model = OpenStudio::Model::Model.new # create an instance of a runner runner = OpenStudio::Measure::OSRunner.new(OpenStudio::WorkflowJSON.new) geojson_file = File.absolute_path(File.join(File.dirname(__FILE__), 'nrel_stm_footprints.geojson')) feature_id = '59a9ce2b42f7d007c059d2ee' # Energy Systems Integration Facility surrounding_buildings = 'None' # 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['geojson_file'] = geojson_file args_hash['feature_id'] = feature_id args_hash['surrounding_buildings'] = surrounding_buildings # populate argument with specified hash value if specified arguments.each do |arg| temp_arg_var = arg.clone if args_hash[arg.name] assert(temp_arg_var.setValue(args_hash[arg.name])) end argument_map[arg.name] = temp_arg_var end # run the measure measure.run(model, runner, argument_map) result = runner.result # save the model to test output directory output_file_path = OpenStudio::Path.new(File.dirname(__FILE__) + "/output/#{feature_id}.osm") model.save(output_file_path, true) # show the output show_output(result) # assert that it ran correctly assert_equal('Success', result.value.valueName) end def test_one_building_w_surrounding_buildings # create an instance of the measure measure = UrbanGeometryCreation.new # create an empty model model = OpenStudio::Model::Model.new # create an instance of a runner runner = OpenStudio::Measure::OSRunner.new(OpenStudio::WorkflowJSON.new) geojson_file = File.absolute_path(File.join(File.dirname(__FILE__), 'nrel_stm_footprints.geojson')) feature_id = '59a9ce2b42f7d007c059d2f0' surrounding_buildings = 'ShadingOnly' # 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['geojson_file'] = geojson_file args_hash['feature_id'] = feature_id args_hash['surrounding_buildings'] = surrounding_buildings # populate argument with specified hash value if specified arguments.each do |arg| temp_arg_var = arg.clone if args_hash[arg.name] assert(temp_arg_var.setValue(args_hash[arg.name])) end argument_map[arg.name] = temp_arg_var end # run the measure measure.run(model, runner, argument_map) result = runner.result # save the model to test output directory output_file_path = OpenStudio::Path.new(File.dirname(__FILE__) + "/output/#{feature_id}.osm") model.save(output_file_path, true) # show the output show_output(result) # assert that it ran correctly assert_equal('Success', result.value.valueName) end end