diff options
-rw-r--r-- | config_binding_service/__init__.py | 10 | ||||
-rw-r--r-- | config_binding_service/client.py | 48 | ||||
-rw-r--r-- | config_binding_service/controller.py | 9 | ||||
-rw-r--r-- | pom.xml | 2 | ||||
-rw-r--r-- | setup.py | 2 | ||||
-rw-r--r-- | tests/test_binding.py | 226 | ||||
-rw-r--r-- | tox-local.ini | 12 | ||||
-rw-r--r-- | tox.ini | 12 |
8 files changed, 197 insertions, 124 deletions
diff --git a/config_binding_service/__init__.py b/config_binding_service/__init__.py index 5f09f1e..2835511 100644 --- a/config_binding_service/__init__.py +++ b/config_binding_service/__init__.py @@ -19,7 +19,7 @@ import os import logging -'''Configures the module root logger''' +# Configures the module root logger root = logging.getLogger() if root.handlers: root.handlers.clear() @@ -29,13 +29,19 @@ handler.setFormatter(formatter) root.addHandler(handler) root.setLevel("DEBUG") + class BadEnviornmentENVNotFound(Exception): + """ + Specific exception to be raised when a required ENV varaible is missing + """ pass + def get_logger(module=None): '''Returns a module-specific logger or global logger if the module is None''' return root if module is None else root.getChild(module) + def get_consul_uri(): """ This method waterfalls reads an envioronmental variable called CONSUL_HOST @@ -48,5 +54,3 @@ def get_consul_uri(): return "http://{0}:{1}".format(os.environ["CONSUL_HOST"], 8500) else: raise BadEnviornmentENVNotFound("CONSUL_HOST") - - diff --git a/config_binding_service/client.py b/config_binding_service/client.py index 8facf35..2c04684 100644 --- a/config_binding_service/client.py +++ b/config_binding_service/client.py @@ -40,6 +40,7 @@ class CantGetConfig(Exception): """ Represents an exception where a required key in consul isn't there """ + def __init__(self, code, response): self.code = code self.response = response @@ -49,6 +50,7 @@ class BadRequest(Exception): """ Exception to be raised when the user tried to do something they shouldn't """ + def __init__(self, response): self.code = 400 self.response = response @@ -84,7 +86,8 @@ def _consul_get_all_as_transaction(service_component_name): new_res = {} for res in result: key = res["KV"]["Key"] - new_res[key] = json.loads(base64.b64decode(res["KV"]["Value"]).decode("utf-8")) + new_res[key] = json.loads(base64.b64decode( + res["KV"]["Value"]).decode("utf-8")) if service_component_name not in new_res: raise CantGetConfig(404, "") @@ -108,18 +111,23 @@ def _get_connection_info_from_consul(service_component_name): TODO: WARNING: FIXTHIS: CALLINTHENATIONALARMY: This tries to determine that a service_component_name is a cdap application by inspecting service_component_name and name munging. However, this would force all CDAP applications to have cdap_app in their name. A much better way to do this is to do some kind of catalog_lookup here, OR MAYBE change this API so that the component_type is passed in somehow. THis is a gaping TODO. """ - _logger.info("Retrieving connection information for {0}".format(service_component_name)) - res = requests.get("{0}/v1/catalog/service/{1}".format(CONSUL, service_component_name)) + _logger.info("Retrieving connection information for {0}".format( + service_component_name)) + res = requests.get( + "{0}/v1/catalog/service/{1}".format(CONSUL, service_component_name)) res.raise_for_status() services = res.json() if services == []: - _logger.info("Warning: config and rels keys were both valid, but there is no component named {0} registered in Consul!".format(service_component_name)) - return None #later will get filtered out + _logger.info("Warning: config and rels keys were both valid, but there is no component named {0} registered in Consul!".format( + service_component_name)) + return None # later will get filtered out ip_addr = services[0]["ServiceAddress"] port = services[0]["ServicePort"] if "cdap_app" in service_component_name: - redirectish_url = "http://{0}:{1}/application/{2}".format(ip_addr, port, service_component_name) - _logger.info("component is a CDAP application; trying the broker redirect on {0}".format(redirectish_url)) + redirectish_url = "http://{0}:{1}/application/{2}".format( + ip_addr, port, service_component_name) + _logger.info("component is a CDAP application; trying the broker redirect on {0}".format( + redirectish_url)) res = requests.get(redirectish_url) res.raise_for_status() details = res.json() @@ -138,7 +146,7 @@ def _replace_rels_template(rels, template_identifier): for rel in rels: if template_identifier in rel and template_identifier is not "": returnl.append(rel) - #returnl now contains a list of DNS names (possible empty), now resolve them (or not if they are not regustered) + # returnl now contains a list of DNS names (possible empty), now resolve them (or not if they are not regustered) return list(filter(lambda x: x is not None, map(_get_connection_info_from_consul, returnl))) @@ -159,10 +167,11 @@ def _replace_value(v, rels, dmaap): - the split below sees if we have v = x,y,z... so we can support {{x,y,z,....}} - the lambda is because we can't fold operators in Python, wanted fold(+, L) where + when applied to lists in python is list concatenation """ - if isinstance(v, six.string_types): #do not try to replace anything that is not a string + if isinstance(v, six.string_types): # do not try to replace anything that is not a string match_on_rels = re.match(template_match_rels, v) if match_on_rels: - template_identifier = match_on_rels.groups()[0].strip() #now holds just x,.. of {{x,...}} + # now holds just x,.. of {{x,...}} + template_identifier = match_on_rels.groups()[0].strip() rtpartial = partial(_replace_rels_template, rels) return reduce(lambda a, b: a + b, map(rtpartial, template_identifier.split(",")), []) match_on_dmaap = re.match(template_match_dmaap, v) @@ -176,7 +185,7 @@ def _replace_value(v, rels, dmaap): So now component developers have to possible handle dicts and [], and we have to communicate that to them """ return _replace_dmaap_template(dmaap, template_identifier) - return v #was not a match or was not a string, return value as is + return v # was not a match or was not a string, return value as is def _recurse(config, rels, dmaap): @@ -195,7 +204,7 @@ def _recurse(config, rels, dmaap): return config if isinstance(config, six.string_types): return _replace_value(config, rels, dmaap) - #not a dict, not a list, not a string, nothing to do. + # not a dict, not a list, not a string, nothing to do. return config @@ -217,7 +226,7 @@ def resolve_override(config, rels=[], dmaap={}): Explicitly take in a config, rels, dmaap and try to resolve it. Useful for testing where you dont want to put the test values in consul """ - #use deepcopy to make sure that config is not touched + # use deepcopy to make sure that config is not touched return _recurse(copy.deepcopy(config), rels, dmaap) @@ -228,10 +237,10 @@ def resolve_all(service_component_name): allk = _consul_get_all_as_transaction(service_component_name) returnk = {} - #replace the config with the resolved config + # replace the config with the resolved config returnk["config"] = resolve(service_component_name) - #concatenate the items + # concatenate the items for k in allk: if "policies" in k: if "policies" not in returnk: @@ -245,7 +254,8 @@ def resolve_all(service_component_name): returnk["policies"]["items"].append(allk[k]) else: if not(k == service_component_name or k.endswith(":rels") or k.endswith(":dmaap")): - suffix = k.split(":")[1] #this would blow up if you had a key in consul without a : but this shouldnt happen + # this would blow up if you had a key in consul without a : but this shouldnt happen + suffix = k.split(":")[1] returnk[suffix] = allk[k] return returnk @@ -256,8 +266,10 @@ def get_key(key, service_component_name): Try to fetch a key k from Consul of the form service_component_name:k """ if key == "policies": - raise BadRequest(":policies is a complex folder and should be retrieved using the service_component_all API") - response = requests.get("{0}/v1/kv/{1}:{2}".format(CONSUL, service_component_name, key)) + raise BadRequest( + ":policies is a complex folder and should be retrieved using the service_component_all API") + response = requests.get( + "{0}/v1/kv/{1}:{2}".format(CONSUL, service_component_name, key)) try: response.raise_for_status() except requests.exceptions.HTTPError as exc: diff --git a/config_binding_service/controller.py b/config_binding_service/controller.py index dbdb57b..7bb5f51 100644 --- a/config_binding_service/controller.py +++ b/config_binding_service/controller.py @@ -48,7 +48,7 @@ def bind_config_for_scn(service_component_name): except client.CantGetConfig as e: return Response(status=e.code, response=e.response) - except Exception as e: #should never happen... + except Exception as e: # should never happen... _logger.error(e) return Response(response="Please report this error", status=500) @@ -67,16 +67,17 @@ def get_key(key, service_component_name): return Response(status=exc.code, response=exc.response, mimetype="text/plain") - except Exception as e: #should never happen... + except Exception as e: # should never happen... _logger.error(e) return Response(response="Please report this error", status=500) def healthcheck(): - #got this far, I must be alive... check my connection to Consul by checking myself + # got this far, I must be alive... check my connection to Consul by checking myself CONSUL = get_consul_uri() - res = requests.get("{0}/v1/catalog/service/config_binding_service".format(CONSUL)) + res = requests.get( + "{0}/v1/catalog/service/config_binding_service".format(CONSUL)) if res.status_code == 200: return Response(response="CBS is alive and Consul connection OK", status=200) @@ -29,7 +29,7 @@ ECOMP is a trademark and service mark of AT&T Intellectual Property. <groupId>org.onap.dcaegen2.platform</groupId> <artifactId>configbinding</artifactId> <name>dcaegen2-platform-configbinding</name> - <version>2.1.0</version> + <version>2.1.1</version> <url>http://maven.apache.org</url> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> @@ -20,7 +20,7 @@ from setuptools import setup, find_packages setup( name='config_binding_service', - version='2.1.0', + version='2.1.1', packages=find_packages(exclude=["tests.*", "tests"]), author="Tommy Carpenter", author_email="tommy@research.att.com", diff --git a/tests/test_binding.py b/tests/test_binding.py index 3f51285..1ed4b0a 100644 --- a/tests/test_binding.py +++ b/tests/test_binding.py @@ -29,7 +29,7 @@ from config_binding_service import client, controller def monkeyed_get_connection_info_from_consul(service_component_name): - #shared monkeypatch. probably somewhat lazy because the function htis patches can be broken up. + # shared monkeypatch. probably somewhat lazy because the function htis patches can be broken up. if service_component_name == "cdap": return '666.666.666.666:666' elif service_component_name == "testing_bravo.somedomain.com": @@ -39,7 +39,7 @@ def monkeyed_get_connection_info_from_consul(service_component_name): elif service_component_name == "testing_charlie.somedomain.com": return '5.5.5.5:555' elif service_component_name == "nonexistent_hope": - return None #the real function returns None here + return None # the real function returns None here elif service_component_name == "cdap_serv.dcae.ecomp.somedomain.com": broker_ip = '1.1.1.1' broker_port = 444 @@ -85,7 +85,8 @@ def monkeyed_requests_put(url, json): def test_consul_get_all_as_transaction(monkeypatch): monkeypatch.setattr('requests.put', monkeyed_requests_put) - allk = client._consul_get_all_as_transaction("test_service_component_name.unknown.unknown.unknown.dcae.onap.org") + allk = client._consul_get_all_as_transaction( + "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") assert allk == { 'test_service_component_name.unknown.unknown.unknown.dcae.onap.org': {'my': 'amazing config'}, 'test_service_component_name.unknown.unknown.unknown.dcae.onap.org:dti': {'my': 'dti'}, @@ -99,8 +100,10 @@ def test_consul_get_all_as_transaction(monkeypatch): def test_get_config_rels_dmaap(monkeypatch): monkeypatch.setattr('requests.put', monkeyed_requests_put) - assert ({"foo3": "bar3"}, ["foo"], {"foo4": "bar4"}) == client._get_config_rels_dmaap("scn_exists") - assert ({"foo5": "bar5"}, [], {}) == client._get_config_rels_dmaap("scn_exists_nord") + assert ({"foo3": "bar3"}, ["foo"], {"foo4": "bar4"} + ) == client._get_config_rels_dmaap("scn_exists") + assert ({"foo5": "bar5"}, [], {}) == client._get_config_rels_dmaap( + "scn_exists_nord") def test_bind_config_for_scn(monkeypatch): @@ -111,7 +114,7 @@ def test_bind_config_for_scn(monkeypatch): client.resolve("scn_NOTexists") R = controller.bind_config_for_scn("scn_exists") - assert(json.loads(R.data) == {"foo3" : "bar3"}) + assert(json.loads(R.data) == {"foo3": "bar3"}) assert(R.status_code == 200) R = controller.bind_config_for_scn("scn_NOTexists") @@ -124,153 +127,187 @@ def test_bind_config_for_scn(monkeypatch): def test_generic(monkeypatch): monkeypatch.setattr('requests.put', monkeyed_requests_put) monkeypatch.setattr('requests.get', monkeyed_requests_get) - assert client.get_key("dti", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") == json.loads('{"my": "dti"}') + assert client.get_key( + "dti", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") == json.loads('{"my": "dti"}') with pytest.raises(client.CantGetConfig): - client.get_key("nokeyforyou", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") + client.get_key( + "nokeyforyou", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") - R = controller.get_key("dti", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") + R = controller.get_key( + "dti", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") assert(json.loads(R.data) == {"my": "dti"}) assert(R.status_code == 200) - R = controller.get_key("nokeyforyou", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") + R = controller.get_key( + "nokeyforyou", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") assert(R.status_code == 404) - R = controller.get_key("policies", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") + R = controller.get_key( + "policies", "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") assert(R.status_code == 400) def test_bad_config_http(): - test_config = {'yeahhhhh' : "{{}}"} + test_config = {'yeahhhhh': "{{}}"} test_rels = ["testing_bravo.somedomain.com"] - assert {'yeahhhhh' : []} == client.resolve_override(test_config, test_rels) + assert {'yeahhhhh': []} == client.resolve_override(test_config, test_rels) + def test_bad_config_dmaap(): - test_config = {'darkness' : "<<>>"} - test_dmaap = {"WHO?" : "darkness"} - assert {'darkness' : {}} == client.resolve_override(test_config, test_dmaap) + test_config = {'darkness': "<<>>"} + test_dmaap = {"WHO?": "darkness"} + assert {'darkness': {}} == client.resolve_override(test_config, test_dmaap) + def test_config(monkeypatch): - #test config override - monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', monkeyed_get_connection_info_from_consul) - test_config = {"autoderegisterafter": "10m", "cdap_to_manage": {'some_nested_thing' : "{{cdap}}"}, "bindingttw": 5, "hcinterval": "5s"} + # test config override + monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', + monkeyed_get_connection_info_from_consul) + test_config = {"autoderegisterafter": "10m", "cdap_to_manage": { + 'some_nested_thing': "{{cdap}}"}, "bindingttw": 5, "hcinterval": "5s"} test_rels = ["cdap"] test_bind_1 = client.resolve_override(test_config, test_rels) - assert test_bind_1 == {'autoderegisterafter': '10m', 'cdap_to_manage': {'some_nested_thing': ['666.666.666.666:666']}, 'bindingttw': 5, 'hcinterval': '5s'} + assert test_bind_1 == {'autoderegisterafter': '10m', 'cdap_to_manage': { + 'some_nested_thing': ['666.666.666.666:666']}, 'bindingttw': 5, 'hcinterval': '5s'} + def test_config_with_list(monkeypatch): - monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', monkeyed_get_connection_info_from_consul) - test_config_1 = {"dcae_target_type": ["vhss-ems", "pcrf-oam"], "downstream-laika": "{{ laika }}", "some-param": "Lorem ipsum dolor sit amet"} - test_rels_1 = ["3df5292249ae4a949f173063617cea8d_docker-snmp-polling-firstnet-m"] + monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', + monkeyed_get_connection_info_from_consul) + test_config_1 = {"dcae_target_type": [ + "vhss-ems", "pcrf-oam"], "downstream-laika": "{{ laika }}", "some-param": "Lorem ipsum dolor sit amet"} + test_rels_1 = [ + "3df5292249ae4a949f173063617cea8d_docker-snmp-polling-firstnet-m"] test_bind_1 = client.resolve_override(test_config_1, test_rels_1, {}) - assert(test_bind_1 == {'dcae_target_type': ['vhss-ems', 'pcrf-oam'], 'downstream-laika': [], 'some-param': 'Lorem ipsum dolor sit amet'}) + assert(test_bind_1 == {'dcae_target_type': [ + 'vhss-ems', 'pcrf-oam'], 'downstream-laika': [], 'some-param': 'Lorem ipsum dolor sit amet'}) - test_config_2 = {"foo" : ["{{cdap}}", "notouching", "<<yo>>"]} + test_config_2 = {"foo": ["{{cdap}}", "notouching", "<<yo>>"]} test_rels_2 = ["cdap"] - test_dmaap_2={"yo" : "im here"} - test_bind_2 = client.resolve_override(test_config_2, test_rels_2, test_dmaap_2) - assert(test_bind_2 == {"foo" : [['666.666.666.666:666'], "notouching", "im here"]}) + test_dmaap_2 = {"yo": "im here"} + test_bind_2 = client.resolve_override( + test_config_2, test_rels_2, test_dmaap_2) + assert(test_bind_2 == { + "foo": [['666.666.666.666:666'], "notouching", "im here"]}) + def test_non_existent(monkeypatch): - #test a valid config-rels but the key is not in Consul - monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', monkeyed_get_connection_info_from_consul) - test_config = {"you shall not be fufilled" : "{{nonexistent_hope}}"} - test_rels = ["nonexistent_hope.rework-central.ecomp.somedomain.com"] #hopefully not registered in Consul.. + # test a valid config-rels but the key is not in Consul + monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', + monkeyed_get_connection_info_from_consul) + test_config = {"you shall not be fufilled": "{{nonexistent_hope}}"} + # hopefully not registered in Consul.. + test_rels = ["nonexistent_hope.rework-central.ecomp.somedomain.com"] test_bind_1 = client.resolve_override(test_config, test_rels, {}) - assert(test_bind_1 == {"you shall not be fufilled" : []}) + assert(test_bind_1 == {"you shall not be fufilled": []}) + def test_cdap(monkeypatch): - #user override to test CDAP functionality - monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', monkeyed_get_connection_info_from_consul) - test_rels = ["testing_alpha.somedomain.com", "testing_bravo.somedomain.com", "testing_charlie.somedomain.com", "testing_charlie.somedomain.com", "cdap"] - test_config = { "streams_publishes" : "{{alpha}}", - "services_calls" : [{"somekey" : "{{charlie}}"}], #should be dumped - "cdap_to_manage": {'some_nested_thing' : "{{cdap}}"} #no dumps - } + # user override to test CDAP functionality + monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', + monkeyed_get_connection_info_from_consul) + test_rels = ["testing_alpha.somedomain.com", "testing_bravo.somedomain.com", + "testing_charlie.somedomain.com", "testing_charlie.somedomain.com", "cdap"] + test_config = {"streams_publishes": "{{alpha}}", + # should be dumped + "services_calls": [{"somekey": "{{charlie}}"}], + "cdap_to_manage": {'some_nested_thing': "{{cdap}}"}} # no dumps test_bind_1 = client.resolve_override(test_config, test_rels) - assert test_bind_1 == {'services_calls': [{"somekey": ["5.5.5.5:555", "5.5.5.5:555"]}], 'streams_publishes': ["6.6.6.6:666"], 'cdap_to_manage': {'some_nested_thing': ['666.666.666.666:666']}} - assert test_bind_1['services_calls'] == [{"somekey" : ["5.5.5.5:555", "5.5.5.5:555"]}] + assert test_bind_1 == {'services_calls': [{"somekey": ["5.5.5.5:555", "5.5.5.5:555"]}], 'streams_publishes': [ + "6.6.6.6:666"], 'cdap_to_manage': {'some_nested_thing': ['666.666.666.666:666']}} + assert test_bind_1['services_calls'] == [ + {"somekey": ["5.5.5.5:555", "5.5.5.5:555"]}] assert test_bind_1['streams_publishes'] == ["6.6.6.6:666"] + def test_broker_redirect(monkeypatch): - #test the broker redirect - monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', monkeyed_get_connection_info_from_consul) - test_config = {"gimmie_dat_cdap" : "{{cdap_serv}}"} + # test the broker redirect + monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', + monkeyed_get_connection_info_from_consul) + test_config = {"gimmie_dat_cdap": "{{cdap_serv}}"} test_rels = ["cdap_serv.dcae.ecomp.somedomain.com"] - assert {"gimmie_dat_cdap" : ['http://1.1.1.1:444/application/cdap_serv.dcae.ecomp.somedomain.com']} == client.resolve_override(test_config, test_rels) + assert {"gimmie_dat_cdap": ['http://1.1.1.1:444/application/cdap_serv.dcae.ecomp.somedomain.com'] + } == client.resolve_override(test_config, test_rels) -def test_multiple_service_types(monkeypatch): - #test {{x,y,z}} - monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', monkeyed_get_connection_info_from_consul) - #test 1: they all resovle - test_rels = ["testing_alpha.somedomain.com", "testing_bravo.somedomain.com", "testing_charlie.somedomain.com", "testing_charlie.somedomain.com"] - config = {"ALL YOUR SERVICE BELONG TO US" : "{{alpha,bravo,charlie}}"} +def test_multiple_service_types(monkeypatch): + # test {{x,y,z}} + monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', + monkeyed_get_connection_info_from_consul) + + # test 1: they all resovle + test_rels = ["testing_alpha.somedomain.com", "testing_bravo.somedomain.com", + "testing_charlie.somedomain.com", "testing_charlie.somedomain.com"] + config = {"ALL YOUR SERVICE BELONG TO US": "{{alpha,bravo,charlie}}"} test_bind_1 = client.resolve_override(config, test_rels) - assert(test_bind_1 == {"ALL YOUR SERVICE BELONG TO US" : ['6.6.6.6:666', '7.7.7.7:777', '5.5.5.5:555', '5.5.5.5:555']}) + assert(test_bind_1 == {"ALL YOUR SERVICE BELONG TO US": [ + '6.6.6.6:666', '7.7.7.7:777', '5.5.5.5:555', '5.5.5.5:555']}) - #test 2: two resolve, one is missing from rels key - config2 = {"two there one not exist" : "{{alpha,bravo,notexist}}"} + # test 2: two resolve, one is missing from rels key + config2 = {"two there one not exist": "{{alpha,bravo,notexist}}"} test_bind_2 = client.resolve_override(config2, test_rels) - assert(test_bind_2 == {"two there one not exist" : ['6.6.6.6:666', '7.7.7.7:777']}) + assert(test_bind_2 == {"two there one not exist": [ + '6.6.6.6:666', '7.7.7.7:777']}) - #test 3: two resolve, one is in rels key but not registered - config3 = {"two there one unregistered" : "{{alpha,bravo,unregistered}}"} - test_rels3 = ["testing_alpha.somedomain.com", "testing_bravo.somedomain.com", "unregistered.somedomain.com"] + # test 3: two resolve, one is in rels key but not registered + config3 = {"two there one unregistered": "{{alpha,bravo,unregistered}}"} + test_rels3 = ["testing_alpha.somedomain.com", + "testing_bravo.somedomain.com", "unregistered.somedomain.com"] test_bind_3 = client.resolve_override(config3, test_rels3) - assert(test_bind_3 == {"two there one unregistered" : ['6.6.6.6:666', '7.7.7.7:777']}) + assert(test_bind_3 == {"two there one unregistered": [ + '6.6.6.6:666', '7.7.7.7:777']}) + def test_dmaap(monkeypatch): - #test resolving dmaap key - config = {"TODAY IS YOUR LUCKY DAY" : "<<XXX>>"} - #does not match - test_bind = client.resolve_override(config, dmaap={"XX" : "ABSOLVEME"}) #XX != XXX - assert(test_bind == {"TODAY IS YOUR LUCKY DAY" : {}}) - #matches - test_bind_2 = client.resolve_override(config, dmaap={"XXX" : "ABSOLVEME"}) - assert(test_bind_2 == {"TODAY IS YOUR LUCKY DAY" : "ABSOLVEME"}) - -expected_config = { - "deep" : { - "ALL YOUR SERVICE BELONG TO US" : ['6.6.6.6:666', '7.7.7.7:777', '5.5.5.5:555', '5.5.5.5:555']}, - "doubledeep" : { - "sodeep" : {"hello" : "darkness"}} - } + # test resolving dmaap key + config = {"TODAY IS YOUR LUCKY DAY": "<<XXX>>"} + # does not match + test_bind = client.resolve_override( + config, dmaap={"XX": "ABSOLVEME"}) # XX != XXX + assert(test_bind == {"TODAY IS YOUR LUCKY DAY": {}}) + # matches + test_bind_2 = client.resolve_override(config, dmaap={"XXX": "ABSOLVEME"}) + assert(test_bind_2 == {"TODAY IS YOUR LUCKY DAY": "ABSOLVEME"}) + + +expected_config = {"deep": {"ALL YOUR SERVICE BELONG TO US": ['6.6.6.6:666', '7.7.7.7:777', '5.5.5.5:555', '5.5.5.5:555']}, + "doubledeep": {"sodeep": {"hello": "darkness"}}} + def test_both(monkeypatch): - #test rels and http - monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', monkeyed_get_connection_info_from_consul) - test_rels = ["testing_alpha.somedomain.com", "testing_bravo.somedomain.com", "testing_charlie.somedomain.com", "testing_charlie.somedomain.com"] - test_dmaap = {"WHO?" : "darkness"} - config = { - "deep" : { - "ALL YOUR SERVICE BELONG TO US" : "{{alpha,bravo,charlie}}"}, - "doubledeep" : { - "sodeep" : {"hello" : "<<WHO?>>"}} - } + # test rels and http + monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', + monkeyed_get_connection_info_from_consul) + test_rels = ["testing_alpha.somedomain.com", "testing_bravo.somedomain.com", + "testing_charlie.somedomain.com", "testing_charlie.somedomain.com"] + test_dmaap = {"WHO?": "darkness"} + config = {"deep": {"ALL YOUR SERVICE BELONG TO US": "{{alpha,bravo,charlie}}"}, + "doubledeep": {"sodeep": {"hello": "<<WHO?>>"}}} test_bind_1 = client.resolve_override(config, test_rels, test_dmaap) assert(test_bind_1 == expected_config) def test_resolve_all(monkeypatch): monkeypatch.setattr('requests.put', monkeyed_requests_put) - allk = client.resolve_all("test_service_component_name.unknown.unknown.unknown.dcae.onap.org") + allk = client.resolve_all( + "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") withstuff = {'config': {'my': 'amazing config'}, - 'dti': {'my': 'dti'}, - 'policies': {'items': [{'policyName': 'DCAE_alex.Config_MS_alex_microservice.132.xml', 'policyConfigMessage': 'Config Retrieved! ', 'responseAttributes': {}, 'policyConfigStatus': 'CONFIG_RETRIEVED', 'matchingConditions': {'ONAPName': 'DCAE', 'Name': 'DCAE', 'ConfigName': 'alex_config_name'}, 'config': {'policyScope': 'alex_policy_scope', 'configName': 'alex_config_name', 'description': 'test DCAE policy-handler', 'service': 'alex_service', 'policyName': 'alex_policy_name', 'riskLevel': '3', 'key1': 'value1', 'policy_hello': 'world!', 'content': {'foo': 'microservice3', 'foo_updated': '2018-01-30T13:25:33.222Z'}, 'riskType': '1712_ETE', 'guard': 'False', 'version': '0.0.1', 'location': 'Central', 'policy_updated_ts': '2018-02-19T15:09:55.217Z', 'updated_policy_id': 'DCAE_alex.Config_MS_alex_microservice', 'policy_updated_to_ver': '132', 'priority': '4', 'policy_updated_from_ver': '131', 'templateVersion': '2', 'uuid': '5e87d7c5-0daf-4b6b-ab92-5365cf5db1ef'}, 'property': None, 'type': 'JSON', 'policyVersion': '132'}, {'policyName': 'DCAE_alex.Config_db_client_policy_id_value.133.xml', 'policyConfigMessage': 'Config Retrieved! ', 'responseAttributes': {}, 'policyConfigStatus': 'CONFIG_RETRIEVED', 'matchingConditions': {'ONAPName': 'DCAE', 'Name': 'DCAE', 'ConfigName': 'alex_config_name'}, 'config': {'db_client_ts': '2017-11-21T12:12:13.696Z', 'db_client': 'ipsum', 'policy_hello': 'world!', 'policy_updated_from_ver': '132', 'updated_policy_id': 'DCAE_alex.Config_db_client_policy_id_value', 'policy_updated_ts': '2018-02-19T15:09:55.812Z', 'policy_updated_to_ver': '133'}, 'property': None, 'type': 'JSON', 'policyVersion': '133'}], 'event': {'action': 'gathered', 'timestamp': '2018-02-19 15:36:44.877380', 'update_id': 'bb73c20a-5ff8-450f-8223-da6720ade267', 'policies_count': 2}} - } + 'dti': {'my': 'dti'}, + 'policies': {'items': [{'policyName': 'DCAE_alex.Config_MS_alex_microservice.132.xml', 'policyConfigMessage': 'Config Retrieved! ', 'responseAttributes': {}, 'policyConfigStatus': 'CONFIG_RETRIEVED', 'matchingConditions': {'ONAPName': 'DCAE', 'Name': 'DCAE', 'ConfigName': 'alex_config_name'}, 'config': {'policyScope': 'alex_policy_scope', 'configName': 'alex_config_name', 'description': 'test DCAE policy-handler', 'service': 'alex_service', 'policyName': 'alex_policy_name', 'riskLevel': '3', 'key1': 'value1', 'policy_hello': 'world!', 'content': {'foo': 'microservice3', 'foo_updated': '2018-01-30T13:25:33.222Z'}, 'riskType': '1712_ETE', 'guard': 'False', 'version': '0.0.1', 'location': 'Central', 'policy_updated_ts': '2018-02-19T15:09:55.217Z', 'updated_policy_id': 'DCAE_alex.Config_MS_alex_microservice', 'policy_updated_to_ver': '132', 'priority': '4', 'policy_updated_from_ver': '131', 'templateVersion': '2', 'uuid': '5e87d7c5-0daf-4b6b-ab92-5365cf5db1ef'}, 'property': None, 'type': 'JSON', 'policyVersion': '132'}, {'policyName': 'DCAE_alex.Config_db_client_policy_id_value.133.xml', 'policyConfigMessage': 'Config Retrieved! ', 'responseAttributes': {}, 'policyConfigStatus': 'CONFIG_RETRIEVED', 'matchingConditions': {'ONAPName': 'DCAE', 'Name': 'DCAE', 'ConfigName': 'alex_config_name'}, 'config': {'db_client_ts': '2017-11-21T12:12:13.696Z', 'db_client': 'ipsum', 'policy_hello': 'world!', 'policy_updated_from_ver': '132', 'updated_policy_id': 'DCAE_alex.Config_db_client_policy_id_value', 'policy_updated_ts': '2018-02-19T15:09:55.812Z', 'policy_updated_to_ver': '133'}, 'property': None, 'type': 'JSON', 'policyVersion': '133'}], 'event': {'action': 'gathered', 'timestamp': '2018-02-19 15:36:44.877380', 'update_id': 'bb73c20a-5ff8-450f-8223-da6720ade267', 'policies_count': 2}}} assert allk == withstuff - monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', monkeyed_get_connection_info_from_consul) + monkeypatch.setattr('config_binding_service.client._get_connection_info_from_consul', + monkeyed_get_connection_info_from_consul) allk = client.resolve_all("test_resolve_scn") - print(allk) - assert allk == {"config" : expected_config} + assert allk == {"config": expected_config} - R = controller.bind_all("test_service_component_name.unknown.unknown.unknown.dcae.onap.org") + R = controller.bind_all( + "test_service_component_name.unknown.unknown.unknown.dcae.onap.org") assert(json.loads(R.data) == withstuff) assert(R.status_code == 200) R = controller.bind_all("test_resolve_scn") - assert(json.loads(R.data) == {"config" : expected_config}) + assert(json.loads(R.data) == {"config": expected_config}) assert(R.status_code == 200) R = controller.bind_all("scn_NOTexists") @@ -278,4 +315,3 @@ def test_resolve_all(monkeypatch): R = controller.bind_all("asdfasdf") assert(R.status_code == 500) - diff --git a/tox-local.ini b/tox-local.ini index 52b7916..8a309b1 100644 --- a/tox-local.ini +++ b/tox-local.ini @@ -1,6 +1,6 @@ # content of: tox.ini , put in same dir as setup.py [tox] -envlist = py36 +envlist = py36,flake8 [testenv] deps= @@ -12,3 +12,13 @@ setenv = HOSTNAME = config_binding_service commands= pytest --verbose --cov config_binding_service --cov-report=html + +[testenv:flake8] +basepython = python3.6 +skip_install = true +deps = flake8 +commands = flake8 setup.py config_binding_service tests + +[flake8] +ignore = E501,E265,E262,E261 + @@ -1,6 +1,6 @@ # content of: tox.ini , put in same dir as setup.py [tox] -envlist = py36 +envlist = py36,flake8 [testenv] deps= @@ -14,3 +14,13 @@ setenv = commands= pytest --junitxml xunit-results.xml --cov config_binding_service --cov-report xml coverage xml + +[testenv:flake8] +basepython = python3.6 +skip_install = true +deps = flake8 +commands = flake8 setup.py config_binding_service tests + +[flake8] +ignore = E501 + |