File: test_setup_no_data_value.py

package info (click to toggle)
gdal 2.4.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 106,060 kB
  • sloc: cpp: 1,034,177; ansic: 177,878; python: 23,590; perl: 7,420; sh: 6,285; java: 5,382; xml: 3,100; cs: 2,343; yacc: 1,198; makefile: 518; sql: 112
file content (58 lines) | stat: -rw-r--r-- 1,895 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
from unittest import mock, TestCase

import gdal2tiles


class AttrDict(dict):
    def __init__(self, *args, **kwargs):
        super(AttrDict, self).__init__(*args, **kwargs)
        self.__dict__ = self


class SetupNoDataValueTest(TestCase):

    def setUp(self):
        self.DEFAULT_OPTIONS = {
            'srcnodata': None,
            'verbose': True,
        }
        self.DEFAULT_ATTRDICT_OPTIONS = AttrDict(self.DEFAULT_OPTIONS)

        self.nodata_in_input = [1, 2, 3, 4]
        self.RASTER_COUNT = 4

        self.mock_dataset = mock.MagicMock()
        self.mock_dataset.RasterCount = self.RASTER_COUNT
        self.mock_dataset.GetRasterBand().GetNoDataValue = mock.MagicMock(
            side_effect=self.nodata_in_input)

    def test_reads_values_from_input_dataset(self):
        nodata = gdal2tiles.setup_no_data_values(self.mock_dataset, self.DEFAULT_ATTRDICT_OPTIONS)

        self.assertEqual(nodata, self.nodata_in_input)

    def test_uses_the_passed_arguments_in_priority(self):
        arg_nodata = "0,2,4,8"
        self.DEFAULT_ATTRDICT_OPTIONS['srcnodata'] = arg_nodata

        nodata = gdal2tiles.setup_no_data_values(self.mock_dataset, self.DEFAULT_ATTRDICT_OPTIONS)

        self.assertEqual(nodata, [float(x) for x in arg_nodata.split(',')])

    def test_extends_passed_arguments_if_not_enough_values_given(self):
        def test_with_args(arg_nodata):
            self.DEFAULT_ATTRDICT_OPTIONS['srcnodata'] = arg_nodata

            nodata = gdal2tiles.setup_no_data_values(
                self.mock_dataset, self.DEFAULT_ATTRDICT_OPTIONS)

            extended_args = ",".join([arg_nodata] * self.RASTER_COUNT)

            self.assertEqual(
                nodata,
                [float(x) for x in extended_args.split(',')][:self.RASTER_COUNT]
            )

        test_with_args("0,2,4")
        test_with_args("0,2")
        test_with_args("0")