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

feature/capgen: add new tests for unit conversions #434

Merged

Conversation

climbfuji
Copy link
Collaborator

@climbfuji climbfuji commented Jan 20, 2022

Description

Add new tests for unit conversions as (1) unit tests and (2) system tests in a separate var_action_test folder. These are testing variables inside a DDT and outside, and with different intents (in, out, inout).

The unit tests all pass, because the unit conversion at variable level (class function compatible) is already implemented. The system tests fail, because capgen does not yet generate the unit conversion code at the suite level.

What's not included?

I was looking for possibilities to add unit tests at the suite_objects.py level, in particular around the analyze function of the scheme class. Implementing tests there in form of doc tests would be complicated and not so much different from the system tests in the new var_action_test folder.

It is also difficult to write unit tests alongside the new system tests, because I don't know how the exact code block should look like in capgen-generated code. Certainly different from the prebuild-generated code!

Additional details

User interface changes?: No

Fixes #430.

Testing:
test removed:
unit tests: unit tests (doc tests) for testing variable compatibility/unit conversions to metavar.py and var_props.py (these tests pass)
system tests: new test directory tests/var_action_test (these tests fail)
manual testing:

@gold2718
Copy link
Collaborator

Please do not overload capgen_test, it is already complicated enough.

@climbfuji
Copy link
Collaborator Author

Please do not overload capgen_test, it is already complicated enough.

The other option I can offer is to rsync capgen_test to another directory var_action_test, strip out everything that is not needed for the var action tests and and keep my proposed changes there.

This way we have the same framework for these end-to-end style tests, but with fewer code in each of them. Some code duplication, but maybe still better than overloading capgen_test.

@gold2718
Copy link
Collaborator

The other option I can offer is to rsync capgen_test to another directory var_action_test, strip out everything that is not needed for the var action tests and and keep my proposed changes there.

Yes please! That is the approach I took with the advection_test.

@climbfuji climbfuji force-pushed the feature/unit_conversions_in_capgen branch from 712df77 to ed34891 Compare January 21, 2022 03:51
@climbfuji
Copy link
Collaborator Author

The other option I can offer is to rsync capgen_test to another directory var_action_test, strip out everything that is not needed for the var action tests and and keep my proposed changes there.

Yes please! That is the approach I took with the advection_test.

Done. This looks much simpler now, and the tests are failing when comparing the return values to the expected values, so that's good because we expect this.

@climbfuji climbfuji marked this pull request as ready for review January 23, 2022 02:23
@climbfuji climbfuji requested a review from gold2718 as a code owner January 23, 2022 02:23
@climbfuji climbfuji changed the title DRAFT - Add new tests for unit conversions to capgen_test feature/capgen: add new tests for unit conversions Jan 23, 2022
Copy link
Collaborator

@gold2718 gold2718 left a comment

Choose a reason for hiding this comment

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

Thanks for creating this, I have a couple of questions and would like some minor cleanup.
This review was of 2e2d5da.

test/var_action_test/test_host.F90 Outdated Show resolved Hide resolved
test/var_action_test/test_host.F90 Outdated Show resolved Hide resolved
test/var_action_test/test_host_mod.F90 Outdated Show resolved Hide resolved
test/var_action_test/test_reports.py Outdated Show resolved Hide resolved
test/var_action_test/test_reports.py Outdated Show resolved Hide resolved
@climbfuji
Copy link
Collaborator Author

I made the changes as requested, including reducing the tolerance to 1.0E-10. This is to some extend a moot point, because if unit conversions are not implemented the differences are much larger, as ./run_tesh.sh shows:

1) var_action_suite = test_suites(1)
 Checking suite var_action_suite
Error: max diff of phys_state%effrl from expected value exceeds tolerance:    0.2499950E+01 >    0.5000000E-14
Error: max diff of phys_state%effri from expected value exceeds tolerance:    0.7499992E+02 >    0.7500000E-14
Error: max diff of            effrs from expected value exceeds tolerance:    0.9999990E+01 >    0.5100000E-13
 Answers are not correct!
STOP -1

All other tests pass, therefore this is expected.

@climbfuji climbfuji requested a review from gold2718 February 24, 2022 03:21
Copy link
Collaborator

@gold2718 gold2718 left a comment

Choose a reason for hiding this comment

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

Looks great now, thanks!!

@climbfuji climbfuji merged commit 195ee07 into NCAR:feature/capgen Feb 28, 2022
@climbfuji climbfuji deleted the feature/unit_conversions_in_capgen branch June 27, 2022 03:03
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.

2 participants