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

Slots #1063

Open
wants to merge 118 commits into
base: main
Choose a base branch
from
Open

Slots #1063

Changes from 1 commit
Commits
Show all changes
118 commits
Select commit Hold shift + click to select a range
24b3649
WIP
tiberiuichim Feb 4, 2021
8aeec3c
Add slot_block_ids index
tiberiuichim Feb 4, 2021
0302833
Improve patch service
tiberiuichim Feb 4, 2021
85b9fa7
WIP on deserializers
tiberiuichim Feb 4, 2021
3bf47f6
WIP on deserializers
tiberiuichim Feb 4, 2021
f17d4d1
WIP
tiberiuichim Feb 5, 2021
98e009d
Add slots engine unittest
tiberiuichim Feb 6, 2021
34bc973
Improve test formatting
tiberiuichim Feb 6, 2021
8401e0c
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Feb 6, 2021
02223e0
More tests on slot engine crutch
tiberiuichim Feb 6, 2021
68d534c
Add VolatileSmartField
tiberiuichim Feb 6, 2021
901e3a0
WIP
tiberiuichim Feb 6, 2021
09630a2
Add another way of treating reordered slot fills
tiberiuichim Feb 7, 2021
48f3865
Add save_data_to_slot to slot engine
tiberiuichim Feb 7, 2021
ef71439
Move SlotsEngine to .slots, tweak names
tiberiuichim Feb 7, 2021
3af5692
Rename ISlotsStorage -> ISlotStorage
tiberiuichim Feb 7, 2021
4a479be
Move zca registrations to slots.zcml; more tests
tiberiuichim Feb 8, 2021
44747ad
More tests
tiberiuichim Feb 8, 2021
3b1540c
Add discovery of slots, add slot storage serializer
tiberiuichim Feb 8, 2021
6fd2006
Add initial test of slot service
tiberiuichim Feb 8, 2021
9b087c5
Fix slot serialization service
tiberiuichim Feb 8, 2021
6ee8e76
Fix slot serializer
tiberiuichim Feb 8, 2021
870881d
Add configlet and control panel for content slots
tiberiuichim Feb 8, 2021
62676e4
Shuffle events code
tiberiuichim Feb 9, 2021
65f02ff
Add get_editable_slots implementation
tiberiuichim Feb 9, 2021
a8a0d98
Pass editable status in @slots endpoints
tiberiuichim Feb 9, 2021
53953af
Fix tests
tiberiuichim Feb 9, 2021
58ccfbc
Fix tests
tiberiuichim Feb 9, 2021
ffa86ba
Add security tests
tiberiuichim Feb 9, 2021
84b5779
Add security tests
tiberiuichim Feb 9, 2021
f56b43a
WIP on deserializer
tiberiuichim Feb 10, 2021
6e27022
Rename slot_blocks -> blocks, slot_blocks_layout -> blocks_layout, as…
tiberiuichim Feb 10, 2021
895f5ad
Visual formatting
tiberiuichim Feb 10, 2021
15305b3
Visual formatting
tiberiuichim Feb 10, 2021
cdc54c3
Move interfaces to .slots package
tiberiuichim Feb 10, 2021
b4693a3
Separate deserializer test
tiberiuichim Feb 10, 2021
15809aa
Fix deserializer
tiberiuichim Feb 10, 2021
3505931
Fix deserializer
tiberiuichim Feb 10, 2021
b70875e
Fix deserializer
tiberiuichim Feb 10, 2021
e23c68d
Add another test
tiberiuichim Feb 10, 2021
afae726
Fix indexing, test remove of block from child layout
tiberiuichim Feb 10, 2021
42f007d
Fix indexing, test remove of block from child layout
tiberiuichim Feb 10, 2021
6344b64
WIP on deserializers
tiberiuichim Feb 10, 2021
ee327f3
Fix deserializer + tests
tiberiuichim Feb 11, 2021
fb0e637
Fix tests; don't use an index to keep block sanity, instead resolve i…
tiberiuichim Feb 11, 2021
03c1962
Remove block removed events and associated catalog index, they're not…
tiberiuichim Feb 11, 2021
cd90fba
Run black
tiberiuichim Feb 11, 2021
a28ea4e
Fix slot
tiberiuichim Feb 12, 2021
790d571
Simplify test content creation
tiberiuichim Feb 12, 2021
bea4d76
Add skip csrf protection
tiberiuichim Feb 14, 2021
1922a9d
Use edit status in serializer
tiberiuichim Feb 14, 2021
dd20be7
Use edit status in serializer
tiberiuichim Feb 14, 2021
063f4d3
Fix deserializer, don't trigger ObjectModifiedEvent, as it needs its …
tiberiuichim Feb 15, 2021
24be48d
Fix block transformer for slots
tiberiuichim Feb 16, 2021
14fbd04
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Mar 8, 2021
216f867
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Mar 19, 2021
d420b87
Run black
tiberiuichim Mar 19, 2021
8cfc7e2
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Mar 29, 2021
c3ae3db
Add can_manage_slots info to response
tiberiuichim Mar 29, 2021
923f7ad
Fix a bug in deleting slot fills
tiberiuichim Mar 29, 2021
495380e
Fix another delete
tiberiuichim Mar 30, 2021
08cd548
Merge master
tiberiuichim May 25, 2021
b54a298
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Jun 7, 2021
49fce60
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Jul 2, 2021
2ee8de7
Add transaction doom
tiberiuichim Jul 2, 2021
fc8d000
Add full parameter
tiberiuichim Jul 2, 2021
28cab5d
Fix deserializer
tiberiuichim Jul 2, 2021
e00ed37
Add block parent
tiberiuichim Jul 2, 2021
401a7ea
Fix parameters
tiberiuichim Jul 2, 2021
d6583c0
Improve block_parent implementation
tiberiuichim Jul 2, 2021
e6bd47b
Pass blocks when full is true
tiberiuichim Jul 2, 2021
cfae76c
Add info about attributes
tiberiuichim Jul 5, 2021
f2cdd56
Fix _v_ handling; send a _v_original to the frontend
tiberiuichim Jul 6, 2021
df11630
WIP
tiberiuichim Jul 6, 2021
8ea93d8
Add test for block hiding
tiberiuichim Jul 8, 2021
30c2f99
Fix sameAs handling
tiberiuichim Jul 8, 2021
527c621
Fix some tests
tiberiuichim Jul 8, 2021
00f5159
More tests, enable the _v_original as it's needed in frontend when 'u…
tiberiuichim Jul 8, 2021
4061471
Fix some tests, run black
tiberiuichim Jul 8, 2021
33a0d8f
Fix deserializer test
tiberiuichim Jul 8, 2021
4ac03ea
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Jul 8, 2021
3c6cfa4
Fix serializer test
tiberiuichim Jul 8, 2021
4964317
Fix one test in test_addons
tiberiuichim Jul 8, 2021
f729ae0
Add upgrade handler
tiberiuichim Jul 8, 2021
8fb791d
Remove unused import
tiberiuichim Jul 8, 2021
4ce5fde
Fix _v_ handling
tiberiuichim Jul 10, 2021
8aea2f9
Fix deserializing when showing a hidden parent
tiberiuichim Jul 10, 2021
fa3c80f
Fix parent if None
tiberiuichim Jul 10, 2021
222043b
Run black, localize test urls
tiberiuichim Jul 10, 2021
ecf0788
Add some test descriptions
tiberiuichim Jul 11, 2021
d8eaaae
Add a test for third-hand inherited slots
tiberiuichim Jul 11, 2021
211420e
Make the test more clear
tiberiuichim Jul 11, 2021
1bfe28f
WIP on test
tiberiuichim Jul 11, 2021
79eb618
Fix deep inheritance test
tiberiuichim Jul 12, 2021
9eb4403
Don't include _v_inherit everywhere; don't fail on deleted inherited …
tiberiuichim Jul 12, 2021
66e7687
WIP on new traversal for slots
tiberiuichim Jul 28, 2021
493f345
Add missing file
tiberiuichim Jul 28, 2021
c5723f6
WIP on new traversal for slots
tiberiuichim Jul 28, 2021
59c3644
Adjust tests for new slots serialized ids
tiberiuichim Jul 29, 2021
f77f5a4
Run zpretty
tiberiuichim Jul 29, 2021
b484298
Run black
tiberiuichim Jul 29, 2021
72aa841
Remove print statement
tiberiuichim Jul 29, 2021
1d524f3
Merge pull request #1187 from plone/slots_traversing
tiberiuichim Jul 29, 2021
6eabb69
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Jul 29, 2021
16839b3
Pass expanders in @slots endpoint
tiberiuichim Jul 29, 2021
29a5a63
Run black
tiberiuichim Jul 31, 2021
7800daa
Fix tests
tiberiuichim Jul 31, 2021
e4aa1e3
Merge master
tiberiuichim Oct 17, 2021
378e5a1
Pass readOnly
tiberiuichim Oct 26, 2021
0e34a87
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Nov 3, 2021
7695215
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Nov 11, 2021
850cf31
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Nov 27, 2021
544f614
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Mar 5, 2022
79f72da
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim May 17, 2022
9b93908
Merge branch 'master' into slots
tiberiuichim Jul 23, 2022
3f6cf2a
Merge remote-tracking branch 'origin/master' into slots
tiberiuichim Aug 2, 2022
be413c1
Merge from 'master'
laszlocseh Jul 27, 2023
af48f1f
Merge remote-tracking branch 'origin/main' into slots
tiberiuichim Oct 11, 2023
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
Prev Previous commit
Next Next commit
Fix tests; don't use an index to keep block sanity, instead resolve i…
…t on serialization and deserialization
  • Loading branch information
tiberiuichim committed Feb 11, 2021

Verified

This commit was signed with the committer’s verified signature.
commit fb0e63770e74cc98c340fd0a169e37270e1d7d37
7 changes: 5 additions & 2 deletions src/plone/restapi/deserializer/slots.py
Original file line number Diff line number Diff line change
@@ -50,10 +50,13 @@ def __call__(self, data=None):
if not ((k in parent_block_ids) or (k in incoming_blocks.keys())):
del self.slot.blocks[k]

# don't store blocks that are inherited
inherited = []
# don't store blocks that are inherited, keep only those that really exist
for k, v in incoming_blocks.items():
if v.get('_v_inherit'):
del incoming_blocks[k]
if k in parent_block_ids:
inherited.append(k)

for id, block_value in incoming_blocks.items():
block_type = block_value.get("@type", "")
@@ -75,7 +78,7 @@ def __call__(self, data=None):
self.slot.blocks = incoming_blocks

# don't keep block ids in layout if they're nowhere in the inheritance tree
all_ids = parent_block_ids + list(self.slot.blocks.keys())
all_ids = parent_block_ids + list(self.slot.blocks.keys()) + inherited
layout = [b for b in data['blocks_layout']['items'] if b in all_ids]
data['blocks_layout']['items'] = layout
self.slot.blocks_layout = data['blocks_layout']
9 changes: 5 additions & 4 deletions src/plone/restapi/slots/__init__.py
Original file line number Diff line number Diff line change
@@ -100,7 +100,7 @@ def get_blocks(self, name):
blocks_layout = []

_replaced = set()
_blockmap = {}
_seen_blocks = {}

stack = self.get_fills_stack(name)

@@ -112,7 +112,7 @@ def get_blocks(self, name):

for uid, block in slot.blocks.items():
block = deepcopy(block)
_blockmap[uid] = block
_seen_blocks[uid] = block

if not (uid in blocks or uid in _replaced):
other = block.get('s:isVariantOf') or block.get('s:sameAs')
@@ -132,11 +132,12 @@ def get_blocks(self, name):
for k, v in blocks.items():
if v.get('s:sameAs'):
v['_v_inherit'] = True
v.update(self._resolve_block(v, _blockmap))
v.update(self._resolve_block(v, _seen_blocks))

return {
'blocks': blocks,
'blocks_layout': {'items': blocks_layout}
'blocks_layout': {'items': [b for b in blocks_layout
if b in _seen_blocks.keys()]}
}

def _resolve_block(self, block, blocks):
120 changes: 65 additions & 55 deletions src/plone/restapi/tests/test_deserializer_slots.py
Original file line number Diff line number Diff line change
@@ -3,6 +3,7 @@
from plone.dexterity.utils import createContentInContainer
from plone.restapi.interfaces import IDeserializeFromJson
from plone.restapi.slots import Slot
from plone.restapi.slots.interfaces import ISlots
from plone.restapi.slots.interfaces import ISlotStorage
from plone.restapi.testing import PLONE_RESTAPI_DX_INTEGRATION_TESTING
from Products.CMFPlone.tests.PloneTestCase import PloneTestCase
@@ -55,48 +56,48 @@ def test_deserialize_put_some(self):

deserializer({
"left": {
'blocks_layout': {'items': [3, 2, 5, 4]},
'blocks_layout': {'items': [u'3', u'2', u'5', u'4']},
'blocks': {
2: {'title': 'Second', 's:isVariantOf': 1},
3: {'title': 'Third', '_v_inherit': True},
5: {'title': 'Fifth', '_v_inherit': True},
u'2': {'title': 'Second', 's:isVariantOf': u'1'},
u'3': {'title': 'Third', '_v_inherit': True},
u'5': {'title': 'Fifth', '_v_inherit': True},
},
},
"right": {
'blocks_layout': {'items': [6, 7]},
'blocks_layout': {'items': [u'6', u'7']},
'blocks': {
6: {'title': 'Sixth'},
u'6': {'title': 'Sixth'},
}
}
})

self.assertEqual(list(storage.keys()), ['left', 'right'])
self.assertEqual(storage['left'].blocks,
{2: {'title': 'Second', 's:isVariantOf': 1}, })
self.assertEqual(storage['left'].blocks_layout, {"items": [2]})
{u'2': {'title': 'Second', 's:isVariantOf': u'1'}, })
self.assertEqual(storage['left'].blocks_layout, {"items": [u'2']})

self.assertEqual(storage['right'].blocks,
{6: {'title': 'Sixth'}, })
self.assertEqual(storage['right'].blocks_layout, {"items": [6, 7]})
{u'6': {'title': 'Sixth'}, })
self.assertEqual(storage['right'].blocks_layout, {"items": [u'6']})

def test_delete_all_with_dict(self):
storage = ISlotStorage(self.doc)

storage['left'] = Slot(**({
'blocks': {
1: {'title': 'First'},
3: {'title': 'Third'},
5: {'title': 'Fifth'},
u'1': {'title': 'First'},
u'3': {'title': 'Third'},
u'5': {'title': 'Fifth'},
},
'blocks_layout': {'items': [5, 1, 3]}
'blocks_layout': {'items': [u'5', u'1', u'3']}
}))
storage['right'] = Slot(**({
'blocks': {
6: {'title': 'First'},
7: {'title': 'Third'},
8: {'title': 'Fifth'},
u'6': {'title': 'First'},
u'7': {'title': 'Third'},
u'8': {'title': 'Fifth'},
},
'blocks_layout': {'items': [8, 6, 7]}
'blocks_layout': {'items': [u'8', u'6', u'7']}
}))

deserializer = getMultiAdapter(
@@ -112,19 +113,19 @@ def test_delete_all_with_empty(self):

storage['left'] = Slot(**({
'blocks': {
1: {'title': 'First'},
3: {'title': 'Third'},
5: {'title': 'Fifth'},
u'1': {'title': 'First'},
u'3': {'title': 'Third'},
u'5': {'title': 'Fifth'},
},
'blocks_layout': {'items': [5, 1, 3]}
'blocks_layout': {'items': [u'5', u'1', u'3']}
}))
storage['right'] = Slot(**({
'blocks': {
6: {'title': 'First'},
7: {'title': 'Third'},
8: {'title': 'Fifth'},
u'6': {'title': 'First'},
u'7': {'title': 'Third'},
u'8': {'title': 'Fifth'},
},
'blocks_layout': {'items': [8, 6, 7]}
'blocks_layout': {'items': [u'8', u'6', u'7']}
}))

deserializer = getMultiAdapter(
@@ -141,31 +142,31 @@ def test_delete_and_save(self):

storage['left'] = Slot(**({
'blocks': {
1: {'title': 'First'},
3: {'title': 'Third'},
5: {'title': 'Fifth'},
u'1': {'title': 'First'},
u'3': {'title': 'Third'},
u'5': {'title': 'Fifth'},
},
'blocks_layout': {'items': [5, 1, 3]}
'blocks_layout': {'items': [u'5', u'1', u'3']}
}))
storage['right'] = Slot(**({
'blocks': {
6: {'title': 'First'},
7: {'title': 'Third'},
8: {'title': 'Fifth'},
u'6': {'title': 'First'},
u'7': {'title': 'Third'},
u'8': {'title': 'Fifth'},
},
'blocks_layout': {'items': [8, 6, 7]}
'blocks_layout': {'items': [u'8', u'6', u'7']}
}))

deserializer = getMultiAdapter(
(self.doc, storage, self.request), IDeserializeFromJson)

deserializer({
"left": {
'blocks_layout': {'items': [3, 2, 5, 4]},
'blocks_layout': {'items': [u'3', u'2', u'5', u'4']},
'blocks': {
2: {'title': 'Second', 's:isVariantOf': 1},
3: {'title': 'Third', '_v_inherit': True},
5: {'title': 'Fifth', '_v_inherit': True},
u'2': {'title': 'Second', 's:isVariantOf': u'1'},
u'3': {'title': 'Third', '_v_inherit': True},
u'5': {'title': 'Fifth', '_v_inherit': True},
},
},
})
@@ -175,40 +176,49 @@ def test_delete_and_save(self):
self.assertEqual(right.blocks_layout, {"items": []})

left = storage['left']
self.assertEqual(left.blocks, {2: {'s:isVariantOf': 1, 'title': 'Second'}})
self.assertEqual(left.blocks_layout, {'items': [3, 2, 5, 4]})
self.assertEqual(
left.blocks, {u'2': {'s:isVariantOf': u'1', 'title': 'Second'}})
self.assertEqual(left.blocks_layout, {'items': [u'2']})

def test_delete_in_parent_affects_child(self):
docstorage = ISlotStorage(self.doc)

docstorage['left'] = Slot(**({
rootstorage = ISlotStorage(self.portal)
rootstorage['left'] = Slot(**({
'blocks': {
1: {'title': 'First'},
u'3': {'title': 'Third'},
u'5': {'title': 'Fifth'},
},
'blocks_layout': {'items': [5, 1, 3]}
'blocks_layout': {'items': [u'5', u'3']}
}))

rootstorage = ISlotStorage(self.portal)
rootstorage['left'] = Slot(**({
docstorage = ISlotStorage(self.doc)

docstorage['left'] = Slot(**({
'blocks': {
3: {'title': 'Third'},
5: {'title': 'Fifth'},
u'1': {'title': 'First'},
# u'5': {'_v_inherit': True},
},
'blocks_layout': {'items': [5, 3]}
'blocks_layout': {'items': [u'5', u'1', u'3']}
}))

self.portal.portal_catalog.indexObject(self.doc)
# self.portal.portal_catalog.indexObject(self.doc)

deserializer = getMultiAdapter(
(self.doc, rootstorage, self.request), IDeserializeFromJson)
(self.portal, rootstorage, self.request), IDeserializeFromJson)

deserializer({
"left": {
'blocks_layout': {'items': [3]},
'blocks_layout': {'items': [u'3']},
'blocks': {
3: {'title': 'Third', },
u'3': {'title': 'Third', },
},
},
})

self.assertEqual(docstorage['left'].blocks_layout['items'], [1, 3])
self.assertEqual(rootstorage['left'].blocks,
{u'3': {'title': 'Third', }, })
self.assertEqual(rootstorage['left'].blocks_layout,
{'items': [u'3']})

engine = ISlots(self.doc)
self.assertEqual(engine.get_blocks('left')['blocks_layout']['items'],
[u'1', u'3'])