Skip to content

Another update for all English databooks #233

Another update for all English databooks

Another update for all English databooks #233

GitHub Actions / JUnit Test Report failed Mar 28, 2024 in 0s

412 tests run, 376 passed, 0 skipped, 36 failed.

Annotations

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/MDV_databook.xlsx]

Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation

Target population is 0 for Cash transfers

Target population is 0 for Lipid-based nutrition supplements

Target population is 0 for Public provision of complementary foods

Target population is 0 for Small quantity lipid-based nutrition supplements
Raw output
self = <nutrition.data.Dataset at 0x7f41547e7c90>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'MDV_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41547eda90>
country = None, region = None, name = 'MDV_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f41551edcd0>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...a90>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/MDV_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f41547e7c90>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'MDV_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41547eda90>
country = None, region = None, name = 'MDV_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/KAZ_databook.xlsx]

Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation

Target population is 0 for Cash transfers

Target population is 0 for Lipid-based nutrition supplements

Target population is 0 for Public provision of complementary foods

Target population is 0 for Small quantity lipid-based nutrition supplements
Raw output
self = <nutrition.data.Dataset at 0x7fac27297150>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'KAZ_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac27268dd0>
country = None, region = None, name = 'KAZ_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac261e81d0>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...0d0>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/KAZ_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac27297150>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'KAZ_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac27268dd0>
country = None, region = None, name = 'KAZ_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/UKR_databook.xlsx]

Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation

Target population is 0 for Cash transfers

Target population is 0 for Lipid-based nutrition supplements

Target population is 0 for Public provision of complementary foods

Target population is 0 for Small quantity lipid-based nutrition supplements
Raw output
self = <nutrition.data.Dataset at 0x7fac26750a90>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'UKR_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac28a75590>
country = None, region = None, name = 'UKR_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac26752110>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...ad0>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/UKR_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac26750a90>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'UKR_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac28a75590>
country = None, region = None, name = 'UKR_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/RUS_databook.xlsx]

Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation

Target population is 0 for Cash transfers

Target population is 0 for Lipid-based nutrition supplements

Target population is 0 for Public provision of complementary foods

Target population is 0 for Small quantity lipid-based nutrition supplements
Raw output
self = <nutrition.data.Dataset at 0x7f4154566050>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'RUS_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41545663d0>
country = None, region = None, name = 'RUS_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f4154607b10>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...450>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/RUS_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f4154566050>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'RUS_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41545663d0>
country = None, region = None, name = 'RUS_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/THA_databook.xlsx]

Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation

Target population is 0 for Cash transfers

Target population is 0 for Lipid-based nutrition supplements

Target population is 0 for Public provision of complementary foods

Target population is 0 for Small quantity lipid-based nutrition supplements
Raw output
self = <nutrition.data.Dataset at 0x7f41543dfa10>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'THA_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41549ce210>
country = None, region = None, name = 'THA_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f4154f496d0>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...8d0>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/THA_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f41543dfa10>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'THA_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41549ce210>
country = None, region = None, name = 'THA_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/AZE_databook.xlsx]

Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation

Target population is 0 for Cash transfers

Target population is 0 for Lipid-based nutrition supplements

Target population is 0 for Public provision of complementary foods

Target population is 0 for Small quantity lipid-based nutrition supplements
Raw output
self = <nutrition.data.Dataset at 0x7f4154520690>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'AZE_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f4154e51690>
country = None, region = None, name = 'AZE_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f41545277d0>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...ed0>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/AZE_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f4154520690>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'AZE_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f4154e51690>
country = None, region = None, name = 'AZE_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/MYS_databook.xlsx]

Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation

Target population is 0 for Cash transfers

Target population is 0 for Lipid-based nutrition supplements

Target population is 0 for Public provision of complementary foods

Target population is 0 for Small quantity lipid-based nutrition supplements
Raw output
self = <nutrition.data.Dataset at 0x7f4154478a50>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'MYS_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f415447b1d0>
country = None, region = None, name = 'MYS_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f41547ef010>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...450>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/MYS_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f4154478a50>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'MYS_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f415447b1d0>
country = None, region = None, name = 'MYS_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/BLR_databook.xlsx]

Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation

Target population is 0 for Cash transfers

Target population is 0 for Lipid-based nutrition supplements

Target population is 0 for Public provision of complementary foods

Target population is 0 for Small quantity lipid-based nutrition supplements
Raw output
self = <nutrition.data.Dataset at 0x7fac26b527d0>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'BLR_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac27e77750>
country = None, region = None, name = 'BLR_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac25c32390>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...0d0>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/BLR_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac26b527d0>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'BLR_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac27e77750>
country = None, region = None, name = 'BLR_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Target population is 0 for Balanced energy-protein supplementation
E           
E           Target population is 0 for Cash transfers
E           
E           Target population is 0 for Lipid-based nutrition supplements
E           
E           Target population is 0 for Public provision of complementary foods
E           
E           Target population is 0 for Small quantity lipid-based nutrition supplements

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/BLR_databook.xlsx]

Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado

La población objetivo es 0 para Transferencias de efectivo

La población objetivo es 0 para Suplementos nutricionales a base de lípidos

La población objetivo es 0 para Suministro público de alimentos complementarios

La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades
Raw output
self = <nutrition.data.Dataset at 0x7fac26e41150>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'BLR_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac26e2c7d0>
country = None, region = None, name = 'BLR_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac25fd0e10>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...110>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/BLR_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac26e41150>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'BLR_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac26e2c7d0>
country = None, region = None, name = 'BLR_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/MDV_databook.xlsx]

Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado

La población objetivo es 0 para Transferencias de efectivo

La población objetivo es 0 para Suplementos nutricionales a base de lípidos

La población objetivo es 0 para Suministro público de alimentos complementarios

La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades
Raw output
self = <nutrition.data.Dataset at 0x7fac25e1f250>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'MDV_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac27298190>
country = None, region = None, name = 'MDV_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac25ea0650>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...890>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/MDV_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac25e1f250>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'MDV_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac27298190>
country = None, region = None, name = 'MDV_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/RUS_databook.xlsx]

Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado

La población objetivo es 0 para Transferencias de efectivo

La población objetivo es 0 para Suplementos nutricionales a base de lípidos

La población objetivo es 0 para Suministro público de alimentos complementarios

La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades
Raw output
self = <nutrition.data.Dataset at 0x7fac26526810>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'RUS_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac2623ec50>
country = None, region = None, name = 'RUS_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac25f6a350>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...090>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/RUS_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac26526810>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'RUS_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac2623ec50>
country = None, region = None, name = 'RUS_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/BIH_databook.xlsx]

ZeroDivisionError: float division by zero
Raw output
path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/BIH_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:184: in load_data
    self.add_model(name, growth=growth)  # add model associated with the dataset or datasets
../nutrition/utils.py:85: in wrapper
    return f(*args, **kwargs)
../nutrition/project.py:372: in add_model
    model = Model(dataset, t, growth=growth)
../nutrition/model.py:25: in __init__
    self._set_progs(self.prog_info.base_progset())
../nutrition/model.py:71: in _set_progs
    self.prog_info.set_init_covs(self.pops)
../nutrition/programs.py:661: in set_init_covs
    prog.set_pop_sizes(pops)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.programs.Program at 0x7f415524ad90>
[<class 'nutrition.programs.Program'>, <class 'sciris.sc_printing.prett...  6,  7,  8,  9, 10,
                    11])
————————————————————————————————————————————————————————————————————————

pops = [<nutrition.populations.Children at 0x7f4154ee3a50>
[<class 'nutrition.populations.Children'>, <class 'nutrition.popul...d0>
              [<class 'nutrition.s [...]
————————————————————————————————————————————————————————————————————————
]

    def set_pop_sizes(self, pops):
        self._set_restrpop(pops)
        self._set_unrestrpop(pops)
        # this accounts for different fractions within age bands
>       self.sat_unrestr = self.restr_popsize / self.unrestr_popsize
E       ZeroDivisionError: float division by zero

../nutrition/programs.py:112: ZeroDivisionError

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[en/LiST countries/TON_databook.xlsx]

Exception: Error in program data: Target population is 0 for Oral rehydration salts

Target population is 0 for Zinc for treatment + ORS
Raw output
self = <nutrition.data.Dataset at 0x7f4154fd6010>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'TON_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f4154fd4d50>
country = None, region = None, name = 'TON_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f41548a8290>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...450>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Target population is 0 for Oral rehydration salts
E           
E           Target population is 0 for Zinc for treatment + ORS

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/en/LiST countries/TON_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f4154fd6010>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'TON_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f4154fd4d50>
country = None, region = None, name = 'TON_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Target population is 0 for Oral rehydration salts
E           
E           Target population is 0 for Zinc for treatment + ORS

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/KAZ_databook.xlsx]

Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado

La población objetivo es 0 para Transferencias de efectivo

La población objetivo es 0 para Suplementos nutricionales a base de lípidos

La población objetivo es 0 para Suministro público de alimentos complementarios

La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades
Raw output
self = <nutrition.data.Dataset at 0x7f4154c071d0>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'KAZ_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f415418dc50>
country = None, region = None, name = 'KAZ_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f4154ec7a90>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...450>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/KAZ_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f4154c071d0>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'KAZ_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f415418dc50>
country = None, region = None, name = 'KAZ_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/UKR_databook.xlsx]

Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado

La población objetivo es 0 para Transferencias de efectivo

La población objetivo es 0 para Suplementos nutricionales a base de lípidos

La población objetivo es 0 para Suministro público de alimentos complementarios

La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades
Raw output
self = <nutrition.data.Dataset at 0x7f41550db810>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'UKR_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41547d7290>
country = None, region = None, name = 'UKR_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f4154465d10>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...e50>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/UKR_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f41550db810>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'UKR_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41547d7290>
country = None, region = None, name = 'UKR_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/THA_databook.xlsx]

Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado

La población objetivo es 0 para Transferencias de efectivo

La población objetivo es 0 para Suplementos nutricionales a base de lípidos

La población objetivo es 0 para Suministro público de alimentos complementarios

La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades
Raw output
self = <nutrition.data.Dataset at 0x7fac25e97710>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'THA_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac279ff890>
country = None, region = None, name = 'THA_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac2585f710>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...5d0>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/THA_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac25e97710>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'THA_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac279ff890>
country = None, region = None, name = 'THA_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/LCA_databook.xlsx]

Exception: Error in program data: El costo es 0 o negativo para Tratamiento de la MAS
Raw output
self = <nutrition.data.Dataset at 0x7f41549ced10>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'LCA_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f415550ea10>
country = None, region = None, name = 'LCA_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f41549b7350>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...450>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: El costo es 0 o negativo para Tratamiento de la MAS

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/LCA_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f41549ced10>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'LCA_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f415550ea10>
country = None, region = None, name = 'LCA_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: El costo es 0 o negativo para Tratamiento de la MAS

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/AZE_databook.xlsx]

Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado

La población objetivo es 0 para Transferencias de efectivo

La población objetivo es 0 para Suplementos nutricionales a base de lípidos

La población objetivo es 0 para Suministro público de alimentos complementarios

La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades
Raw output
self = <nutrition.data.Dataset at 0x7fac262e9c90>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'AZE_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac25dbc2d0>
country = None, region = None, name = 'AZE_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac259ec590>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...090>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/AZE_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac262e9c90>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'AZE_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac25dbc2d0>
country = None, region = None, name = 'AZE_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/MYS_databook.xlsx]

Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado

La población objetivo es 0 para Transferencias de efectivo

La población objetivo es 0 para Suplementos nutricionales a base de lípidos

La población objetivo es 0 para Suministro público de alimentos complementarios

La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades
Raw output
self = <nutrition.data.Dataset at 0x7fac25b6ac10>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'MYS_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac26801b10>
country = None, region = None, name = 'MYS_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac25aad990>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...090>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/MYS_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac25b6ac10>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'MYS_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac26801b10>
country = None, region = None, name = 'MYS_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La población objetivo es 0 para Suplemento energético-proteico equilibrado
E           
E           La población objetivo es 0 para Transferencias de efectivo
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos
E           
E           La población objetivo es 0 para Suministro público de alimentos complementarios
E           
E           La población objetivo es 0 para Suplementos nutricionales a base de lípidos en pequeñas cantidades

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/TUR_databook.xlsx]

ZeroDivisionError: float division by zero
Raw output
path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/TUR_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:184: in load_data
    self.add_model(name, growth=growth)  # add model associated with the dataset or datasets
../nutrition/utils.py:85: in wrapper
    return f(*args, **kwargs)
../nutrition/project.py:372: in add_model
    model = Model(dataset, t, growth=growth)
../nutrition/model.py:25: in __init__
    self._set_progs(self.prog_info.base_progset())
../nutrition/model.py:71: in _set_progs
    self.prog_info.set_init_covs(self.pops)
../nutrition/programs.py:661: in set_init_covs
    prog.set_pop_sizes(pops)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.programs.Program at 0x7fac2610db50>
[<class 'nutrition.programs.Program'>, <class 'sciris.sc_printing.prett... years: array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
————————————————————————————————————————————————————————————————————————

pops = [<nutrition.populations.Children at 0x7fac25b93450>
[<class 'nutrition.populations.Children'>, <class 'nutrition.popul...10>
              [<class 'nutrition.s [...]
————————————————————————————————————————————————————————————————————————
]

    def set_pop_sizes(self, pops):
        self._set_restrpop(pops)
        self._set_unrestrpop(pops)
        # this accounts for different fractions within age bands
>       self.sat_unrestr = self.restr_popsize / self.unrestr_popsize
E       ZeroDivisionError: float division by zero

../nutrition/programs.py:112: ZeroDivisionError

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/JOR_databook.xlsx]

ZeroDivisionError: float division by zero
Raw output
path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/JOR_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:184: in load_data
    self.add_model(name, growth=growth)  # add model associated with the dataset or datasets
../nutrition/utils.py:85: in wrapper
    return f(*args, **kwargs)
../nutrition/project.py:372: in add_model
    model = Model(dataset, t, growth=growth)
../nutrition/model.py:25: in __init__
    self._set_progs(self.prog_info.base_progset())
../nutrition/model.py:71: in _set_progs
    self.prog_info.set_init_covs(self.pops)
../nutrition/programs.py:661: in set_init_covs
    prog.set_pop_sizes(pops)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.programs.Program at 0x7fac25e9be10>
[<class 'nutrition.programs.Program'>, <class 'sciris.sc_printing.prett... years: array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
————————————————————————————————————————————————————————————————————————

pops = [<nutrition.populations.Children at 0x7fac25d4b450>
[<class 'nutrition.populations.Children'>, <class 'nutrition.popul...10>
              [<class 'nutrition.s [...]
————————————————————————————————————————————————————————————————————————
]

    def set_pop_sizes(self, pops):
        self._set_restrpop(pops)
        self._set_unrestrpop(pops)
        # this accounts for different fractions within age bands
>       self.sat_unrestr = self.restr_popsize / self.unrestr_popsize
E       ZeroDivisionError: float division by zero

../nutrition/programs.py:112: ZeroDivisionError

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[fr/LiST countries/LCA_databook.xlsx]

Exception: Error in program data: Le coût est égal à 0 ou négatif pour Traitement de la MAS
Raw output
self = <nutrition.data.Dataset at 0x7f41547ec090>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'LCA_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41542ca390>
country = None, region = None, name = 'LCA_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7f4154dd2f10>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...450>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: Le coût est égal à 0 ou négatif pour Traitement de la MAS

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/fr/LiST countries/LCA_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7f41547ec090>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'LCA_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7f41542ca390>
country = None, region = None, name = 'LCA_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: Le coût est égal à 0 ou négatif pour Traitement de la MAS

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/BIH_databook.xlsx]

ZeroDivisionError: float division by zero
Raw output
path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/BIH_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:184: in load_data
    self.add_model(name, growth=growth)  # add model associated with the dataset or datasets
../nutrition/utils.py:85: in wrapper
    return f(*args, **kwargs)
../nutrition/project.py:372: in add_model
    model = Model(dataset, t, growth=growth)
../nutrition/model.py:25: in __init__
    self._set_progs(self.prog_info.base_progset())
../nutrition/model.py:71: in _set_progs
    self.prog_info.set_init_covs(self.pops)
../nutrition/programs.py:661: in set_init_covs
    prog.set_pop_sizes(pops)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.programs.Program at 0x7fac25952790>
[<class 'nutrition.programs.Program'>, <class 'sciris.sc_printing.prett... years: array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
————————————————————————————————————————————————————————————————————————

pops = [<nutrition.populations.Children at 0x7fac25b2aa90>
[<class 'nutrition.populations.Children'>, <class 'nutrition.popul...50>
              [<class 'nutrition.s [...]
————————————————————————————————————————————————————————————————————————
]

    def set_pop_sizes(self, pops):
        self._set_restrpop(pops)
        self._set_unrestrpop(pops)
        # this accounts for different fractions within age bands
>       self.sat_unrestr = self.restr_popsize / self.unrestr_popsize
E       ZeroDivisionError: float division by zero

../nutrition/programs.py:112: ZeroDivisionError

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[es/LiST countries/TON_databook.xlsx]

Exception: Error in program data: La población objetivo es 0 para Sales de rehidratación oral

La población objetivo es 0 para Zinc para el tratamiento + SRO
Raw output
self = <nutrition.data.Dataset at 0x7fac25f5b750>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'TON_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac25c936d0>
country = None, region = None, name = 'TON_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac2676de10>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...0d0>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La población objetivo es 0 para Sales de rehidratación oral
E           
E           La población objetivo es 0 para Zinc para el tratamiento + SRO

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/es/LiST countries/TON_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac25f5b750>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'TON_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac25c936d0>
country = None, region = None, name = 'TON_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La población objetivo es 0 para Sales de rehidratación oral
E           
E           La población objetivo es 0 para Zinc para el tratamiento + SRO

../nutrition/data.py:1006: Exception

Check failure on line 14 in tests/test_tox_databooks.py

See this annotation in the file changed.

@github-actions github-actions / JUnit Test Report

test_tox_databooks.test_databook[fr/LiST countries/KAZ_databook.xlsx]

Exception: Error in program data: La population cible est 0 pour Supplémentation équilibrée en énergie et en protéines

La population cible est 0 pour Transferts monétaires

La population cible est 0 pour Supplémentation en nutriments à base de lipides

La population cible est 0 pour Fourniture publique d'aliments complémentaires

La population cible est 0 pour Petite quantité de supplémentation en nutriments à base de lipides
Raw output
self = <nutrition.data.Dataset at 0x7fac25cc4610>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'KAZ_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac256bde90>
country = None, region = None, name = 'KAZ_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
>           self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)

../nutrition/data.py:1004: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/data.py:683: in __init__
    self.validate()
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.ProgramData at 0x7fac2564dbd0>
[<class 'nutrition.data.ProgramData'>]
————————————————————————————————...350>
                 [<class 'nutritio [...]
————————————————————————————————————————————————————————————————————————


    def validate(self):
        """ Validate program data """
        invalid = []
        for progname in self.base_prog_set:
            cov = self.base_cov[progname]
            if cov < 0 or cov > 1:
                errormsg = _("Baseline coverage is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            sat = self.sat[progname]
            if sat < 0 or sat > 1:
                errormsg = _("Saturation is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_inc = self.max_inc[progname]
            if max_inc < 0 or max_inc > 1:
                errormsg = _("Maximum increase is outside the interval (0, 100) for %s") % progname
                invalid.append(errormsg)
            max_dec = self.max_dec[progname]
            if max_dec < 0 or max_dec > 1:
                errormsg = _("Maximum decrease is outside the interval (0, 100) for %s") % progname
    
                invalid.append(errormsg)
            cost = self.costs[progname]
            if cost <= 0:
                errormsg = _("Cost is 0 or negative for %s") % progname
                invalid.append(errormsg)
            if progname not in self.prog_target.keys():
                errormsg = _("Target population not defined for %s") % progname
                invalid.append(errormsg)
            elif sum(self.prog_target[progname].values()) == 0:
                errormsg = _("Target population is 0 for %s") % progname
                invalid.append(errormsg)
        if invalid:
            errors = "\n\n".join(invalid)
>           raise Exception(errors)
E           Exception: La population cible est 0 pour Supplémentation équilibrée en énergie et en protéines
E           
E           La population cible est 0 pour Transferts monétaires
E           
E           La population cible est 0 pour Supplémentation en nutriments à base de lipides
E           
E           La population cible est 0 pour Fourniture publique d'aliments complémentaires
E           
E           La population cible est 0 pour Petite quantité de supplémentation en nutriments à base de lipides

../nutrition/data.py:727: Exception

The above exception was the direct cause of the following exception:

path = PosixPath('/home/runner/work/Nutrition/Nutrition/inputs/fr/LiST countries/KAZ_databook.xlsx')

    @pytest.mark.parametrize('path', excel_files, ids=lambda x: str(x.relative_to(inputdir)))
    def test_databook(path):
        P = nu.Project("test")
>       P.load_data(inputspath=path)

test_tox_databooks.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
../nutrition/project.py:175: in load_data
    dataset = Dataset(databook=databook, country=country, region=region, name=name)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <nutrition.data.Dataset at 0x7fac25cc4610>
[<class 'nutrition.data.Dataset'>]
————————————————————————————————————————...  name: 'KAZ_databook'
          region: None
————————————————————————————————————————————————————————————————————————

databook = <pandas.io.excel._base.ExcelFile object at 0x7fac256bde90>
country = None, region = None, name = 'KAZ_databook'

    def __init__(self, databook: pandas.ExcelFile, country=None, region=None, name=None):
        """
        :param databook: Databook that is being used in the model
        :param country: The country of interest for data
        :param region: The region of interest in the country (in geospatial optimization)
        :param name:
        """
    
        self.country = country
        self.region = region
        self.name = name
    
        self.calcscache = CalcCellCache()
    
        # Read them into actual data
        try:
            self.demographic_data = DemographicData(databook, self.calcscache)
        except Exception as E:
            raise Exception("Error in databook: %s" % str(E)) from E
    
        try:
            self.prog_data = ProgramData(databook, self.demographic_data, self.calcscache)
        except Exception as E:
>           raise Exception("Error in program data: %s" % str(E)) from E
E           Exception: Error in program data: La population cible est 0 pour Supplémentation équilibrée en énergie et en protéines
E           
E           La population cible est 0 pour Transferts monétaires
E           
E           La population cible est 0 pour Supplémentation en nutriments à base de lipides
E           
E           La population cible est 0 pour Fourniture publique d'aliments complémentaires
E           
E           La population cible est 0 pour Petite quantité de supplémentation en nutriments à base de lipides

../nutrition/data.py:1006: Exception