Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Changes to integrate t-route master branch #502

Merged
merged 6 commits into from
Mar 29, 2023

Conversation

mattw-nws
Copy link
Contributor

@mattw-nws mattw-nws commented Mar 23, 2023

Routing_Py_Adapter now attempts to run the master branch main_v04 method if the legacy ngen_routing module is not found (this is not preference ordering, rather is the easiest way to determine which of the two is installed), so either version is runnable. Notably, however, all automated test code now tests the master branch and not the legacy ngen branch!

Additions

  • Code to run the new master branch main_v04 method in t-route
  • A test case to use on with the master branch

Removals

  • Unit test for legacy ngen branch version of t-route... while still possible to use, it is no longer integration tested!

Changes

Testing

  1. Automated tests passing
  2. Included somewhat complex test case in data/gauge_01073000, which successfully produces output.

Screenshots

Notes

Todos

  • Eventually, the legacy ngen branch support should be removed.

Checklist

  • PR has an informative and human-readable title
  • Changes are limited to a single goal (no scope creep)
  • Code can be automatically merged (no conflicts)
  • Code follows project standards (link if applicable)
  • Passes all existing automated tests
  • Any change in functionality is tested
  • New functions are documented (with a description, list of inputs, and expected output)
  • Placeholder code is flagged / future todos are captured in comments
  • Project documentation has been updated (including the "Unreleased" section of the CHANGELOG)
  • Reviewers requested with the Reviewers tool ➡️

Testing checklist (automated report can be put here)

Target Environment support

  • Linux

@mattw-nws
Copy link
Contributor Author

@hellkite500 @donaldwj @robertbartel ... maybe @shorvath-noaa and @kumdonoaa ... Before I fix the last test...

With this PR the ngen code itself can now--for now--work with either the old legacy ngen_main t-route code or the new nwm_routing module. This is particularly for use cases where old configs exist, I'm thinking particularly of the calibration work. The question is, what, if anything, should we do with extern/t-route? Should I bump it to t-route:master? Should I leave it in place for now pointing to the ngen branch (we may or may not want to bump the commit in that branch)? Should I remove it entirely?

My inclination is to encourage the build/installation of t-route separately going forward, especially since ngen will find it as long as it's installed (doesn't have to be in a particular dir, like the other modules in extern...or at least more so). So what to do with extern/t-route?

@hellkite500
Copy link
Contributor

I'm inclined to remove the sub module all together and replace it with a little documentation on pulling and installing the desired branch.

@kumdonoaa
Copy link

@mattw-nws Just trying to understand what bumping it to t-route:master means, can you explain what changes would or should be made from the action and what results would come in terms of running t-route. Thanks.

@mattw-nws
Copy link
Contributor Author

@mattw-nws Just trying to understand what bumping it to t-route:master means

Sure, it's basically only a matter of what version of t-route we are "bundling" (in source form) with ngen, if any... we have previously been including the t-route source as a git submodule inside the ngen repo... the question is whether we should continue doing that and what version if any.

@mattw-nws
Copy link
Contributor Author

Related question... should we keep the troute integration test in the ngen repo... or make a test for ngen integration in the t-route repo... or other?

@kumdonoaa
Copy link

Regarding the troute integration test, I feel that we need a meeting where Sean first demonstrates the progress of implementing BMI to t-route and reservoir modules so that you can give us feedbacks on whether we're on a right track or not. After that, it would be great to show us how it looks like to do the integration test from ngen side and what are required. Would that be a good starting point?

@mattw-nws
Copy link
Contributor Author

This now needs NOAA-OWP/t-route#606 to merge before the macOS routing test will pass, I think.

@mattw-nws mattw-nws changed the title basic t-route master branch changes with test case dataset Changes to integrate t-route master branch Mar 27, 2023
@mattw-nws mattw-nws requested a review from donaldwj March 27, 2023 18:43
@mattw-nws mattw-nws marked this pull request as ready for review March 27, 2023 18:43
@mattw-nws
Copy link
Contributor Author

Believe that when t-route/#606 is merged, the failing macOS test may fix itself... if not some small change may be required here, but everything is failing that test ATM.

Copy link
Contributor

@donaldwj donaldwj left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Almost completely configuration file changes. We may want to document the changes in the pull request page

@mattw-nws
Copy link
Contributor Author

Yes the configuration file for t-route is changed very substantially. The documentation probably goes in t-route, however, I'd think.

I also filed #505 on the macOS forkbomb issue.

mattw-nws added a commit to mattw-nws/ngen that referenced this pull request Mar 29, 2023
@mattw-nws mattw-nws mentioned this pull request Mar 29, 2023
11 tasks
@mattw-nws mattw-nws merged commit 96eede1 into NOAA-OWP:master Mar 29, 2023
@mattw-nws mattw-nws mentioned this pull request Mar 29, 2023
4 tasks
mattw-nws added a commit to mattw-nws/ngen that referenced this pull request Apr 11, 2023
aaraney added a commit that referenced this pull request Jun 5, 2023
* First draft docs update goes with #502

* minor revisions following first review of #506.

---------

Co-authored-by: Austin Raney <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants