From 174105e0444087658fe979ee741443bcf6c1a4ca Mon Sep 17 00:00:00 2001
From: uramirez8707 <49168881+uramirez8707@users.noreply.github.com>
Date: Thu, 14 Nov 2024 10:11:47 -0500
Subject: [PATCH] fix: make define_blocks warning a note (#1588)
---
block_control/block_control.F90 | 17 +++--
configure.ac | 1 +
test_fms/Makefile.am | 2 +-
test_fms/block_control/Makefile.am | 47 +++++++++++++
test_fms/block_control/test_block_control.F90 | 69 +++++++++++++++++++
test_fms/block_control/test_block_control.sh | 38 ++++++++++
.../diag_manager/test_reduction_methods.F90 | 1 +
7 files changed, 168 insertions(+), 7 deletions(-)
create mode 100644 test_fms/block_control/Makefile.am
create mode 100644 test_fms/block_control/test_block_control.F90
create mode 100755 test_fms/block_control/test_block_control.sh
diff --git a/block_control/block_control.F90 b/block_control/block_control.F90
index fd385e8266..f78e8659f3 100644
--- a/block_control/block_control.F90
+++ b/block_control/block_control.F90
@@ -23,8 +23,9 @@
module block_control_mod
-use mpp_mod, only: mpp_error, NOTE, WARNING, FATAL
+use mpp_mod, only: mpp_error, NOTE, WARNING, FATAL, mpp_sum, mpp_npes
use mpp_domains_mod, only: mpp_compute_extent
+use fms_string_utils_mod, only: string
implicit none
public block_control_type
@@ -104,15 +105,19 @@ subroutine define_blocks (component, Block, isc, iec, jsc, jec, kpts, &
integer, dimension(ny_block) :: j1, j2
character(len=256) :: text
integer :: i, j, nblks, ix, ii, jj
+ integer :: non_uniform_blocks !< Number of non uniform blocks
if (message) then
+ non_uniform_blocks = 0
if ((mod(iec-isc+1,nx_block) .ne. 0) .or. (mod(jec-jsc+1,ny_block) .ne. 0)) then
- write( text,'(a,a,2i4,a,2i4,a)' ) trim(component),'define_blocks: domain (',&
- (iec-isc+1), (jec-jsc+1),') is not an even divisor with definition (',&
- nx_block, ny_block,') - blocks will not be uniform'
- call mpp_error (WARNING, trim(text))
+ non_uniform_blocks = 1
+ endif
+ call mpp_sum(non_uniform_blocks)
+ if (non_uniform_blocks > 0 ) then
+ call mpp_error(NOTE, string(non_uniform_blocks)//" out of "//string(mpp_npes())//" total domains "//&
+ "have non-uniform blocks for block size ("//string(nx_block)//","//string(ny_block)//")")
+ message = .false.
endif
- message = .false.
endif
!--- set up blocks
diff --git a/configure.ac b/configure.ac
index d5ab7d2f88..a398b7637c 100644
--- a/configure.ac
+++ b/configure.ac
@@ -533,6 +533,7 @@ AC_CONFIG_FILES([
test_fms/random_numbers/Makefile
test_fms/topography/Makefile
test_fms/column_diagnostics/Makefile
+ test_fms/block_control/Makefile
FMS.pc
])
diff --git a/test_fms/Makefile.am b/test_fms/Makefile.am
index 230ad1b164..409cde9765 100644
--- a/test_fms/Makefile.am
+++ b/test_fms/Makefile.am
@@ -27,7 +27,7 @@ ACLOCAL_AMFLAGS = -I m4
SUBDIRS = astronomy coupler diag_manager data_override exchange monin_obukhov drifters \
mosaic2 interpolator fms mpp mpp_io time_interp time_manager horiz_interp topography \
field_manager axis_utils affinity fms2_io parser string_utils sat_vapor_pres tracer_manager \
-random_numbers diag_integral column_diagnostics tridiagonal
+random_numbers diag_integral column_diagnostics tridiagonal block_control
# testing utility scripts to distribute
EXTRA_DIST = test-lib.sh.in intel_coverage.sh.in tap-driver.sh
diff --git a/test_fms/block_control/Makefile.am b/test_fms/block_control/Makefile.am
new file mode 100644
index 0000000000..4fc64f93b0
--- /dev/null
+++ b/test_fms/block_control/Makefile.am
@@ -0,0 +1,47 @@
+#***********************************************************************
+#* GNU Lesser General Public License
+#*
+#* This file is part of the GFDL Flexible Modeling System (FMS).
+#*
+#* FMS is free software: you can redistribute it and/or modify it under
+#* the terms of the GNU Lesser General Public License as published by
+#* the Free Software Foundation, either version 3 of the License, or (at
+#* your option) any later version.
+#*
+#* FMS is distributed in the hope that it will be useful, but WITHOUT
+#* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+#* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+#* for more details.
+#*
+#* You should have received a copy of the GNU Lesser General Public
+#* License along with FMS. If not, see .
+#***********************************************************************
+
+# This is an automake file for the test_fms/block_control directory of the
+# FMS package.
+
+# Find the fms and mpp mod files.
+AM_CPPFLAGS = -I$(top_srcdir)/include -I$(MODDIR)
+
+# Link to the FMS library.
+LDADD = $(top_builddir)/libFMS/libFMS.la
+
+# Build this test program.
+check_PROGRAMS = \
+ test_block_control
+
+# This is the source code for the test.
+test_block_control_SOURCES = test_block_control.F90
+
+# Run the test program.
+TESTS = test_block_control.sh
+
+# Copy over other needed files to the srcdir
+EXTRA_DIST = test_block_control.sh
+
+TEST_EXTENSIONS = .sh
+SH_LOG_DRIVER = env AM_TAP_AWK='$(AWK)' $(SHELL) \
+ $(abs_top_srcdir)/test_fms/tap-driver.sh
+
+# Clean up
+CLEANFILES = input.nml *.out* *.dpi *.spi *.dyn *.spl
diff --git a/test_fms/block_control/test_block_control.F90 b/test_fms/block_control/test_block_control.F90
new file mode 100644
index 0000000000..97ff4aa7f6
--- /dev/null
+++ b/test_fms/block_control/test_block_control.F90
@@ -0,0 +1,69 @@
+!***********************************************************************
+!* GNU Lesser General Public License
+!*
+!* This file is part of the GFDL Flexible Modeling System (FMS).
+!*
+!* FMS is free software: you can redistribute it and/or modify it under
+!* the terms of the GNU Lesser General Public License as published by
+!* the Free Software Foundation, either version 3 of the License, or (at
+!* your option) any later version.
+!*
+!* FMS is distributed in the hope that it will be useful, but WITHOUT
+!* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+!* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+!* for more details.
+!*
+!* You should have received a copy of the GNU Lesser General Public
+!* License along with FMS. If not, see .
+!***********************************************************************
+
+program test_block_control
+ use fms_mod, only: fms_init, fms_end
+ use mpp_domains_mod, only: domain2d, mpp_define_domains, mpp_get_compute_domain
+ use block_control_mod, only: block_control_type, define_blocks
+ use mpp_mod, only: mpp_pe, mpp_root_pe, mpp_error, FATAL
+ use fms_string_utils_mod, only: string
+
+ implicit none
+
+ integer, parameter :: nx=96 !< Size of the x grid
+ integer, parameter :: ny=96 !< Size of the y grid
+ type(domain2d) :: Domain !< 2D domain
+ integer :: layout(2) = (/2, 3/) !< Layout of the domain
+ type(block_control_type) :: my_block !< Block control type
+ integer :: isc, iec, jsc, jec !< Starting and ending index for the commute domain
+ integer :: expected_startingy !< Expected starting y index for the current block
+ integer :: expected_endingy !< Expected ending y index for the current block
+ integer :: ncy(3) !< Size of the y for each block
+ logical :: message !< Set to .True., to output the warning message
+ integer :: i !< For do loops
+
+ call fms_init()
+ message = .True. !< Needs to be .true. so that the error message can be printed
+ call mpp_define_domains( (/1,nx,1,ny/), layout, Domain)
+ call mpp_get_compute_domain(Domain, isc, iec, jsc, jec)
+ call define_blocks ('testing_model', my_block, isc, iec, jsc, jec, kpts=0, &
+ nx_block=1, ny_block=3, message=message)
+
+ !< Message will be set to .false. if the blocks are not uniform
+ if (message) &
+ call mpp_error(FATAL, "test_block_control::define_blocks did not output the warning message"//&
+ " about uneven blocks")
+
+ !Expected size of each block for every PE
+ ncy = (/11, 10, 11/)
+ expected_endingy = jsc-1
+ do i = 1, 3
+ ! Check the starting and ending "x" indices for each block
+ if (my_block%ibs(i) .ne. isc .or. my_block%ibe(i) .ne. iec) &
+ call mpp_error(FATAL, "The starting and ending 'x' index for the "//string(i)//" block is not expected value!")
+
+ ! Check the starting and ending "y" indices for each block
+ expected_startingy = expected_endingy + 1
+ expected_endingy = expected_startingy + ncy(i) - 1
+ if (my_block%jbs(i) .ne. expected_startingy .or. my_block%jbe(i) .ne. expected_endingy) &
+ call mpp_error(FATAL, "The starting and ending 'y' index for the "//string(i)//" block is not expected value!")
+ enddo
+
+ call fms_end()
+end program
diff --git a/test_fms/block_control/test_block_control.sh b/test_fms/block_control/test_block_control.sh
new file mode 100755
index 0000000000..a5e76f68c3
--- /dev/null
+++ b/test_fms/block_control/test_block_control.sh
@@ -0,0 +1,38 @@
+#!/bin/sh
+
+#***********************************************************************
+#* GNU Lesser General Public License
+#*
+#* This file is part of the GFDL Flexible Modeling System (FMS).
+#*
+#* FMS is free software: you can redistribute it and/or modify it under
+#* the terms of the GNU Lesser General Public License as published by
+#* the Free Software Foundation, either version 3 of the License, or (at
+#* your option) any later version.
+#*
+#* FMS is distributed in the hope that it will be useful, but WITHOUT
+#* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+#* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+#* for more details.
+#*
+#* You should have received a copy of the GNU Lesser General Public
+#* License along with FMS. If not, see .
+#***********************************************************************
+
+# This is part of the GFDL FMS package. This is a shell script to
+# execute tests in the test_fms/block_control directory.
+
+# Set common test settings.
+. ../test-lib.sh
+
+# Prepare the directory to run the tests.
+cat < input.nml
+EOF
+
+# Run the test.
+
+test_expect_success "Test block_control" '
+ mpirun -n 6 ./test_block_control
+'
+
+test_done
diff --git a/test_fms/diag_manager/test_reduction_methods.F90 b/test_fms/diag_manager/test_reduction_methods.F90
index 0b09fc69ca..7a0bb8efc6 100644
--- a/test_fms/diag_manager/test_reduction_methods.F90
+++ b/test_fms/diag_manager/test_reduction_methods.F90
@@ -135,6 +135,7 @@ program test_reduction_methods
ddata = allocate_buffer(isd, ied, jsd, jed, nz, nw)
call init_buffer(ddata, isc, iec, jsc, jec, 2) !< The halos never get set
case (test_openmp)
+ message = .true.
if (mpp_pe() .eq. mpp_root_pe()) print *, "Testing the send_data calls with openmp blocks"
call define_blocks ('testing_model', my_block, isc, iec, jsc, jec, kpts=0, &
nx_block=1, ny_block=4, message=message)