Skip to content

Commit

Permalink
TST: add test for GeoQuadMesh.set_array without wrap
Browse files Browse the repository at this point in the history
  • Loading branch information
rcomer committed Jul 13, 2023
1 parent d8cebc3 commit afbb531
Showing 1 changed file with 31 additions and 0 deletions.
31 changes: 31 additions & 0 deletions lib/cartopy/tests/mpl/test_mpl_integration.py
Original file line number Diff line number Diff line change
Expand Up @@ -506,6 +506,37 @@ def test_pcolormesh_set_array_with_mask(mesh_data_kind):
return fig


def test_pcolormesh_set_array_nowrap():
# Roundtrip check that set_array works with the correct shaped arrays
nx, ny = 36, 18
xbnds = np.linspace(-60, 60, nx, endpoint=True)
ybnds = np.linspace(-80, 80, ny, endpoint=True)
xbnds, ybnds = np.meshgrid(xbnds, ybnds)

rng = np.random.default_rng()
print(f"{xbnds.shape=}, {ybnds.shape=}")
data = rng.random((17, 35))

ax = plt.figure().add_subplot(projection=ccrs.PlateCarree())
mesh = ax.pcolormesh(xbnds, ybnds, data)
assert not hasattr(mesh, '_wrapped_collection_fix')

expected = data
if MPL_VERSION.release[:2] < (3, 8):
expected = expected.ravel()
np.testing.assert_array_equal(mesh.get_array(), expected)

# For backwards compatibility, check we can set a flattened array
data = rng.random(35 * 17)
mesh.set_array(data)
np.testing.assert_array_equal(mesh.get_array(), data.reshape(17, 35))

# Check that we can set a 2D array even if previous was flat
data = rng.random((17, 35))
mesh.set_array(data)
np.testing.assert_array_equal(mesh.get_array(), data)


@pytest.mark.natural_earth
@pytest.mark.mpl_image_compare(filename='pcolormesh_global_wrap3.png',
tolerance=1.42)
Expand Down

0 comments on commit afbb531

Please sign in to comment.