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

Fix chdir and add tests for fsutils functions #45

Merged
merged 8 commits into from
Nov 15, 2024

Conversation

DavidHuber-NOAA
Copy link
Collaborator

Description

This modifies chdir so that it produces an error if the target directory is not available and returns to the original working directory when the with completes without producing a warning.

Tests were added to verify that chdir, as well as the other fsutils, run as expected. While writing these tests, the following issues were found and fixed:

  • mkdir_p was simplified to use the os.mkdir exist_ok=True parameter instead of attempting to handle that in wxflow.
  • Added a missing_ok parameter to rmdir to allow missing directories to be skipped without error.
  • Improved rm_p error handling and added a missing_okparameter.

Lastly, the only function that did not have a test added was chgrp. I am not sure what groups are available on GitHub runners, so I am not sure how this could be tested reliably.

Type of change

  • Bug fix (non-breaking change which fixes an issue)
  • New tests

How Has This Been Tested?

  • pynorms
  • pytests

Checklist

  • My code follows the style guidelines of this project
  • I have performed a self-review of my own code
  • I have commented my code, particularly in hard-to-understand areas
  • My changes generate no new warnings
  • New and existing tests pass with my changes

if missing_ok:
logger.warning(f"WARNING cannot remove the target path {dir_path} because it does not exist")
else:
raise exc
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
raise exc
raise FileNotFoundError()

Should this raise this error specifically. Not sure how this works, if its trying to remove something that is not existant.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Since exc is the original FileNotFoundError, raising exc is equivalent to raising FileNotFoundError. But, raising a custom FileNotFoundError with an more specific error message would be useful. I'll add that in.

So if the file doesn't exist, nothing will happen but rmtree will return a FileNotFoundError. If missing_ok=False, then this Exception will be passed on. Otherwise, you get a warning for trying.

Copy link

codecov bot commented Nov 14, 2024

Codecov Report

Attention: Patch coverage is 83.33333% with 4 lines in your changes missing coverage. Please review.

Project coverage is 52.41%. Comparing base (e1ef697) to head (6524b8b).
Report is 2 commits behind head on develop.

Files with missing lines Patch % Lines
src/wxflow/fsutils.py 83.33% 4 Missing ⚠️
Additional details and impacted files
@@             Coverage Diff             @@
##           develop      #45      +/-   ##
===========================================
+ Coverage    50.12%   52.41%   +2.29%     
===========================================
  Files           18       18              
  Lines         1652     1679      +27     
  Branches       339      296      -43     
===========================================
+ Hits           828      880      +52     
+ Misses         765      749      -16     
+ Partials        59       50       -9     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Copy link
Contributor

@aerorahul aerorahul left a comment

Choose a reason for hiding this comment

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

lgtm. thanks for beefing up fsutils and adding tests.

@DavidHuber-NOAA DavidHuber-NOAA merged commit a7b49e9 into NOAA-EMC:develop Nov 15, 2024
9 checks passed
DavidHuber-NOAA added a commit to NOAA-EMC/global-workflow that referenced this pull request Dec 9, 2024
…3105)

# Description
This adds the capability to archive the experiment directory.
Additionally, this adds options to run `git status` and `git diff` on
the `HOMEgfs` global workflow (but not the submodules) and store that
information within the experiment directory's archive. These options are
specified in `config.base` with the following defaults:

```bash
export ARCH_EXPDIR='YES'     # Archive the EXPDIR configs, XML, and database
export ARCH_EXPDIR_FREQ=0    # How often to archive the EXPDIR in hours or 0 for first and last cycle only
export ARCH_HASHES='YES'     # Archive the hashes of the GW and submodules and 'git status' for each; requires ARCH_EXPDIR
export ARCH_DIFFS='NO'       # Archive the output of 'git diff' for the GW; requires ARCH_EXPDIR
```

Resolves #2994
# Type of change
- [x] New feature (adds functionality)

# Change characteristics
<!-- Choose YES or NO from each of the following and delete the other
-->
- Is this a breaking change (a change in existing functionality)? NO
- Does this change require a documentation update? YES
- Does this change require an update to any of the following submodules?
YES (If YES, please add a link to any PRs that are pending.)
  - [x] wxflow NOAA-EMC/wxflow#45

# How has this been tested?
- [x] Local archiving on Hercules for a C48_ATM case
- [x] Cycled testing on Hercules with `ARCH_DIFFS=YES` and
`ARCH_EXPDIR_FREQ=6,12`
- [x] Testing with `ARCH_EXPDIR=NO` or `ARCH_HASHES=NO`

# Checklist
- [x] Any dependent changes have been merged and published
- [x] My code follows the style guidelines of this project
- [x] I have performed a self-review of my own code
- [x] I have commented my code, particularly in hard-to-understand areas
- [x] I have documented my code, including function, input, and output
descriptions
- [x] My changes generate no new warnings
- [x] New and existing tests pass with my changes
- [x] This change is covered by an existing CI test or a new one has
been added
- [x] Any new scripts have been added to the .github/CODEOWNERS file
with owners
- [x] I have made corresponding changes to the system documentation if
necessary

---------

Co-authored-by: Walter Kolczynski - NOAA <Walter.Kolczynski@noaa.gov>
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