Skip to content

Commit a6e3ce5

Browse files
Merge pull request #39 from andreroggeri/master
Allow mapping to be deleted by metadata
2 parents 9bbec90 + 4bfcd1a commit a6e3ce5

File tree

2 files changed

+25
-1
lines changed

2 files changed

+25
-1
lines changed

wiremock/resources/mappings/resource.py

+10
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,10 @@ def endpoint(cls):
1212
def endpoint_single(cls):
1313
return "/mappings/{id}"
1414

15+
@classmethod
16+
def endpoint_delete_by_metadata(cls):
17+
return "/mappings/remove-by-metadata"
18+
1519
@classmethod
1620
def entity_class(cls):
1721
return MappingResponse
@@ -72,5 +76,11 @@ def delete_mapping(cls, mapping_id, parameters={}):
7276
response = cls.REST_CLIENT.delete(cls.get_base_uri(cls.endpoint_single(), **ids), headers=make_headers(), params=parameters)
7377
return cls.REST_CLIENT.handle_response(response)
7478

79+
@classmethod
80+
def delete_mapping_by_metadata(cls, metadata, parameters={}):
81+
response = cls.REST_CLIENT.post(cls.get_base_uri(cls.endpoint_delete_by_metadata()), headers=make_headers(), params=parameters, json=metadata)
82+
83+
return cls.REST_CLIENT.handle_response(response)
84+
7585

7686
__all__ = ["Mappings"]

wiremock/tests/resource_tests/mappings_tests/resource_tests.py

+15-1
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ def test_create_mapping(self):
2222
@attr("unit", "mappings", "resource")
2323
@responses.activate
2424
def test_retrieve_all_mappings(self):
25-
e = AllMappings(mappings=[Mapping(id="1234-5678", priority=1),], meta=MappingMeta(total=1))
25+
e = AllMappings(mappings=[Mapping(id="1234-5678", priority=1), ], meta=MappingMeta(total=1))
2626
resp = e.get_json_data()
2727
responses.add(responses.GET, "http://localhost/__admin/mappings", json=resp, status=200)
2828

@@ -87,3 +87,17 @@ def test_delete_mapping(self):
8787

8888
r = Mappings.delete_mapping(e)
8989
self.assertEquals(200, r.status_code)
90+
91+
@attr("unit", "mappings", "resource")
92+
@responses.activate
93+
def test_delete_mapping_by_metadata(self):
94+
responses.add(responses.POST, "http://localhost/__admin/mappings/remove-by-metadata", body='{}', status=200)
95+
96+
r = Mappings.delete_mapping_by_metadata({
97+
"matchesJsonPath": {
98+
"expression": "$.some.key",
99+
"equalTo": "SomeValue"
100+
}
101+
})
102+
103+
self.assertEquals(200, r.status_code)

0 commit comments

Comments
 (0)