diff --git a/src/plone/restapi/tests/test_batching.py b/src/plone/restapi/tests/test_batching.py index 810846298c..17339a132c 100644 --- a/src/plone/restapi/tests/test_batching.py +++ b/src/plone/restapi/tests/test_batching.py @@ -455,7 +455,8 @@ def test_first_link_contained(self): self.request.form["b_size"] = 10 batch = HypermediaBatch(self.request, items) - self.assertDictContainsSubset({"first": "http://nohost?b_start=0"}, batch.links) + expected = {"first": "http://nohost?b_start=0"} + self.assertEqual(batch.links, {**batch_links, **expected}) def test_first_link_preserves_list_like_querystring_params(self): items = list(range(1, 26)) @@ -478,14 +479,16 @@ def test_last_link_contained(self): self.request.form["b_size"] = 10 batch = HypermediaBatch(self.request, items) - self.assertDictContainsSubset({"last": "http://nohost?b_start=20"}, batch.links) + expected = {"last": "http://nohost?b_start=20"} + self.assertEqual(batch.links, {**batch_links, **expected}) def test_next_link_contained_if_necessary(self): items = list(range(1, 26)) self.request.form["b_size"] = 10 batch = HypermediaBatch(self.request, items) - self.assertDictContainsSubset({"next": "http://nohost?b_start=10"}, batch.links) + expected = {"next": "http://nohost?b_start=10"} + self.assertEqual(batch.links, {**batch_links, **expected}) def test_next_link_omitted_on_last_page(self): items = list(range(1, 26)) @@ -503,7 +506,8 @@ def test_prev_link_contained_if_necessary(self): self.request.form["b_size"] = 10 self.request.form["b_start"] = 20 batch = HypermediaBatch(self.request, items) - self.assertDictContainsSubset({"prev": "http://nohost?b_start=10"}, batch.links) + expected = {"prev": "http://nohost?b_start=10"} + self.assertEqual(batch.links, {**batch_links, **expected}) def test_prev_link_omitted_on_first_page(self): items = list(range(1, 26)) diff --git a/src/plone/restapi/tests/test_permissions.py b/src/plone/restapi/tests/test_permissions.py index 917ab4a588..dc4e205473 100644 --- a/src/plone/restapi/tests/test_permissions.py +++ b/src/plone/restapi/tests/test_permissions.py @@ -55,10 +55,9 @@ def test_unauthorized_if_missing_permission(self): response = self.api_session.get(self.portal_url) self.assertEqual(response.status_code, 401) - self.assertDictContainsSubset( - { - "type": "Unauthorized", - "message": "Missing 'plone.restapi: Use REST API' permission", - }, - response.json(), - ) + expected = { + "type": "Unauthorized", + "message": "Missing 'plone.restapi: Use REST API' permission", + } + data = response.json() + self.assertEqual(data, {**data, **expected}) diff --git a/src/plone/restapi/tests/test_search.py b/src/plone/restapi/tests/test_search.py index 2f66ecdba9..376f9dc82c 100644 --- a/src/plone/restapi/tests/test_search.py +++ b/src/plone/restapi/tests/test_search.py @@ -247,15 +247,14 @@ def test_partial_metadata_retrieval(self): } response = self.api_session.get("/@search", params=query) - self.assertDictContainsSubset( - { - "@id": self.portal_url + "/folder/doc", - "title": "Lorem Ipsum", - "portal_type": "DXTestDocument", - "review_state": "private", - }, - response.json()["items"][0], - ) + expected = { + "@id": self.portal_url + "/folder/doc", + "title": "Lorem Ipsum", + "portal_type": "DXTestDocument", + "review_state": "private", + } + item = response.json()["items"][0] + self.assertEqual(item, {**item, **expected}) def test_full_metadata_retrieval(self): query = {"SearchableText": "lorem", "metadata_fields": "_all"} diff --git a/src/plone/restapi/tests/test_serializer_catalog.py b/src/plone/restapi/tests/test_serializer_catalog.py index 453680f02c..61bd27e70f 100644 --- a/src/plone/restapi/tests/test_serializer_catalog.py +++ b/src/plone/restapi/tests/test_serializer_catalog.py @@ -55,8 +55,10 @@ def test_lazy_map_serialization(self): lazy_map = self.catalog() results = getMultiAdapter((lazy_map, self.request), ISerializeToJson)() - self.assertDictContainsSubset({"@id": "http://nohost"}, results) - self.assertDictContainsSubset({"items_total": 3}, results) + expected = {"@id": "http://nohost"} + self.assertEqual(results, {**results, **expected}) + expected = {"items_total": 3} + self.assertEqual(results, {**results, **expected}) self.assertEqual(3, len(results["items"])) @unittest.skipIf(HAS_PLONE_6, "... before it was not") @@ -65,8 +67,10 @@ def test_lazy_map_serialization_plone5(self): lazy_map = self.catalog() results = getMultiAdapter((lazy_map, self.request), ISerializeToJson)() - self.assertDictContainsSubset({"@id": "http://nohost"}, results) - self.assertDictContainsSubset({"items_total": 2}, results) + expected = {"@id": "http://nohost"} + self.assertEqual(results, {**results, **expected}) + expected = {"items_total": 2} + self.assertEqual(results, {**results, **expected}) self.assertEqual(2, len(results["items"])) def test_lazy_map_serialization_with_fullobjects(self): @@ -76,45 +80,45 @@ def test_lazy_map_serialization_with_fullobjects(self): fullobjects=True ) - self.assertDictContainsSubset({"@id": "http://nohost"}, results) - self.assertDictContainsSubset({"items_total": 1}, results) + expected = {"@id": "http://nohost"} + self.assertEqual(results, {**results, **expected}) + expected = {"items_total": 1} + self.assertEqual(results, {**results, **expected}) self.assertEqual(1, len(results["items"])) result_item = results["items"][0] - self.assertDictContainsSubset( - { - "@id": "http://nohost/plone/my-folder/my-document", - "@type": "Document", - "changeNote": "", - "contributors": [], - "creators": ["test_user_1_"], + expected = { + "@id": "http://nohost/plone/my-folder/my-document", + "@type": "Document", + "changeNote": "", + "contributors": [], + "creators": ["test_user_1_"], + "description": "", + "effective": None, + "exclude_from_nav": False, + "expires": None, + "id": "my-document", + "is_folderish": False, + "language": "", + "layout": "document_view", + "parent": { + "@id": "http://nohost/plone/my-folder", + "@type": "Folder", + "type_title": "Folder", "description": "", - "effective": None, - "exclude_from_nav": False, - "expires": None, - "id": "my-document", - "is_folderish": False, - "language": "", - "layout": "document_view", - "parent": { - "@id": "http://nohost/plone/my-folder", - "@type": "Folder", - "type_title": "Folder", - "description": "", - "review_state": "private", - "title": "My Folder", - }, - "relatedItems": [], "review_state": "private", - "rights": "", - "subjects": [], - "table_of_contents": None, - "text": None, - "title": "My Document", - "version": "current", + "title": "My Folder", }, - result_item, - ) + "relatedItems": [], + "review_state": "private", + "rights": "", + "subjects": [], + "table_of_contents": None, + "text": None, + "title": "My Document", + "version": "current", + } + self.assertEqual(result_item, {**result_item, **expected}) def test_brain_summary_representation(self): lazy_map = self.catalog(path="/plone/my-folder/my-document") diff --git a/src/plone/restapi/tests/test_services.py b/src/plone/restapi/tests/test_services.py index dac51df7ca..ddd63a22fa 100644 --- a/src/plone/restapi/tests/test_services.py +++ b/src/plone/restapi/tests/test_services.py @@ -111,10 +111,9 @@ def test_get_news_item(self): self.assertEqual( "This is an image caption.", response.json()["image_caption"] ) - self.assertDictContainsSubset( - {"download": self.portal_url + f"/news1/@@images/{scale_url_uuid}.png"}, - response.json()["image"], - ) + expected = {"download": self.portal_url + f"/news1/@@images/{scale_url_uuid}.png"} + data = response.json()["image"] + self.assertEqual(data, {**data, **expected}) def test_get_folder(self): self.portal.invokeFactory("Folder", id="folder1", title="My Folder") diff --git a/src/plone/restapi/tests/test_services_querystring.py b/src/plone/restapi/tests/test_services_querystring.py index 1203ab6336..258ebb7bc1 100644 --- a/src/plone/restapi/tests/test_services_querystring.py +++ b/src/plone/restapi/tests/test_services_querystring.py @@ -80,13 +80,11 @@ def test_endpoint_inlines_vocabularies(self): indexes = response.json()["indexes"] idx = indexes["review_state"] - self.assertDictContainsSubset( - { - "title": "Review state", - "vocabulary": "plone.app.vocabularies.WorkflowStates", - }, - idx, - ) + expected = { + "title": "Review state", + "vocabulary": "plone.app.vocabularies.WorkflowStates", + } + sef.assertEqual(idx, {**idx, **expected}) expected_vocab_values = { "external": {"title": "Externally visible [external]"}, @@ -110,16 +108,14 @@ def test_endpoint_inlines_operators(self): indexes = response.json()["indexes"] idx = indexes["isDefaultPage"] - self.assertDictContainsSubset( - { - "title": "Default Page", - "operations": [ - "plone.app.querystring.operation.boolean.isTrue", - "plone.app.querystring.operation.boolean.isFalse", - ], - }, - idx, - ) + expected = { + "title": "Default Page", + "operations": [ + "plone.app.querystring.operation.boolean.isTrue", + "plone.app.querystring.operation.boolean.isFalse", + ], + } + sef.assertEqual(idx, {**idx, **expected}) expected_operators = { "plone.app.querystring.operation.boolean.isFalse": { @@ -144,17 +140,15 @@ def test_endpoint_includes_widgets_for_operators(self): indexes = response.json()["indexes"] idx = indexes["getObjPositionInParent"] - self.assertDictContainsSubset( - { - "title": "Order in folder", - "operations": [ - "plone.app.querystring.operation.int.is", - "plone.app.querystring.operation.int.lessThan", - "plone.app.querystring.operation.int.largerThan", - ], - }, - idx, - ) + expected = { + "title": "Order in folder", + "operations": [ + "plone.app.querystring.operation.int.is", + "plone.app.querystring.operation.int.lessThan", + "plone.app.querystring.operation.int.largerThan", + ], + } + sef.assertEqual(idx, {**idx, **expected}) ops = idx["operators"]