Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix failing tests related to object_provides index #518

Merged
merged 9 commits into from
Oct 19, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions news/518.internal
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Fixup tests because PloneSite gets IContentish again. @Akshat2Jain @jaroel
73 changes: 36 additions & 37 deletions src/plone/api/tests/test_content.py
Original file line number Diff line number Diff line change
@@ -1,19 +1,18 @@
"""Tests for plone.api.content."""

from Acquisition import aq_base
from OFS.CopySupport import CopyError
from OFS.event import ObjectWillBeMovedEvent
from OFS.interfaces import IObjectWillBeMovedEvent
from plone import api
from plone.api.content import _parse_object_provides_query
from plone.api.tests.base import INTEGRATION_TESTING
from plone.app.contenttypes.interfaces import IFolder
from plone.app.layout.navigation.interfaces import INavigationRoot
from plone.app.linkintegrity.exceptions import LinkIntegrityNotificationException
from plone.app.textfield import RichTextValue
from plone.indexer import indexer
from plone.uuid.interfaces import IMutableUUID
from plone.uuid.interfaces import IUUIDGenerator
from Products.CMFCore.interfaces import IContentish
from Products.CMFCore.WorkflowCore import WorkflowException
from Products.ZCatalog.interfaces import IZCatalog
from unittest import mock
Expand Down Expand Up @@ -209,8 +208,8 @@ def test_create_dexterity(self):
"""Test create dexterity."""
container = self.portal

# This section check for DX compatibilty. The custom DX types defined
# in plone.api are for Plone 4 compatiblity.
# This section check for DX compatibility. The custom DX types defined
# in plone.api are for Plone 4 compatibility.
Comment on lines +211 to +212
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I know it's not related to this PR but seeing "Plone 4" here made me see that this test and custom type can be removed. This branch is no longer compatible with Plone 4.

This can be done in another PR of course.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@wesleybl Feel free to do so after landing this.


# Create a folder
folder = api.content.create(
Expand Down Expand Up @@ -332,7 +331,7 @@ def test_create_raises_unicodedecodeerror(self):

# register a title indexer that will force a UnicodeDecodeError
# during content reindexing
@indexer(IContentish, IZCatalog)
@indexer(IFolder, IZCatalog)
def force_unicode_error(object):
raise UnicodeDecodeError(
"ascii",
Expand Down Expand Up @@ -446,7 +445,7 @@ def test_get_constraints(self):
api.content.get()

def test_get(self):
"""Test the getting of content in varios ways."""
"""Test the getting of content in various ways."""
# Test getting the about folder by path and UID
about_by_path = api.content.get("/about")
about_by_uid = api.content.get(UID=self.about.UID())
Expand Down Expand Up @@ -707,7 +706,7 @@ def test_copy(self):
container["about"]["our-team"] and container["about"]["our-team"] == ourteam
)

# When copying whithout target parameter should take source parent
# When copying without target parameter should take source parent
api.content.copy(source=self.team, id="our-team-no-target")
assert container["about"]["our-team-no-target"]

Expand Down Expand Up @@ -989,11 +988,11 @@ def test_find_depth(self):

def test_find_interface(self):
# Find documents by interface or it's identifier
identifier = IContentish.__identifier__
identifier = IFolder.__identifier__
brains = api.content.find(object_provides=identifier)
by_identifier = [x.getObject() for x in brains]

brains = api.content.find(object_provides=IContentish)
brains = api.content.find(object_provides=IFolder)
by_interface = [x.getObject() for x in brains]

self.assertEqual(by_identifier, by_interface)
Expand All @@ -1008,18 +1007,19 @@ def test_find_interface_dict(self):
brains = api.content.find(
object_provides={
"query": [
IContentish.__identifier__,
IFolder.__identifier__,
INavigationRoot.__identifier__,
],
"operator": "and",
},
)

self.assertEqual(len(brains), 1)

# plone.api query using interfaces
brains = api.content.find(
object_provides={
"query": [IContentish, INavigationRoot],
"query": [IFolder, INavigationRoot],
"operator": "and",
},
)
Expand All @@ -1029,19 +1029,18 @@ def test_find_interface_dict__include_not_query(self):
"""Check if not query in object_provides is functional."""

brains_all = api.content.find(
object_provides={"query": IContentish.__identifier__},
object_provides={"query": IFolder.__identifier__},
)

alsoProvides(self.portal.events, INavigationRoot)
self.portal.events.reindexObject(idxs=["object_provides"])

brains = api.content.find(
object_provides={
"query": IContentish.__identifier__,
"query": IFolder.__identifier__,
"not": INavigationRoot.__identifier__,
},
)

self.assertEqual(len(brains_all) - len(brains), 1)

def test_find_interface_dict__all_options(self):
Expand All @@ -1051,42 +1050,42 @@ def test_find_interface_dict__all_options(self):
parser = _parse_object_provides_query

self.assertDictEqual(
parser({"query": IContentish}),
{"query": [IContentish.__identifier__], "operator": "or"},
parser({"query": IFolder}),
{"query": [IFolder.__identifier__], "operator": "or"},
)

self.assertDictEqual(
parser(
{
"query": [IContentish, INavigationRoot.__identifier__],
"query": [IFolder, INavigationRoot.__identifier__],
"operator": "and",
},
),
{
"query": [IContentish.__identifier__, INavigationRoot.__identifier__],
"query": [IFolder.__identifier__, INavigationRoot.__identifier__],
"operator": "and",
},
)

self.assertDictEqual(
parser({"not": IContentish}),
{"not": [IContentish.__identifier__]},
parser({"not": IFolder}),
{"not": [IFolder.__identifier__]},
)

self.assertDictEqual(
parser({"not": [IContentish, INavigationRoot.__identifier__]}),
{"not": [IContentish.__identifier__, INavigationRoot.__identifier__]},
parser({"not": [IFolder, INavigationRoot.__identifier__]}),
{"not": [IFolder.__identifier__, INavigationRoot.__identifier__]},
)

self.assertDictEqual(
parser({"not": IContentish}),
{"not": [IContentish.__identifier__]},
parser({"not": IFolder}),
{"not": [IFolder.__identifier__]},
)

self.assertDictEqual(
parser({"query": IContentish, "operator": "and", "not": INavigationRoot}),
parser({"query": IFolder, "operator": "and", "not": INavigationRoot}),
{
"query": [IContentish.__identifier__],
"query": [IFolder.__identifier__],
"operator": "and",
"not": [INavigationRoot.__identifier__],
},
Expand Down Expand Up @@ -1133,38 +1132,38 @@ def test_find_parse_object_provides_query(self):

# single interface
self.assertDictEqual(
parse(IContentish),
parse(IFolder),
{
"query": [IContentish.__identifier__],
"query": [IFolder.__identifier__],
"operator": "or",
},
)
# single identifier
self.assertDictEqual(
parse(IContentish.__identifier__),
parse(IFolder.__identifier__),
{
"query": [IContentish.__identifier__],
"query": [IFolder.__identifier__],
"operator": "or",
},
)
# multiple interfaces/identifiers (mixed as list)
self.assertDictEqual(
parse([INavigationRoot, IContentish.__identifier__]),
parse([INavigationRoot, IFolder.__identifier__]),
{
"query": [
INavigationRoot.__identifier__,
IContentish.__identifier__,
IFolder.__identifier__,
],
"operator": "or",
},
)
# multiple interfaces/identifiers (mixed as tuple)
self.assertDictEqual(
parse((INavigationRoot, IContentish.__identifier__)),
parse((INavigationRoot, IFolder.__identifier__)),
{
"query": [
INavigationRoot.__identifier__,
IContentish.__identifier__,
IFolder.__identifier__,
],
"operator": "or",
},
Expand All @@ -1173,14 +1172,14 @@ def test_find_parse_object_provides_query(self):
self.assertDictEqual(
parse(
{
"query": [INavigationRoot, IContentish.__identifier__],
"query": [INavigationRoot, IFolder.__identifier__],
"operator": "and",
}
),
{
"query": [
INavigationRoot.__identifier__,
IContentish.__identifier__,
IFolder.__identifier__,
],
"operator": "and",
},
Expand Down Expand Up @@ -1283,7 +1282,7 @@ def test_transition(self):
"internally_published",
)

def test_diable_roles_acquisition(self):
def test_disable_roles_acquisition(self):
"""Test disabling local roles acquisition."""
# This should fail because an content item is mandatory
from plone.api.exc import MissingParameterError
Expand Down