Build:
- 0
2025-03-27 11:06.33: New job: docker build { "compose-or-build": true, "commit": "f5290c443abb1c6126d5edd7426f25c3a7a7d8af", "dockerfile": { "file": "Dockerfile" }, "docker_context": null, "squash": false, "build_args": [], "path": null } 2025-03-27 11:06.33: Checking out commit f5290c44. To reproduce: git clone --recursive "https://github.com/quantifyearth/yirgacheffe.git" -b "main" && cd "yirgacheffe" && git reset --hard f5290c44 2025-03-27 11:06.33: Exec: "cp" "-a" "--" "/var/lib/ocurrent/var/git/yirgacheffe.git-1b1f760b12502161d1ac4703144473aebfb7743225131709358f4b6e819ae9da/.git" "/tmp/git-checkout24874325" 2025-03-27 11:06.33: Exec: "git" "-C" "/tmp/git-checkout24874325" "submodule" "deinit" "--force" "--all" 2025-03-27 11:06.33: Exec: "git" "-C" "/tmp/git-checkout24874325" "reset" "--hard" "-q" "f5290c443abb1c6126d5edd7426f25c3a7a7d8af" 2025-03-27 11:06.33: Exec: "git" "-C" "/tmp/git-checkout24874325" "submodule" "update" "--recursive" "--init" "--no-fetch" 2025-03-27 11:06.33: Exec: "docker" "build" "--pull" "-f" "/tmp/git-checkout24874325/Dockerfile" "--iidfile" "/tmp/git-checkout24874325/docker-iid" "--" "/tmp/git-checkout24874325" DEPRECATED: The legacy builder is deprecated and will be removed in a future release. Install the buildx component to build images with BuildKit: https://docs.docker.com/go/buildx/ Sending build context to Docker daemon 1.239MB Step 1/10 : from ghcr.io/osgeo/gdal:ubuntu-small-3.9.2 ubuntu-small-3.9.2: Pulling from osgeo/gdal Digest: sha256:6af57cbe64534fd8c3803ac4158e9bf812dfb1968cf13e8922b80f665d76d063 Status: Image is up to date for ghcr.io/osgeo/gdal:ubuntu-small-3.9.2 ---> 782f90affb9c Step 2/10 : RUN apt-get update -qqy && apt-get install -qy git python3-pip && rm -rf /var/lib/apt/lists/* && rm -rf /var/cache/apt/* ---> Using cache ---> 5f6bceffed75 Step 3/10 : COPY ./ /root/ ---> dd7640999b72 Step 4/10 : WORKDIR /root/ ---> Running in be1b9ea3c17c ---> Removed intermediate container be1b9ea3c17c ---> 147388b4ca53 Step 5/10 : RUN pip config set global.break-system-packages true ---> Running in 921d1a91d4c0 Writing to /root/.config/pip/pip.conf ---> Removed intermediate container 921d1a91d4c0 ---> 5e4815403f47 Step 6/10 : RUN pip install "numpy<2" gdal[numpy] scikit-image ---> Running in f95a664d3ec2 Requirement already satisfied: numpy<2 in /usr/lib/python3/dist-packages (1.26.4) Collecting scikit-image Downloading scikit_image-0.25.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (14 kB) Requirement already satisfied: gdal[numpy] in /usr/lib/python3/dist-packages (3.9.2) Collecting scipy>=1.11.4 (from scikit-image) Downloading scipy-1.15.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (61 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 62.0/62.0 kB 3.1 MB/s eta 0:00:00 Collecting networkx>=3.0 (from scikit-image) Downloading networkx-3.4.2-py3-none-any.whl.metadata (6.3 kB) Requirement already satisfied: pillow>=10.1 in /usr/lib/python3/dist-packages (from scikit-image) (10.2.0) Collecting imageio!=2.35.0,>=2.33 (from scikit-image) Downloading imageio-2.37.0-py3-none-any.whl.metadata (5.2 kB) Collecting tifffile>=2022.8.12 (from scikit-image) Downloading tifffile-2025.3.13-py3-none-any.whl.metadata (32 kB) Collecting packaging>=21 (from scikit-image) Downloading packaging-24.2-py3-none-any.whl.metadata (3.2 kB) Collecting lazy-loader>=0.4 (from scikit-image) Downloading lazy_loader-0.4-py3-none-any.whl.metadata (7.6 kB) Downloading scikit_image-0.25.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (15.0 MB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 15.0/15.0 MB 40.0 MB/s eta 0:00:00 Downloading imageio-2.37.0-py3-none-any.whl (315 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 315.8/315.8 kB 26.9 MB/s eta 0:00:00 Downloading lazy_loader-0.4-py3-none-any.whl (12 kB) Downloading networkx-3.4.2-py3-none-any.whl (1.7 MB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 1.7/1.7 MB 46.1 MB/s eta 0:00:00 Downloading packaging-24.2-py3-none-any.whl (65 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 65.5/65.5 kB 8.6 MB/s eta 0:00:00 Downloading scipy-1.15.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (37.3 MB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 37.3/37.3 MB 23.9 MB/s eta 0:00:00 Downloading tifffile-2025.3.13-py3-none-any.whl (226 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 226.8/226.8 kB 14.5 MB/s eta 0:00:00 Installing collected packages: tifffile, scipy, packaging, networkx, imageio, lazy-loader, scikit-image Successfully installed imageio-2.37.0 lazy-loader-0.4 networkx-3.4.2 packaging-24.2 scikit-image-0.25.2 scipy-1.15.2 tifffile-2025.3.13 WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv ---> Removed intermediate container f95a664d3ec2 ---> 7be85c90e72c Step 7/10 : RUN pip install pylint mypy pytest types-setuptools ---> Running in f24ef7152b88 Collecting pylint Downloading pylint-3.3.6-py3-none-any.whl.metadata (12 kB) Collecting mypy Downloading mypy-1.15.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl.metadata (2.1 kB) Collecting pytest Downloading pytest-8.3.5-py3-none-any.whl.metadata (7.6 kB) Collecting types-setuptools Downloading types_setuptools-76.0.0.20250313-py3-none-any.whl.metadata (2.2 kB) Collecting astroid<=3.4.0.dev0,>=3.3.8 (from pylint) Downloading astroid-3.3.9-py3-none-any.whl.metadata (4.5 kB) Collecting dill>=0.3.6 (from pylint) Downloading dill-0.3.9-py3-none-any.whl.metadata (10 kB) Collecting isort!=5.13,<7,>=4.2.5 (from pylint) Downloading isort-6.0.1-py3-none-any.whl.metadata (11 kB) Collecting mccabe<0.8,>=0.6 (from pylint) Downloading mccabe-0.7.0-py2.py3-none-any.whl.metadata (5.0 kB) Collecting platformdirs>=2.2 (from pylint) Downloading platformdirs-4.3.7-py3-none-any.whl.metadata (11 kB) Collecting tomlkit>=0.10.1 (from pylint) Downloading tomlkit-0.13.2-py3-none-any.whl.metadata (2.7 kB) Collecting typing_extensions>=4.6.0 (from mypy) Downloading typing_extensions-4.13.0-py3-none-any.whl.metadata (3.0 kB) Collecting mypy_extensions>=1.0.0 (from mypy) Downloading mypy_extensions-1.0.0-py3-none-any.whl.metadata (1.1 kB) Collecting iniconfig (from pytest) Downloading iniconfig-2.1.0-py3-none-any.whl.metadata (2.7 kB) Requirement already satisfied: packaging in /usr/local/lib/python3.12/dist-packages (from pytest) (24.2) Collecting pluggy<2,>=1.5 (from pytest) Downloading pluggy-1.5.0-py3-none-any.whl.metadata (4.8 kB) Requirement already satisfied: setuptools in /usr/lib/python3/dist-packages (from types-setuptools) (68.1.2) Downloading pylint-3.3.6-py3-none-any.whl (522 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 522.5/522.5 kB 16.5 MB/s eta 0:00:00 Downloading mypy-1.15.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl (12.4 MB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 12.4/12.4 MB 49.1 MB/s eta 0:00:00 Downloading pytest-8.3.5-py3-none-any.whl (343 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 343.6/343.6 kB 23.0 MB/s eta 0:00:00 Downloading types_setuptools-76.0.0.20250313-py3-none-any.whl (65 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 65.8/65.8 kB 6.4 MB/s eta 0:00:00 Downloading astroid-3.3.9-py3-none-any.whl (275 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 275.3/275.3 kB 24.7 MB/s eta 0:00:00 Downloading dill-0.3.9-py3-none-any.whl (119 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 119.4/119.4 kB 11.5 MB/s eta 0:00:00 Downloading isort-6.0.1-py3-none-any.whl (94 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 94.2/94.2 kB 10.8 MB/s eta 0:00:00 Downloading mccabe-0.7.0-py2.py3-none-any.whl (7.3 kB) Downloading mypy_extensions-1.0.0-py3-none-any.whl (4.7 kB) Downloading platformdirs-4.3.7-py3-none-any.whl (18 kB) Downloading pluggy-1.5.0-py3-none-any.whl (20 kB) Downloading tomlkit-0.13.2-py3-none-any.whl (37 kB) Downloading typing_extensions-4.13.0-py3-none-any.whl (45 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 45.7/45.7 kB 4.6 MB/s eta 0:00:00 Downloading iniconfig-2.1.0-py3-none-any.whl (6.0 kB) Installing collected packages: typing_extensions, types-setuptools, tomlkit, pluggy, platformdirs, mypy_extensions, mccabe, isort, iniconfig, dill, astroid, pytest, pylint, mypy Successfully installed astroid-3.3.9 dill-0.3.9 iniconfig-2.1.0 isort-6.0.1 mccabe-0.7.0 mypy-1.15.0 mypy_extensions-1.0.0 platformdirs-4.3.7 pluggy-1.5.0 pylint-3.3.6 pytest-8.3.5 tomlkit-0.13.2 types-setuptools-76.0.0.20250313 typing_extensions-4.13.0 WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv ---> Removed intermediate container f24ef7152b88 ---> 1252ee7702a8 Step 8/10 : RUN pip install h3==4.0.0b5 ---> Running in a0f427cade69 Collecting h3==4.0.0b5 Downloading h3-4.0.0b5-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (5.1 kB) Downloading h3-4.0.0b5-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.0 MB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 1.0/1.0 MB 9.3 MB/s eta 0:00:00 Installing collected packages: h3 Successfully installed h3-4.0.0b5 WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv ---> Removed intermediate container a0f427cade69 ---> 34a813a2fc31 Step 9/10 : RUN python3 -m pytest -vv ---> Running in ca75222edfd0 ============================= test session starts ============================== platform linux -- Python 3.12.3, pytest-8.3.5, pluggy-1.5.0 -- /usr/bin/python3 cachedir: .pytest_cache rootdir: /root configfile: pyproject.toml collecting ... collected 580 items tests/test_area.py::test_area_operators[lhs0-rhs0-True-True] PASSED [ 0%] tests/test_area.py::test_area_operators[lhs1-rhs1-False-True] PASSED [ 0%] tests/test_area.py::test_area_operators[lhs2-rhs2-False-False] PASSED [ 0%] tests/test_area.py::test_area_operators[lhs3-rhs3-False-True] PASSED [ 0%] tests/test_auto_windowing.py::test_add_windows PASSED [ 0%] tests/test_auto_windowing.py::test_multiply_windows PASSED [ 1%] tests/test_auto_windowing.py::test_add_windows_offset PASSED [ 1%] tests/test_auto_windowing.py::test_multiply_windows_offset PASSED [ 1%] tests/test_auto_windowing.py::test_add_windows_sum PASSED [ 1%] tests/test_auto_windowing.py::test_multiply_windows_sum PASSED [ 1%] tests/test_auto_windowing.py::test_constant_layer_result_rhs_add PASSED [ 1%] tests/test_auto_windowing.py::test_constant_layer_result_lhs_add PASSED [ 2%] tests/test_auto_windowing.py::test_constant_layer_result_rhs_multiply PASSED [ 2%] tests/test_auto_windowing.py::test_constant_layer_result_lhs_multiply PASSED [ 2%] tests/test_auto_windowing.py::test_vector_layers_add PASSED [ 2%] tests/test_auto_windowing.py::test_vector_layers_multiply PASSED [ 2%] tests/test_base.py::test_pixel_to_latlng_unsupported_projection PASSED [ 2%] tests/test_base.py::test_pixel_from_latlng_unsupported_projection PASSED [ 3%] tests/test_base.py::test_latlng_for_pixel[area0-pixel0-expected0] PASSED [ 3%] tests/test_base.py::test_latlng_for_pixel[area1-pixel1-expected1] PASSED [ 3%] tests/test_base.py::test_latlng_for_pixel[area2-pixel2-expected2] PASSED [ 3%] tests/test_base.py::test_latlng_for_pixel[area3-pixel3-expected3] PASSED [ 3%] tests/test_base.py::test_latlng_for_pixel[area4-pixel4-expected4] PASSED [ 3%] tests/test_base.py::test_latlng_for_pixel[area5-pixel5-expected5] PASSED [ 4%] tests/test_base.py::test_pixel_for_latlng[area0-coord0-expected0] PASSED [ 4%] tests/test_base.py::test_pixel_for_latlng[area1-coord1-expected1] PASSED [ 4%] tests/test_base.py::test_pixel_for_latlng[area2-coord2-expected2] PASSED [ 4%] tests/test_base.py::test_latlng_for_pixel_with_intersection[area0-window0-pixel0-expected0] PASSED [ 4%] tests/test_base.py::test_latlng_for_pixel_with_intersection[area1-window1-pixel1-expected1] PASSED [ 5%] tests/test_base.py::test_latlng_for_pixel_with_intersection[area2-window2-pixel2-expected2] PASSED [ 5%] tests/test_base.py::test_latlng_for_pixel_with_intersection[area3-window3-pixel3-expected3] PASSED [ 5%] tests/test_base.py::test_latlng_for_pixel_with_intersection[area4-window4-pixel4-expected4] PASSED [ 5%] tests/test_base.py::test_latlng_for_pixel_with_intersection[area5-window5-pixel5-expected5] PASSED [ 5%] tests/test_base.py::test_pixel_for_latlng_with_intersection[area0-window0-coord0-expected0] PASSED [ 5%] tests/test_base.py::test_pixel_for_latlng_with_intersection[area1-window1-coord1-expected1] PASSED [ 6%] tests/test_base.py::test_pixel_for_latlng_with_intersection[area2-window2-coord2-expected2] PASSED [ 6%] tests/test_group.py::test_empty_group PASSED [ 6%] tests/test_group.py::test_invalid_file_list PASSED [ 6%] tests/test_group.py::test_empty_file_list PASSED [ 6%] tests/test_group.py::test_valid_file_list PASSED [ 6%] tests/test_group.py::test_single_raster_layer_in_group PASSED [ 7%] tests/test_group.py::test_mismatched_layers PASSED [ 7%] tests/test_group.py::test_two_raster_areas_side_by_side[GroupLayer] PASSED [ 7%] tests/test_group.py::test_two_raster_areas_side_by_side[TiledGroupLayer] PASSED [ 7%] tests/test_group.py::test_two_raster_areas_top_to_bottom[GroupLayer] PASSED [ 7%] tests/test_group.py::test_two_raster_areas_top_to_bottom[TiledGroupLayer] PASSED [ 7%] tests/test_group.py::test_grid_tiles[GroupLayer-2] PASSED [ 8%] tests/test_group.py::test_grid_tiles[TiledGroupLayer-2] PASSED [ 8%] tests/test_group.py::test_grid_tiles[GroupLayer-3] PASSED [ 8%] tests/test_group.py::test_grid_tiles[TiledGroupLayer-3] PASSED [ 8%] tests/test_group.py::test_overlapping_tiles[GroupLayer-2] PASSED [ 8%] tests/test_group.py::test_overlapping_tiles[TiledGroupLayer-2] PASSED [ 8%] tests/test_group.py::test_overlapping_tiles[GroupLayer-3] PASSED [ 9%] tests/test_group.py::test_overlapping_tiles[TiledGroupLayer-3] PASSED [ 9%] tests/test_group.py::test_two_raster_read_only_from_one PASSED [ 9%] tests/test_group.py::test_two_raster_read_only_from_other PASSED [ 9%] tests/test_group.py::test_single_vector_layer_in_group PASSED [ 9%] tests/test_group.py::test_overlapping_vector_layers PASSED [ 10%] tests/test_group.py::test_with_window_adjust[GroupLayer] PASSED [ 10%] tests/test_group.py::test_with_window_adjust[TiledGroupLayer] PASSED [ 10%] tests/test_group.py::test_multipe_tiles_with_window[GroupLayer-2] PASSED [ 10%] tests/test_group.py::test_multipe_tiles_with_window[TiledGroupLayer-2] PASSED [ 10%] tests/test_group.py::test_multipe_tiles_with_window[GroupLayer-3] PASSED [ 10%] tests/test_group.py::test_multipe_tiles_with_window[TiledGroupLayer-3] PASSED [ 11%] tests/test_group.py::test_overlapping_tiles_with_window[GroupLayer-2] PASSED [ 11%] tests/test_group.py::test_overlapping_tiles_with_window[TiledGroupLayer-2] PASSED [ 11%] tests/test_group.py::test_overlapping_tiles_with_window[GroupLayer-3] PASSED [ 11%] tests/test_group.py::test_overlapping_tiles_with_window[TiledGroupLayer-3] PASSED [ 11%] tests/test_group.py::test_overlapping_tiles_with_read_aligned_to_tiles[GroupLayer] PASSED [ 11%] tests/test_group.py::test_overlapping_tiles_with_read_aligned_to_tiles[TiledGroupLayer] PASSED [ 12%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-3-0] PASSED [ 12%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-0] PASSED [ 12%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-3-1] PASSED [ 12%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-1] PASSED [ 12%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-3-2] PASSED [ 12%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-2_0] PASSED [ 13%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-3-3] PASSED [ 13%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-3] PASSED [ 13%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-3-4] PASSED [ 13%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-4] PASSED [ 13%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-3-5] PASSED [ 13%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-5] PASSED [ 14%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-3-6] PASSED [ 14%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-6] PASSED [ 14%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-3-7] PASSED [ 14%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-7] PASSED [ 14%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-3-8] PASSED [ 15%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-8] PASSED [ 15%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-0] PASSED [ 15%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-0] PASSED [ 15%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-1] PASSED [ 15%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-1] PASSED [ 15%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-2] PASSED [ 16%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-3-2_1] PASSED [ 16%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-3] PASSED [ 16%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-3] PASSED [ 16%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-4] PASSED [ 16%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-4] PASSED [ 16%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-5] PASSED [ 17%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-5] PASSED [ 17%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-6] PASSED [ 17%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-6] PASSED [ 17%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-7] PASSED [ 17%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-7] PASSED [ 17%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-12] PASSED [ 18%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-12] PASSED [ 18%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-13] PASSED [ 18%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-13] PASSED [ 18%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-14] PASSED [ 18%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-14] PASSED [ 18%] tests/test_group.py::test_multipe_tiles_with_missing_tile[GroupLayer-4-15] PASSED [ 19%] tests/test_group.py::test_multipe_tiles_with_missing_tile[TiledGroupLayer-4-15] PASSED [ 19%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-3-0] PASSED [ 19%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-0] PASSED [ 19%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-3-1] PASSED [ 19%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-1] PASSED [ 20%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-3-2] PASSED [ 20%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-2_0] PASSED [ 20%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-3-3] PASSED [ 20%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-3] PASSED [ 20%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-3-4] PASSED [ 20%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-4] PASSED [ 21%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-3-5] PASSED [ 21%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-5] PASSED [ 21%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-3-6] PASSED [ 21%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-6] PASSED [ 21%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-3-7] PASSED [ 21%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-7] PASSED [ 22%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-3-8] PASSED [ 22%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-8] PASSED [ 22%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-0] PASSED [ 22%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-0] PASSED [ 22%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-1] PASSED [ 22%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-1] PASSED [ 23%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-2] PASSED [ 23%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-3-2_1] PASSED [ 23%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-3] PASSED [ 23%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-3] PASSED [ 23%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-4] PASSED [ 23%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-4] PASSED [ 24%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-5] PASSED [ 24%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-5] PASSED [ 24%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-6] PASSED [ 24%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-6] PASSED [ 24%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-7] PASSED [ 25%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-7] PASSED [ 25%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-12] PASSED [ 25%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-12] PASSED [ 25%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-13] PASSED [ 25%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-13] PASSED [ 25%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-14] PASSED [ 26%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-14] PASSED [ 26%] tests/test_group.py::test_oversized_tiles_with_missing_tile[GroupLayer-4-15] PASSED [ 26%] tests/test_group.py::test_oversized_tiles_with_missing_tile[TiledGroupLayer-4-15] PASSED [ 26%] tests/test_group.py::test_read_zero_pixels[GroupLayer-size0] PASSED [ 26%] tests/test_group.py::test_read_zero_pixels[GroupLayer-size1] PASSED [ 26%] tests/test_group.py::test_read_zero_pixels[TiledGroupLayer-size2] PASSED [ 27%] tests/test_group.py::test_read_zero_pixels[TiledGroupLayer-size3] PASSED [ 27%] tests/test_group.py::test_read_tiles_superset[read_area0] PASSED [ 27%] tests/test_group.py::test_read_tiles_superset[read_area1] PASSED [ 27%] tests/test_group.py::test_read_tiles_superset[read_area2] PASSED [ 27%] tests/test_group.py::test_read_tiles_superset[read_area3] PASSED [ 27%] tests/test_group.py::test_read_tiles_superset[read_area4] PASSED [ 28%] tests/test_group.py::test_read_tiles_superset[read_area5] PASSED [ 28%] tests/test_group.py::test_read_tiles_superset[read_area6] PASSED [ 28%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[GroupLayer-3-0] PASSED [ 28%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-0] PASSED [ 28%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[GroupLayer-3-1] PASSED [ 28%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-1] PASSED [ 29%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[GroupLayer-3-2] PASSED [ 29%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-2] PASSED [ 29%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[GroupLayer-3-3] PASSED [ 29%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-3] PASSED [ 29%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[GroupLayer-3-4] PASSED [ 30%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-4] PASSED [ 30%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[GroupLayer-3-5] PASSED [ 30%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-5] PASSED [ 30%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[GroupLayer-3-6] PASSED [ 30%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-6] PASSED [ 30%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[GroupLayer-3-7] PASSED [ 31%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-7] PASSED [ 31%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[GroupLayer-3-8] PASSED [ 31%] tests/test_group.py::test_oversized_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-8] PASSED [ 31%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[GroupLayer-3-0] PASSED [ 31%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-0] PASSED [ 31%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[GroupLayer-3-1] PASSED [ 32%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-1] PASSED [ 32%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[GroupLayer-3-2] PASSED [ 32%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-2] PASSED [ 32%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[GroupLayer-3-3] PASSED [ 32%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-3] PASSED [ 32%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[GroupLayer-3-4] PASSED [ 33%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-4] PASSED [ 33%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[GroupLayer-3-5] PASSED [ 33%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-5] PASSED [ 33%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[GroupLayer-3-6] PASSED [ 33%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-6] PASSED [ 33%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[GroupLayer-3-7] PASSED [ 34%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-7] PASSED [ 34%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[GroupLayer-3-8] PASSED [ 34%] tests/test_group.py::test_multipe_tiles_with_missing_tile_row_slices[TiledGroupLayer-3-8] PASSED [ 34%] tests/test_h3layer.py::test_h3_layer[hello-False-0] PASSED [ 34%] tests/test_h3layer.py::test_h3_layer[88972eac11fffff-True-8] PASSED [ 35%] tests/test_h3layer.py::test_h3_layer_magnifications[0.0-0.0] PASSED [ 35%] tests/test_h3layer.py::test_h3_layer_magnifications[0.0-45.0] PASSED [ 35%] tests/test_h3layer.py::test_h3_layer_magnifications[45.0-0.0] PASSED [ 35%] tests/test_h3layer.py::test_h3_layer_magnifications[45.0-45.0] PASSED [ 35%] tests/test_h3layer.py::test_h3_layer_magnifications[85.0-0.0] PASSED [ 35%] tests/test_h3layer.py::test_h3_layer_magnifications[85.0-45.0] PASSED [ 36%] tests/test_h3layer.py::test_h3_layer_magnifications[1.0-95.0] PASSED [ 36%] tests/test_h3layer.py::test_h3_layer_not_clipped[0.0-0.0] PASSED [ 36%] tests/test_h3layer.py::test_h3_layer_not_clipped[0.0-45.0] PASSED [ 36%] tests/test_h3layer.py::test_h3_layer_not_clipped[45.0-0.0] PASSED [ 36%] tests/test_h3layer.py::test_h3_layer_not_clipped[45.0-45.0] PASSED [ 36%] tests/test_h3layer.py::test_h3_layer_not_clipped[85.0-0.0] PASSED [ 37%] tests/test_h3layer.py::test_h3_layer_not_clipped[85.0-45.0] PASSED [ 37%] tests/test_h3layer.py::test_h3_layer_not_clipped[1.0-95.0] PASSED [ 37%] tests/test_h3layer.py::test_h3_layer_clipped[0.0-0.0] PASSED [ 37%] tests/test_h3layer.py::test_h3_layer_clipped[0.0-45.0] PASSED [ 37%] tests/test_h3layer.py::test_h3_layer_clipped[45.0-0.0] PASSED [ 37%] tests/test_h3layer.py::test_h3_layer_clipped[45.0-45.0] PASSED [ 38%] tests/test_h3layer.py::test_h3_layer_clipped[85.0-0.0] PASSED [ 38%] tests/test_h3layer.py::test_h3_layer_clipped[85.0-45.0] PASSED [ 38%] tests/test_h3layer.py::test_h3_layer_clipped[1.0-95.0] PASSED [ 38%] tests/test_h3layer.py::test_h3_layer_wrapped_on_projection[50.0-179.9] PASSED [ 38%] tests/test_h3layer.py::test_h3_layer_wrapped_on_projection[50.0--179.9] PASSED [ 38%] tests/test_h3layer.py::test_h3_layer_overlapped PASSED [ 39%] tests/test_intersection.py::test_find_intersection_empty_list PASSED [ 39%] tests/test_intersection.py::test_find_intersection_single_item PASSED [ 39%] tests/test_intersection.py::test_find_intersection_same PASSED [ 39%] tests/test_intersection.py::test_find_intersection_subset PASSED [ 39%] tests/test_intersection.py::test_find_intersection_overlap PASSED [ 40%] tests/test_intersection.py::test_find_intersection_distinct PASSED [ 40%] tests/test_intersection.py::test_find_intersection_with_constant PASSED [ 40%] tests/test_intersection.py::test_find_intersection_different_pixel_pitch PASSED [ 40%] tests/test_intersection.py::test_set_intersection_self[0.01] PASSED [ 40%] tests/test_intersection.py::test_set_intersection_self[0.02] PASSED [ 40%] tests/test_intersection.py::test_set_intersection_self[0.03] PASSED [ 41%] tests/test_intersection.py::test_set_intersection_self[0.04] PASSED [ 41%] tests/test_intersection.py::test_set_intersection_self[0.05] PASSED [ 41%] tests/test_intersection.py::test_set_intersection_self[0.06] PASSED [ 41%] tests/test_intersection.py::test_set_intersection_self[0.07] PASSED [ 41%] tests/test_intersection.py::test_set_intersection_self[0.08] PASSED [ 41%] tests/test_intersection.py::test_set_intersection_self[0.09] PASSED [ 42%] tests/test_intersection.py::test_set_intersection_subset PASSED [ 42%] tests/test_intersection.py::test_set_intersection_distinct PASSED [ 42%] tests/test_intersection.py::test_find_intersection_nearly_same PASSED [ 42%] tests/test_intersection.py::test_intersection_stability PASSED [ 42%] tests/test_multiband.py::test_simple_two_band_image PASSED [ 42%] tests/test_multiband.py::test_stack_tifs_with_area_match PASSED [ 43%] tests/test_operators.py::test_add_byte_layers PASSED [ 43%] tests/test_operators.py::test_error_of_pixel_scale_wrong PASSED [ 43%] tests/test_operators.py::test_error_of_pixel_scale_wrong_three_param PASSED [ 43%] tests/test_operators.py::test_add_byte_layers_with_callback[1-expected_steps0] PASSED [ 43%] tests/test_operators.py::test_add_byte_layers_with_callback[2-expected_steps1] PASSED [ 43%] tests/test_operators.py::test_sub_byte_layers PASSED [ 44%] tests/test_operators.py::test_add_float_layers PASSED [ 44%] tests/test_operators.py::test_sub_float_layers PASSED [ 44%] tests/test_operators.py::test_mult_float_layers PASSED [ 44%] tests/test_operators.py::test_add_to_float_layer_by_const[2.5] PASSED [ 44%] tests/test_operators.py::test_add_to_float_layer_by_const[2] PASSED [ 45%] tests/test_operators.py::test_add_to_float_layer_by_const[c2] PASSED [ 45%] tests/test_operators.py::test_add_to_float_layer_by_const[c3] PASSED [ 45%] tests/test_operators.py::test_sub_from_float_layer_by_const PASSED [ 45%] tests/test_operators.py::test_mult_float_layer_by_const PASSED [ 45%] tests/test_operators.py::test_div_float_layer_by_const PASSED [ 45%] tests/test_operators.py::test_power_float_layer_by_const PASSED [ 46%] tests/test_operators.py::test_simple_unary_numpy_apply PASSED [ 46%] tests/test_operators.py::test_isin_unary_numpy_apply PASSED [ 46%] tests/test_operators.py::test_simple_binary_numpy_apply PASSED [ 46%] tests/test_operators.py::test_simple_unary_shader_apply PASSED [ 46%] tests/test_operators.py::test_simple_binary_shader_apply PASSED [ 46%] tests/test_operators.py::test_comparison_float_layer_by_const[<lambda>0] PASSED [ 47%] tests/test_operators.py::test_comparison_float_layer_by_const[<lambda>1] PASSED [ 47%] tests/test_operators.py::test_comparison_float_layer_by_const[<lambda>2] PASSED [ 47%] tests/test_operators.py::test_comparison_float_layer_by_const[<lambda>3] PASSED [ 47%] tests/test_operators.py::test_comparison_float_layer_by_const[<lambda>4] PASSED [ 47%] tests/test_operators.py::test_comparison_float_layer_by_const[<lambda>5] PASSED [ 47%] tests/test_operators.py::test_sum_layer PASSED [ 48%] tests/test_operators.py::test_constant_layer_result_rhs PASSED [ 48%] tests/test_operators.py::test_constant_layer_result_lhs PASSED [ 48%] tests/test_operators.py::test_shader_apply_constant_lhs PASSED [ 48%] tests/test_operators.py::test_shader_apply_constant_rhs PASSED [ 48%] tests/test_operators.py::test_direct_layer_save PASSED [ 48%] tests/test_operators.py::test_direct_layer_sum PASSED [ 49%] tests/test_operators.py::test_direct_layer_sum_chunked PASSED [ 49%] tests/test_operators.py::test_direct_layer_min PASSED [ 49%] tests/test_operators.py::test_direct_layer_min_chunked PASSED [ 49%] tests/test_operators.py::test_direct_layer_max PASSED [ 49%] tests/test_operators.py::test_direct_layer_max_chunked PASSED [ 50%] tests/test_operators.py::test_direct_layer_save_and_sum PASSED [ 50%] tests/test_operators.py::test_add_to_float_layer_by_np_array PASSED [ 50%] tests/test_operators.py::test_write_mulitband_raster PASSED [ 50%] tests/test_operators.py::test_save_and_sum_float32 PASSED [ 50%] tests/test_operators.py::test_parallel_save_and_sum_float32 PASSED [ 50%] tests/test_operators.py::test_sum_float32 PASSED [ 51%] tests/test_operators.py::test_and_byte_layers PASSED [ 51%] tests/test_operators.py::test_or_byte_layers PASSED [ 51%] tests/test_operators.py::test_and_int_layers PASSED [ 51%] tests/test_operators.py::test_or_int_layers PASSED [ 51%] tests/test_operators.py::test_nan_to_num PASSED [ 51%] tests/test_operators.py::test_nan_to_num_default PASSED [ 52%] tests/test_operators.py::test_where_simple[float] PASSED [ 52%] tests/test_operators.py::test_where_simple[int] PASSED [ 52%] tests/test_operators.py::test_where_simple[uint16] PASSED [ 52%] tests/test_operators.py::test_where_simple[float32] PASSED [ 52%] tests/test_operators.py::test_where_layers PASSED [ 52%] tests/test_operators.py::test_isin_simple_method PASSED [ 53%] tests/test_operators.py::test_isin_simple_module PASSED [ 53%] tests/test_operators.py::test_layer_comparison_to_value[2.0] PASSED [ 53%] tests/test_operators.py::test_layer_comparison_to_value[2] PASSED [ 53%] tests/test_operators.py::test_layer_comparison_to_value[val2] PASSED [ 53%] tests/test_operators.py::test_layer_comparison_to_value[val3] PASSED [ 53%] tests/test_operators.py::test_layer_less_than_value PASSED [ 54%] tests/test_operators.py::test_layer_less_than_or_equal_to_value PASSED [ 54%] tests/test_operators.py::test_layer_greater_than_value PASSED [ 54%] tests/test_operators.py::test_layer_greater_than_or_equal_to_value PASSED [ 54%] tests/test_operators.py::test_layer_comparison_to_layer PASSED [ 54%] tests/test_operators.py::test_layer_less_than_layer PASSED [ 55%] tests/test_operators.py::test_layer_less_than_or_equal_to_layer PASSED [ 55%] tests/test_operators.py::test_layer_greater_than_layer PASSED [ 55%] tests/test_operators.py::test_layer_greater_than_or_equal_to_layer PASSED [ 55%] tests/test_operators.py::test_log_method PASSED [ 55%] tests/test_operators.py::test_log_module PASSED [ 55%] tests/test_operators.py::test_log2 PASSED [ 56%] tests/test_operators.py::test_log10 PASSED [ 56%] tests/test_operators.py::test_exp_method PASSED [ 56%] tests/test_operators.py::test_exp_module PASSED [ 56%] tests/test_operators.py::test_exp2 PASSED [ 56%] tests/test_operators.py::test_minimum_layers PASSED [ 56%] tests/test_operators.py::test_maximum_layers PASSED [ 57%] tests/test_operators.py::test_clip_both_method PASSED [ 57%] tests/test_operators.py::test_clip_both_module PASSED [ 57%] tests/test_operators.py::test_clip_upper_method PASSED [ 57%] tests/test_operators.py::test_clip_upper_module PASSED [ 57%] tests/test_operators.py::test_clip_lower_method PASSED [ 57%] tests/test_operators.py::test_clip_lower_module PASSED [ 58%] tests/test_optimisation.py::test_h3_vs_naive[0.0-0.0] PASSED [ 58%] tests/test_optimisation.py::test_h3_vs_naive[0.0-45.0] PASSED [ 58%] tests/test_optimisation.py::test_h3_vs_naive[45.0-0.0] PASSED [ 58%] tests/test_optimisation.py::test_h3_vs_naive[45.0-45.0] PASSED [ 58%] tests/test_optimisation.py::test_h3_vs_naive[85.0-0.0] PASSED [ 58%] tests/test_optimisation.py::test_h3_vs_naive[85.0-45.0] PASSED [ 59%] tests/test_optimisation.py::test_h3_vs_naive[1.0-95.0] PASSED [ 59%] tests/test_optimisation.py::test_h3_vs_naive_for_union[0.0-0.0] PASSED [ 59%] tests/test_optimisation.py::test_h3_vs_naive_for_union[0.0-45.0] PASSED [ 59%] tests/test_optimisation.py::test_h3_vs_naive_for_union[45.0-0.0] PASSED [ 59%] tests/test_optimisation.py::test_h3_vs_naive_for_union[45.0-45.0] PASSED [ 60%] tests/test_optimisation.py::test_h3_vs_naive_for_union[85.0-0.0] PASSED [ 60%] tests/test_optimisation.py::test_h3_vs_naive_for_union[85.0-45.0] PASSED [ 60%] tests/test_optimisation.py::test_h3_vs_naive_for_union[1.0-95.0] PASSED [ 60%] tests/test_optimisation.py::test_h3_vs_naive_for_intersection[0.0-0.0] PASSED [ 60%] tests/test_optimisation.py::test_h3_vs_naive_for_intersection[0.0-45.0] PASSED [ 60%] tests/test_optimisation.py::test_h3_vs_naive_for_intersection[45.0-0.0] PASSED [ 61%] tests/test_optimisation.py::test_h3_vs_naive_for_intersection[45.0-45.0] PASSED [ 61%] tests/test_optimisation.py::test_h3_vs_naive_for_intersection[85.0-0.0] PASSED [ 61%] tests/test_optimisation.py::test_h3_vs_naive_for_intersection[85.0-45.0] PASSED [ 61%] tests/test_optimisation.py::test_h3_vs_naive_for_intersection[1.0-95.0] PASSED [ 61%] tests/test_optimisation.py::test_cells_dont_overlap[87a968290ffffff] PASSED [ 61%] tests/test_optimisation.py::test_cells_dont_overlap[87a9680e0ffffff] PASSED [ 62%] tests/test_optimisation.py::test_cells_dont_overlap[87a96811cffffff] PASSED [ 62%] tests/test_optimisation.py::test_cells_dont_overlap[87a968293ffffff] PASSED [ 62%] tests/test_optimisation.py::test_cells_dont_overlap[87a968768ffffff] PASSED [ 62%] tests/test_optimisation.py::test_cells_dont_overlap[87a968893ffffff] PASSED [ 62%] tests/test_optimisation.py::test_cells_dont_overlap[87a968000ffffff] PASSED [ 62%] tests/test_optimisation.py::test_cells_dont_overlap[87a96b934ffffff] PASSED [ 63%] tests/test_optimisation.py::test_cells_dont_overlap[87a968130ffffff] PASSED [ 63%] tests/test_parallel_operators.py::test_add_byte_layers PASSED [ 63%] tests/test_parallel_operators.py::test_parallel_with_different_skip[1-expected_steps0] PASSED [ 63%] tests/test_parallel_operators.py::test_parallel_with_different_skip[2-expected_steps1] PASSED [ 63%] tests/test_parallel_operators.py::test_parallel_unary_numpy_apply_with_function PASSED [ 63%] tests/test_parallel_operators.py::test_parallel_unary_numpy_apply_with_lambda PASSED [ 64%] tests/test_parallel_operators.py::test_parallel_where_simple PASSED [ 64%] tests/test_pickle.py::test_pickle_raster_layer PASSED [ 64%] tests/test_pickle.py::test_pickle_raster_mem_layer_fails PASSED [ 64%] tests/test_pickle.py::test_pickle_dyanamic_vector_layer PASSED [ 64%] tests/test_pickle.py::test_pickle_uniform_area_layer PASSED [ 65%] tests/test_pickle.py::test_pickle_group_layer PASSED [ 65%] tests/test_pickle.py::test_pickle_constant_layer[2.5] PASSED [ 65%] tests/test_pickle.py::test_pickle_constant_layer[2] PASSED [ 65%] tests/test_pickle.py::test_pickle_constant_layer[c2] PASSED [ 65%] tests/test_pickle.py::test_pickle_constant_layer[c3] PASSED [ 65%] tests/test_pickle.py::test_pickle_simple_calc[2.5] PASSED [ 66%] tests/test_pickle.py::test_pickle_simple_calc[2] PASSED [ 66%] tests/test_pickle.py::test_pickle_simple_calc[c2] PASSED [ 66%] tests/test_pickle.py::test_pickle_simple_calc[c3] PASSED [ 66%] tests/test_pickle.py::test_pickle_lambda_calc PASSED [ 66%] tests/test_pickle.py::test_pickle_func_calc PASSED [ 66%] tests/test_pickle.py::test_pickle_rescaled_raster_layer PASSED [ 67%] tests/test_raster.py::test_make_basic_layer PASSED [ 67%] tests/test_raster.py::test_make_basic_layer_old_name PASSED [ 67%] tests/test_raster.py::test_layer_from_null PASSED [ 67%] tests/test_raster.py::test_layer_from_nonexistent_file PASSED [ 67%] tests/test_raster.py::test_open_file PASSED [ 67%] tests/test_raster.py::test_empty_layers_are_pixel_aligned[initial_area0] PASSED [ 68%] tests/test_raster.py::test_empty_layers_are_pixel_aligned[initial_area1] PASSED [ 68%] tests/test_raster.py::test_empty_layers_are_pixel_aligned[initial_area2] PASSED [ 68%] tests/test_raster.py::test_empty_layers_are_pixel_aligned[initial_area3] PASSED [ 68%] tests/test_raster.py::test_empty_layers_are_pixel_aligned[initial_area4] PASSED [ 68%] tests/test_raster.py::test_empty_layer_from_raster PASSED [ 68%] tests/test_raster.py::test_empty_layer_from_raster_with_no_data_value[0] PASSED [ 69%] tests/test_raster.py::test_empty_layer_from_raster_with_no_data_value[0.0] PASSED [ 69%] tests/test_raster.py::test_empty_layer_from_raster_with_no_data_value[2] PASSED [ 69%] tests/test_raster.py::test_empty_layer_from_raster_with_no_data_value[2.0] PASSED [ 69%] tests/test_raster.py::test_empty_layer_from_raster_with_new_smaller_area PASSED [ 69%] tests/test_raster.py::test_empty_layer_from_raster_new_datatype PASSED [ 70%] tests/test_raster.py::test_empty_layer_from_raster_with_window PASSED [ 70%] tests/test_raster.py::test_layer_with_positive_offset PASSED [ 70%] tests/test_raster.py::test_layer_with_zero_offset PASSED [ 70%] tests/test_raster.py::test_layer_with_negative_offset PASSED [ 70%] tests/test_raster.py::test_layer_with_excessive_negative_offset PASSED [ 70%] tests/test_raster.py::test_layer_offsets_accumulate PASSED [ 71%] tests/test_raster.py::test_scale_up PASSED [ 71%] tests/test_raster.py::test_scale_down PASSED [ 71%] tests/test_raster.py::test_read_array_size[size0-True] PASSED [ 71%] tests/test_raster.py::test_read_array_size[size1-True] PASSED [ 71%] tests/test_raster.py::test_read_array_size[size2-True] PASSED [ 71%] tests/test_raster.py::test_read_array_size[size3-False] PASSED [ 72%] tests/test_raster.py::test_read_array_size[size4-False] PASSED [ 72%] tests/test_raster.py::test_invalid_band PASSED [ 72%] tests/test_raster.py::test_multiband_raster PASSED [ 72%] tests/test_rescaling.py::test_simple_scale_down PASSED [ 72%] tests/test_rescaling.py::test_simple_scale_up PASSED [ 72%] tests/test_rescaling.py::test_scaling_up_pixels PASSED [ 73%] tests/test_rescaling.py::test_scaling_down_pixels PASSED [ 73%] tests/test_rescaling.py::test_rescaled_up_in_operation PASSED [ 73%] tests/test_rescaling.py::test_rescaled_down_in_operation PASSED [ 73%] tests/test_rescaling.py::test_rescaled_up_with_window_set PASSED [ 73%] tests/test_rescaling.py::test_rescaled_up_with_window_set_2 PASSED [ 73%] tests/test_rescaling.py::test_rescaled_down_with_window_set PASSED [ 74%] tests/test_rounding.py::test_almost_equal[1.0-1.0-True] PASSED [ 74%] tests/test_rounding.py::test_almost_equal[1.0-1.1-False] PASSED [ 74%] tests/test_rounding.py::test_almost_equal[1.1102230246251565e-16-0.0-True] PASSED [ 74%] tests/test_rounding.py::test_almost_equal[4.440892098500626e-16-0.0-False] PASSED [ 74%] tests/test_rounding.py::test_pixel_rounding_up[8033.000000000001-0.0008983152841195215-8033] PASSED [ 75%] tests/test_rounding.py::test_pixel_rounding_up[8033.001-0.0008983152841195215-8033] PASSED [ 75%] tests/test_rounding.py::test_pixel_rounding_up[8033.01-0.0008983152841195215-8034] PASSED [ 75%] tests/test_rounding.py::test_pixel_rounding_up[8032.999999999999-0.0008983152841195215-8033] PASSED [ 75%] tests/test_rounding.py::test_pixel_rounding_down[55.99999999999926-0.0008983152841195215-56] PASSED [ 75%] tests/test_rounding.py::test_pixel_rounding_down[55.998-0.0008983152841195215-56] PASSED [ 75%] tests/test_rounding.py::test_pixel_rounding_down[55.98-0.0008983152841195215-55] PASSED [ 76%] tests/test_rounding.py::test_pixel_rounding_down[55.000000000001-0.0008983152841195215-55] PASSED [ 76%] tests/test_rounding.py::test_pixel_scale_comparison[pixel_scales0-True] PASSED [ 76%] tests/test_rounding.py::test_pixel_scale_comparison[pixel_scales1-True] PASSED [ 76%] tests/test_rounding.py::test_pixel_scale_comparison[pixel_scales2-True] PASSED [ 76%] tests/test_rounding.py::test_pixel_scale_comparison[pixel_scales3-True] PASSED [ 76%] tests/test_rounding.py::test_pixel_scale_comparison[pixel_scales4-True] PASSED [ 77%] tests/test_rounding.py::test_pixel_scale_comparison[pixel_scales5-False] PASSED [ 77%] tests/test_save_with_window.py::test_add_byte_layers_with_union PASSED [ 77%] tests/test_save_with_window.py::test_add_byte_layers_with_intersection_with_max_save_raster PASSED [ 77%] tests/test_save_with_window.py::test_add_byte_layers_with_intersection_with_min_save_raster PASSED [ 77%] tests/test_sum_with_window.py::test_sum_sans_window_update PASSED [ 77%] tests/test_sum_with_window.py::test_sum_with_union PASSED [ 78%] tests/test_sum_with_window.py::test_sum_with_intersection PASSED [ 78%] tests/test_sum_with_window.py::test_save_with_sum_with_union PASSED [ 78%] tests/test_sum_with_window.py::test_save_with_sum_with_intersection PASSED [ 78%] tests/test_uniform_area_layer.py::test_open_uniform_area_layer[1.0] PASSED [ 78%] tests/test_uniform_area_layer.py::test_open_uniform_area_layer[0.2345678] PASSED [ 78%] tests/test_uniform_area_layer.py::test_incorrect_tiff_for_uniform_area PASSED [ 79%] tests/test_uniform_area_layer.py::test_set_intersection PASSED [ 79%] tests/test_union.py::test_find_union_empty_list PASSED [ 79%] tests/test_union.py::test_find_union_single_item PASSED [ 79%] tests/test_union.py::test_find_union_same PASSED [ 79%] tests/test_union.py::test_find_union_subset PASSED [ 80%] tests/test_union.py::test_find_union_overlap PASSED [ 80%] tests/test_union.py::test_find_union_distinct PASSED [ 80%] tests/test_union.py::test_find_union_with_null PASSED [ 80%] tests/test_union.py::test_find_union_different_pixel_pitch PASSED [ 80%] tests/test_union.py::test_set_union_self[0.01] PASSED [ 80%] tests/test_union.py::test_set_union_self[0.02] PASSED [ 81%] tests/test_union.py::test_set_union_self[0.03] PASSED [ 81%] tests/test_union.py::test_set_union_self[0.04] PASSED [ 81%] tests/test_union.py::test_set_union_self[0.05] PASSED [ 81%] tests/test_union.py::test_set_union_self[0.06] PASSED [ 81%] tests/test_union.py::test_set_union_self[0.07] PASSED [ 81%] tests/test_union.py::test_set_union_self[0.08] PASSED [ 82%] tests/test_union.py::test_set_union_self[0.09] PASSED [ 82%] tests/test_union.py::test_set_union_superset[1-1-0-0] PASSED [ 82%] tests/test_union.py::test_set_union_superset[0-1-0-0] PASSED [ 82%] tests/test_union.py::test_set_union_superset[1-0-0-0] PASSED [ 82%] tests/test_union.py::test_set_union_superset[0-0-0-0] PASSED [ 82%] tests/test_union.py::test_set_union_superset[1-1-1-0] PASSED [ 83%] tests/test_union.py::test_set_union_superset[0-1-1-0] PASSED [ 83%] tests/test_union.py::test_set_union_superset[1-0-1-0] PASSED [ 83%] tests/test_union.py::test_set_union_superset[0-0-1-0] PASSED [ 83%] tests/test_union.py::test_set_union_superset[1-1-0-1] PASSED [ 83%] tests/test_union.py::test_set_union_superset[0-1-0-1] PASSED [ 83%] tests/test_union.py::test_set_union_superset[1-0-0-1] PASSED [ 84%] tests/test_union.py::test_set_union_superset[0-0-0-1] PASSED [ 84%] tests/test_union.py::test_set_union_superset[1-1-1-1] PASSED [ 84%] tests/test_union.py::test_set_union_superset[0-1-1-1] PASSED [ 84%] tests/test_union.py::test_set_union_superset[1-0-1-1] PASSED [ 84%] tests/test_union.py::test_set_union_superset[0-0-1-1] PASSED [ 85%] tests/test_vectors.py::test_basic_vector_layer_no_filter_match PASSED [ 85%] tests/test_vectors.py::test_basic_dyanamic_vector_layer PASSED [ 85%] tests/test_vectors.py::test_old_dyanamic_vector_layer PASSED [ 85%] tests/test_vectors.py::test_rastered_vector_layer PASSED [ 85%] tests/test_vectors.py::test_old_rastered_vector_layer PASSED [ 85%] tests/test_vectors.py::test_basic_dynamic_vector_layer_no_filter_match PASSED [ 86%] tests/test_vectors.py::test_multi_area_vector PASSED [ 86%] tests/test_vectors.py::test_empty_layer_from_vector PASSED [ 86%] tests/test_vectors.py::test_vector_layers_with_default_burn_value[VectorLayer] PASSED [ 86%] tests/test_vectors.py::test_vector_layers_with_default_burn_value[RasteredVectorLayer] PASSED [ 86%] tests/test_vectors.py::test_vector_layers_with_fixed_burn_value[VectorLayer] PASSED [ 86%] tests/test_vectors.py::test_vector_layers_with_fixed_burn_value[RasteredVectorLayer] PASSED [ 87%] tests/test_vectors.py::test_vector_layers_with_default_burn_value_and_filter[VectorLayer] PASSED [ 87%] tests/test_vectors.py::test_vector_layers_with_default_burn_value_and_filter[RasteredVectorLayer] PASSED [ 87%] tests/test_vectors.py::test_vector_layers_with_invalid_burn_value[VectorLayer] PASSED [ 87%] tests/test_vectors.py::test_vector_layers_with_invalid_burn_value[RasteredVectorLayer] PASSED [ 87%] tests/test_vectors.py::test_vector_layers_with_field_value[VectorLayer] PASSED [ 87%] tests/test_vectors.py::test_vector_layers_with_field_value[RasteredVectorLayer] PASSED [ 88%] tests/test_vectors.py::test_vector_layers_with_guessed_type_burn_value[1-1] PASSED [ 88%] tests/test_vectors.py::test_vector_layers_with_guessed_type_burn_value[42-1] PASSED [ 88%] tests/test_vectors.py::test_vector_layers_with_guessed_type_burn_value[-1-3] PASSED [ 88%] tests/test_vectors.py::test_vector_layers_with_guessed_type_burn_value[1024-2] PASSED [ 88%] tests/test_vectors.py::test_vector_layers_with_guessed_type_burn_value[1048576-4] PASSED [ 88%] tests/test_vectors.py::test_vector_layers_with_guessed_type_burn_value[-1048576-5] PASSED [ 89%] tests/test_vectors.py::test_vector_layers_with_guessed_type_burn_value[1.0-7] PASSED [ 89%] tests/test_vectors.py::test_vector_layers_with_different_type_burn_value[1-1] PASSED [ 89%] tests/test_vectors.py::test_vector_layers_with_different_type_burn_value[42-1] PASSED [ 89%] tests/test_vectors.py::test_vector_layers_with_different_type_burn_value[1-3] PASSED [ 89%] tests/test_vectors.py::test_vector_layers_with_different_type_burn_value[42-3] PASSED [ 90%] tests/test_vectors.py::test_vector_layers_with_different_type_burn_value[1024-3] PASSED [ 90%] tests/test_vectors.py::test_vector_layers_with_different_type_burn_value[1.0-6] PASSED [ 90%] tests/test_vectors.py::test_vector_layers_with_different_type_burn_value[0.5-6] PASSED [ 90%] tests/test_vectors.py::test_vector_layers_with_different_type_burn_value[1.0-7] PASSED [ 90%] tests/test_vectors.py::test_vector_layers_with_guess_field_type_burn_value[1-13] PASSED [ 90%] tests/test_vectors.py::test_vector_layers_with_guess_field_type_burn_value[1.0-7] PASSED [ 91%] tests/test_vectors.py::test_read_array_size[size0-True] PASSED [ 91%] tests/test_vectors.py::test_read_array_size[size1-True] PASSED [ 91%] tests/test_vectors.py::test_read_array_size[size2-True] PASSED [ 91%] tests/test_vectors.py::test_read_array_size[size3-False] PASSED [ 91%] tests/test_vectors.py::test_read_array_size[size4-False] PASSED [ 91%] tests/test_vectors.py::test_anchor_offsets[anchor0-area0-expected0] PASSED [ 92%] tests/test_vectors.py::test_anchor_offsets[anchor1-area1-expected1] PASSED [ 92%] tests/test_vectors.py::test_anchor_offsets[anchor2-area2-expected2] PASSED [ 92%] tests/test_vectors.py::test_anchor_offsets[anchor3-area3-expected3] PASSED [ 92%] tests/test_vectors.py::test_anchor_offsets[anchor4-area4-expected4] PASSED [ 92%] tests/test_vectors.py::test_anchor_offsets[anchor5-area5-expected5] PASSED [ 92%] tests/test_vectors.py::test_anchor_offsets[anchor6-area6-expected6] PASSED [ 93%] tests/test_vectors.py::test_anchor_offsets[anchor7-area7-expected7] PASSED [ 93%] tests/test_vectors.py::test_anchor_offsets[anchor8-area8-expected8] PASSED [ 93%] tests/test_vectors.py::test_anchor_offsets[anchor9-area9-expected9] PASSED [ 93%] tests/test_vectors.py::test_anchor_offsets[anchor10-area10-expected10] PASSED [ 93%] tests/test_vectors.py::test_anchor_offsets[anchor11-area11-expected11] PASSED [ 93%] tests/test_vectors.py::test_anchor_offsets[anchor12-area12-expected12] PASSED [ 94%] tests/test_vectors.py::test_anchor_offsets[anchor13-area13-expected13] PASSED [ 94%] tests/test_vectors.py::test_anchor_offsets[anchor14-area14-expected14] PASSED [ 94%] tests/test_vectors.py::test_anchor_offsets[anchor15-area15-expected15] PASSED [ 94%] tests/test_vectors.py::test_anchor_offsets[anchor16-area16-expected16] PASSED [ 94%] tests/test_vectors.py::test_anchor_offsets[anchor17-area17-expected17] PASSED [ 95%] tests/test_vectors.py::test_vector_layers_with_empty_features[VectorLayer] PASSED [ 95%] tests/test_vectors.py::test_vector_layers_with_empty_features[RasteredVectorLayer] PASSED [ 95%] tests/test_window.py::test_window_operators[lhs0-rhs0-False-True] PASSED [ 95%] tests/test_window.py::test_window_operators[lhs1-rhs1-False-True] PASSED [ 95%] tests/test_window.py::test_window_operators[lhs2-rhs2-False-True] PASSED [ 95%] tests/test_window.py::test_window_operators[lhs3-rhs3-False-True] PASSED [ 96%] tests/test_window.py::test_window_operators[lhs4-rhs4-False-True] PASSED [ 96%] tests/test_window.py::test_window_operators[lhs5-rhs5-False-True] PASSED [ 96%] tests/test_window.py::test_window_operators[lhs6-rhs6-False-True] PASSED [ 96%] tests/test_window.py::test_window_operators[lhs7-rhs7-False-False] PASSED [ 96%] tests/test_window.py::test_window_operators[lhs8-rhs8-False-False] PASSED [ 96%] tests/test_window.py::test_window_operators[lhs9-rhs9-False-False] PASSED [ 97%] tests/test_window.py::test_window_operators[lhs10-rhs10-False-False] PASSED [ 97%] tests/test_window.py::test_window_operators[lhs11-rhs11-True-False] PASSED [ 97%] tests/test_window.py::test_window_operators[lhs12-rhs12-True-False] PASSED [ 97%] tests/test_window.py::test_window_operators[lhs13-rhs13-True-False] PASSED [ 97%] tests/test_window.py::test_window_operators[lhs14-rhs14-True-False] PASSED [ 97%] tests/test_window.py::test_window_operators[lhs15-rhs15-False-False] PASSED [ 98%] tests/test_window.py::test_window_operators[lhs16-rhs16-False-False] PASSED [ 98%] tests/test_window.py::test_window_operators[lhs17-rhs17-False-False] PASSED [ 98%] tests/test_window.py::test_window_operators[lhs18-rhs18-False-False] PASSED [ 98%] tests/test_window.py::test_window_operators[lhs19-rhs19-True-False] PASSED [ 98%] tests/test_window.py::test_window_operators[lhs20-rhs20-True-False] PASSED [ 98%] tests/test_window.py::test_find_intersection_empty_list PASSED [ 99%] tests/test_window.py::test_find_intersection_single_item PASSED [ 99%] tests/test_window.py::test_find_intersection_same PASSED [ 99%] tests/test_window.py::test_find_intersection_subset PASSED [ 99%] tests/test_window.py::test_find_intersection_overlap PASSED [ 99%] tests/test_window.py::test_find_intersection_distinct PASSED [100%] ============================= 580 passed in 24.41s ============================= ---> Removed intermediate container ca75222edfd0 ---> f8d8caa7991f Step 10/10 : RUN python -m pylint yirgacheffe ---> Running in 43f0cde13f50 ------------------------------------ Your code has been rated at 10.00/10 ---> Removed intermediate container 43f0cde13f50 ---> c9c4b10f06c1 Successfully built c9c4b10f06c1 2025-03-27 11:07.54: Job succeeded