Development Process
- Have CI added to any new SDK repo
- Write tests for new code functionality. Run the tests locally
- Make sure there is an issue created for items you are working on (for tracking purposes and so that the item appears in the changelog for the release). Use the following labels on the GitHub issue:
- Feature (features will appear as “New” item in the changelog)
- Enhancement (these will appear as “Improved” in the changelog)
- Bug (these will appear as “Fixed” in the changelog)
- Branch off of the
develop
branch (unless it is a hotfix for production) - When done, create pull requests against the
develop
branch. You can group related issues together in the same PR).- Make sure all tests are passing and run rubocop
- Assign a reviewer to look over the code
- Use the “DO NOT MERGE” label for Pull Requests that should not be merged
Functionality Development / Copying over to the CLI
Functionality should be developed in the urbanopt-example-geojson-project repo. Once it is ready and passing tests, the files from urbanopt-example-geojson-project will be copied over to the urbanopt-cli repo. Take care when performing the copy process as it is possible some changes were made directly on the cli repo (i.e., you might have to diff the files and reconcile both repos with the latest changes).
Notes for the copy process (from example-project repo to cli repo):
- Copy example_project/resources folder to example_files/resources
- Delete the contents of resources/residential-measures/weather/ so it is just an empty dir
- Copy the contents of the mappers folder to the CLI
- Pasting in the contents of the folder will help ensure you don’t overwrite the Class Project items
- mappers/residential/tests/ can be deleted as it is generated from the tests
- copy the measures folder to example_files/measures
- copy xml_building to example_files/xml_building
- copy osm_building to example_files/osm_building
- copy reopt to example_files/reopt. (on this one maybe diff the files to ensure that changes weren’t just made on the CLI repo)
- copy visualization to example_files/visualization
- There is no need to copy any of the scenario CSVs
Conflicting packages
If you make changes, ensure that all gems use the openstudio-standards
gem shipped with OpenStudio to avoid unforeseen consequences (do not include an openstudio-standards dependency in the gemfile).
Generating rdoc Documentation
Follow these steps to generate rdocs for new and existing SDK gems:
- Install NodeJS
- Go to the repository docs file, eg. urbanopt-scenario-gem/docs and type
npm install
- Move to the root level of the repo, eg. urbanopt-scenario-gem and enter these commands:
bundle exec rdoc --template-stylesheets ./docs/.vuepress/public/custom_rdoc_styles.css
npm run build --prefix docs
- Finally, to deploy the docs, enter:
npm run deploy --prefix docs
Rdoc options are controlled with this config file.
Developing with the CLI
When developing locally on URBANopt™ gems and testing new functionality and dependencies via the CLI, it may be necessary to install local versions of some gems.
For local development, you will want to set the environment variable FAVOR_LOCAL_GEMS to 1. This enables local copies of gems in the Gemfile. Note that setting FAVOR_LOCAL_GEMS to 0 will not undo local gems functionality: you will have to either remove the FAVOR_LOCAL_GEMS environment variable or set it to nil or false (not 0), and open a new terminal window to turn it off.
There are 2 Gemfiles of interest:
-
When testing a new measure that will run in the OpenStudio workflow OSW file, enable the gem that contains the measure in the Gemfile of the project you are testing by uncommenting the appropriate block of code. You may have to modify the path or branch referenced to match what you are testing. If you are adding a new OpenStudio measure gem, you will also need to (temporarily) add it to the CLI gemfile until you have released the measure gem on rubygems.org. Follow the instructions below to install the CLI in development mode once you have the gem added to the CLI Gemfile.
-
When testing new functionality in the URBANOPT workflow (a new scenario post-processor, for example), enable the gem in the Gemfile of the URBANopt-cli local directory by uncommenting the appropriate block of code. You may have to modify the path or branch referenced to match what you are testing.
Follow these steps when testing local gems via the CLI:
bundle install
(to install the local gems that were just enabled in the Gemfile)bundle exec rake install
(to install the CLI in a place that has access to those local gems)bundle exec uo ...
(to execute the CLI calls)
Example Project Development
- Develop new functionality in the example project directory.
- When the functionality is ready and all tests are passing, update the example project files in the urbanopt-cli repo.