From 493ce833f0d9d9d51a792c229b71f8dd95a8ba9f Mon Sep 17 00:00:00 2001 From: "Benjamin W. Portner" Date: Sun, 18 Feb 2024 19:35:04 +0100 Subject: [PATCH 1/2] add test for generic strategy overwrite_exchange_field_values --- tests/strategies/generic.py | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/tests/strategies/generic.py b/tests/strategies/generic.py index 95f12272..2620e4d6 100644 --- a/tests/strategies/generic.py +++ b/tests/strategies/generic.py @@ -9,6 +9,8 @@ tupleize_categories, split_exchanges, ) +from bw2io.strategies.generic import overwrite_exchange_field_values +from bw2data.tests import bw2test from bw2data import Database from copy import deepcopy import numpy as np @@ -397,3 +399,27 @@ def test_split_exchanges_no_changes(): }]} ] assert split_exchanges(data, {'name': 'football'}, [{'location': 'A'}, {'location': 'B', 'cat': 'dog'}], [12/20, 8/20]) == expected + + +@bw2test +def test_overwrite_exchange_field_values(): + db = Database("bio") + db.write( + { + ("bio", "1"): {"code": 1, "name": "foo", "categories": ("air",)}, + ("bio", "2"): {"code": 2, "name": "foo", "categories": ("water",)}, + ("bio", "3"): {"code": 3, "name": "foo", "categories": ("soil",)}, + } + ) + + # default fields -> should add name and overwrite categories + ds = [{"exchanges": [{"input": ("bio", "2"), "categories": "water"}]}] + got = overwrite_exchange_field_values(ds) + expected = [{"exchanges": [{"input": ("bio", "2"), "categories": ("water",), "name": "foo"}]}] + assert got == expected + + # prevent adding name by specifying fields + ds = [{"exchanges": [{"input": ("bio", "2"), "categories": "water"}]}] + got = overwrite_exchange_field_values(ds.copy(), fields=["categories"]) + expected = [{"exchanges": [{"input": ("bio", "2"), "categories": ("water",)}]}] + assert got == expected From 0b0d195f448041f5287df0088f121b409976031e Mon Sep 17 00:00:00 2001 From: "Benjamin W. Portner" Date: Sun, 18 Feb 2024 19:42:47 +0100 Subject: [PATCH 2/2] add test for generic strategy test_assign_default_location --- tests/strategies/generic.py | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/tests/strategies/generic.py b/tests/strategies/generic.py index 2620e4d6..2e8e4845 100644 --- a/tests/strategies/generic.py +++ b/tests/strategies/generic.py @@ -9,7 +9,7 @@ tupleize_categories, split_exchanges, ) -from bw2io.strategies.generic import overwrite_exchange_field_values +from bw2io.strategies.generic import overwrite_exchange_field_values, assign_default_location from bw2data.tests import bw2test from bw2data import Database from copy import deepcopy @@ -423,3 +423,29 @@ def test_overwrite_exchange_field_values(): got = overwrite_exchange_field_values(ds.copy(), fields=["categories"]) expected = [{"exchanges": [{"input": ("bio", "2"), "categories": ("water",)}]}] assert got == expected + + +def test_assign_default_location(): + ds = [ + {"name": "foo", "location": "DE"}, + {"name": "bar"}, + {"name": "con", "location": "CH"}, + ] + + # default should add "GLO" as missing locations + got = assign_default_location(ds) + expected = [ + {"name": "foo", "location": "DE"}, + {"name": "bar", "location": "GLO"}, + {"name": "con", "location": "CH"}, + ] + assert got == expected + + # test overwrite with custom loc + got = assign_default_location(ds, default_loc="ES", overwrite=True) + expected = [ + {"name": "foo", "location": "ES"}, + {"name": "bar", "location": "ES"}, + {"name": "con", "location": "ES"}, + ] + assert got == expected \ No newline at end of file