Skip to content

Commit

Permalink
Merge branch 'develop' into feature_2586_gen_vx_mask_solar_time
Browse files Browse the repository at this point in the history
  • Loading branch information
georgemccabe committed Dec 19, 2024
2 parents ac4a34e + bf72040 commit 4e1ee99
Show file tree
Hide file tree
Showing 11 changed files with 134 additions and 42 deletions.
1 change: 1 addition & 0 deletions docs/Release_Guide/metplus_development.rst
Original file line number Diff line number Diff line change
Expand Up @@ -21,4 +21,5 @@ Create a new vX.Y.Z-betaN or vX.Y.Z-rcN development release from the develop bra
.. include:: release_steps/metplus/update_version_on_develop.rst
.. include:: release_steps/metplus/update_dtc_website.rst
.. include:: release_steps/finalize_release_on_github_development.rst
.. include:: release_steps/metplus/update_web_server_data.rst
.. include:: release_steps/release_acceptance_testing.rst
1 change: 0 additions & 1 deletion docs/Release_Guide/metplus_official.rst
Original file line number Diff line number Diff line change
Expand Up @@ -24,5 +24,4 @@ Create a new vX.Y.Z official release from the develop branch.
.. include:: release_steps/update_docs_official.rst
.. include:: release_steps/metplus/add_next_version_to_lookup.rst
.. include:: release_steps/metplus/coordinated_release_announcement.rst
.. include:: release_steps/metplus/update_web_server_data.rst
.. include:: release_steps/set_beta_deletion_reminder_official.rst
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,12 @@ Return to GitHub to finalize the details of this release.

.. dropdown:: Instructions

* Update issues:

* Close the GitHub issue for creating this official release.

* If necessary, reassign any remaining issues for the current milestone to other milestones.

* Update milestones:

* Edit the milestone for the current release by updating the *Due date* with the actual release date.
Expand All @@ -15,12 +21,6 @@ Return to GitHub to finalize the details of this release.

* If necessary, create a new milestone for the next official release (e.g. next vX.Y.Z release).

* Update issues:

* Close the GitHub issue for creating this official release.

* If necessary, reassign any remaining issues for the current milestone to other milestones.

* Update projects:

* Close the existing development project for the current milestone.
Expand Down
56 changes: 31 additions & 25 deletions docs/Release_Guide/release_steps/metplus/update_web_server_data.rst
Original file line number Diff line number Diff line change
Expand Up @@ -4,37 +4,43 @@ Update DTC Web Server Data
Create Directory for Next Release
"""""""""""""""""""""""""""""""""

On the DTC web server where the sample input data for use cases is hosted,
run the setup_next_release_data.py script for the next upcoming release
to set up the data directory for the next major/minor version development.
The script can be found in the METplus repository in internal/tests/use_cases.
The file should be found in the home directory of the met_test user on
the DTC web server host. It is linked to the file in the METplus repository.
Pull the latest changes from the develop branch before running the script::
.. dropdown:: If creating a rc1 release

runas met_test
cd /home/met_test/METplus
git checkout develop
git pull
On the DTC web server where the sample input data for use cases is hosted,
run the setup_next_release_data.py script for the next upcoming release
to set up the data directory for the next major/minor version development.
The script can be found in the METplus repository in internal/tests/use_cases.
The file should be found in the home directory of the met_test user on
the DTC web server host. It is linked to the file in the METplus repository.
Pull the latest changes from the develop branch before running the script::

Now run the script passing in the version of the next release, i.e.
if creating the v4.1.0 release, pass in v5.0 as the argument::
runas met_test
cd /home/met_test/METplus
git checkout develop
git pull

new_version=v5.0
/home/met_test/setup_next_release_data.py ${new_version}
Now run the script passing in the version of the next release, i.e.
if creating the v6.0.0-rc1 release, pass in v6.1 as the argument::

See the comments in the script for more details.
Ensure that the script runs without error and that the newly created
directory contains links to all of the sample data tar files::
new_version=v6.1
/home/met_test/setup_next_release_data.py ${new_version}

ls -lh /home/met_test/METplus_Data/${new_version}
See the comments in the script for more details.
Ensure that the script runs without error and that the newly created
directory contains links to all of the sample data tar files::

Untar each of the sample data tarfiles so the model_applications and
met_test directories exist::
ls -lh /home/met_test/METplus_Data/${new_version}

cd /home/met_test/METplus_Data/${new_version}
for f in sample_data*; do echo tar xzf $f;tar xzf $f; done
Untar each of the sample data tarfiles so the model_applications and
met_test directories exist::

Check if the met_test and model_applications directories now exist::
cd /home/met_test/METplus_Data/${new_version}
for f in sample_data*; do echo tar xzf $f;tar xzf $f; done

ls -lh /home/met_test/METplus_Data/${new_version}
Check if the met_test and model_applications directories now exist::

ls -lh /home/met_test/METplus_Data/${new_version}

.. dropdown:: If creating a betaN or rc2+ release

Continue to the next instruction.
10 changes: 5 additions & 5 deletions docs/Release_Guide/release_steps/update_docs_official.rst
Original file line number Diff line number Diff line change
Expand Up @@ -13,15 +13,15 @@ repository will need to do the following to update the default branch:

* Click on the appropriate METplus component project

* Click on Admin in the top menu

* Click on Advanced Settings in the left menu
* Click on Settings in the top right menu

* Select the new default branch in the dropdown menu for "Default branch"
(e.g. main_v4.0.0)
(e.g. main_v4.0.0) and click the Save button at the bottom of the page

* Ensure that "latest" points to the new default branch by clicking on
"View Docs"in the upper right corner and confirm that the version number
"latest" build that just started and click on "Version latest" to view the
build run. When it finishes running, click on "View Docs" on the right of
the page and confirm that the version number
displayed in the header is the desired version for "latest".


59 changes: 59 additions & 0 deletions internal/scripts/dev_tools/compile_official_release_notes.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
#! /usr/bin/env python3

# Written by George McCabe <[email protected]>
# Helper script that parses release notes from development releases,
# gathers all issues by category, sorts them by issue number, then
# outputs the formatted content
# Note: Careful review and massaging of output is likely needed
# Run this script from the top of the repository to parse
# Assumes location and name of release notes RST file

import re

infile = './docs/Users_Guide/release-notes.rst'

with open(infile, 'r') as file_handle:
content = file_handle.read().splitlines()

category = None
items = {}
# gather issues and organize them by category
for line in content:
if match := re.match(r' .. dropdown:: (.*)', line):
category = match.group(1)
if not items.get(category):
items[category] = []
continue
if category is None: continue
if not line: continue
if line.strip().startswith('.. _'):
break
if line.lstrip().startswith('*'):
items[category].append(line)
elif line.strip().lower() == 'none' or line.startswith('MET') or line.startswith('---') or line.startswith('==='):
continue
elif not items.get(category):
continue
else:
items[category][-1] += f'\n{line}'

# get issues in each category to sort
issues = {}
for cat, item_list in items.items():
if not issues.get(cat):
issues[cat] = {}
for issue in item_list:
match = re.match(r'.*\#(\d+).*', issue.replace('\n', ''))
if match:
issues[cat][match.group(1)] = issue

# sort issues within each category and print formatted result
for cat in issues:
nums = sorted([int(item) for item in issues[cat].keys()])
print(f" .. dropdown:: {cat}\n")
if not nums:
print(' None\n')
continue
for num in nums:
print(issues[cat][str(num)])
print()
5 changes: 4 additions & 1 deletion internal/scripts/dev_tools/generate_release_notes.py
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,10 @@ def print_issues_by_category(repo_name, issues_by_category):
for category, issues in issues_by_category.items():
print()
if category != 'none':
print(f" .. dropdown:: {category}\n")
header = category
if header in ('Enhancement', 'New Wrapper', 'New Use Case'):
header = f'{header}s'
print(f" .. dropdown:: {header}\n")
elif issues:
print('COULD NOT PARSE CATEGORY FROM THESE:\n')

Expand Down
4 changes: 2 additions & 2 deletions internal/tests/pytests/requirements.txt
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
certifi==2023.7.22
certifi==2024.7.4
cftime==1.6.2
coverage==7.2.7
exceptiongroup==1.1.2
Expand All @@ -8,7 +8,7 @@ numpy==1.25.2
packaging==23.1
pandas==2.0.3
pdf2image==1.16.3
Pillow==10.0.0
Pillow==10.3.0
pluggy==1.2.0
pytest==7.4.0
pytest-cov==4.1.0
Expand Down
10 changes: 10 additions & 0 deletions internal/tests/pytests/util/run_util/test_run_util.py
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,10 @@
'INPUT_THRESH',
]

def remove_output_base(config):
config_output_base = config.getdir("OUTPUT_BASE")
if config_output_base and os.path.exists(config_output_base):
ru.shutil.rmtree(config_output_base)

def get_run_util_configs(conf_name):
script_dir = os.path.dirname(__file__)
Expand Down Expand Up @@ -130,6 +134,7 @@ def test_pre_run_setup():
expected_stage = os.path.join(actual.get('config', 'OUTPUT_BASE'), 'stage')
assert actual.get('config', 'STAGING_DIR') == expected_stage
assert actual.get('user_env_vars', 'GODS_OF_WEATHER') == 'Indra_Thor_Zeus'
remove_output_base(actual)


@pytest.mark.util
Expand All @@ -139,6 +144,7 @@ def test_pre_run_setup_env_vars():
actual = ru.pre_run_setup(conf_inputs)
assert actual.env['MY_ENV_VAR'] == '42'
assert actual.get('config', 'OMP_NUM_THREADS') == '4'
remove_output_base(actual)


@pytest.mark.util
Expand Down Expand Up @@ -262,6 +268,7 @@ def test_run_metplus(capfd, config_dict, expected, check_err):
else:
assert err == ''

remove_output_base(config)

@pytest.mark.parametrize(
"side_effect,return_value,check_err",
Expand All @@ -285,6 +292,8 @@ def test_run_metplus_errors(capfd, side_effect, return_value, check_err):
else:
assert err == check_err

remove_output_base(config)


@pytest.mark.util
def test_get_wrapper_instance(metplus_config):
Expand All @@ -308,6 +317,7 @@ def test_get_wrapper_instance_raises(capfd, side_effect, check_err):
assert actual == None
out, err = capfd.readouterr()
assert check_err in err
remove_output_base(config)


@pytest.mark.util
Expand Down
13 changes: 11 additions & 2 deletions metplus/component_versions.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,23 @@
import sys

VERSION_LOOKUP = {
'6.1': {
'metplus': '6.1.0',
'met': '12.1.0',
'metplotpy': '3.1.0',
'metcalcpy': '3.1.0',
'metdataio': '3.1.0',
'metviewer': '6.1.0',
'metexpress': None,
},
'6.0': {
'metplus': '6.0.0',
'met': '12.0.0',
'metplotpy': '3.0.0',
'metcalcpy': '3.0.0',
'metdataio': '3.0.0',
'metviewer': '6.0.0',
'metexpress': None,
'metexpress': '6.0.0',
},
'5.1': {
'metplus': '5.1.0',
Expand All @@ -30,7 +39,7 @@
'metcalcpy': '2.1.0',
'metdataio': '2.1.0',
'metviewer': '5.1.0',
'metexpress': '5.3.3',
'metexpress': '5.3.5',
},
}

Expand Down
5 changes: 5 additions & 0 deletions metplus/util/config_metplus.py
Original file line number Diff line number Diff line change
Expand Up @@ -462,6 +462,8 @@ def __init__(self, conf=None, run_id=None):
super().__init__(conf)
self._cycle = None
self.run_id = run_id if run_id else str(uuid.uuid4())[0:8]
# if run ID is specified, this is a copy of a config
self.is_copy = run_id is not None
self._logger = logging.getLogger(f'metplus.{self.run_id}')
# config.logger is called in wrappers, so set this name
# so the code doesn't break
Expand All @@ -475,6 +477,9 @@ def __init__(self, conf=None, run_id=None):

def __del__(self):
"""!When object is deleted, close and remove all log handlers"""
# do not close log handlers if this is a copied config object
if self.is_copy:
return
handlers = self.logger.handlers[:]
for handler in handlers:
self.logger.removeHandler(handler)
Expand Down

0 comments on commit 4e1ee99

Please sign in to comment.