Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
erp5
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Léo-Paul Géneau
erp5
Commits
bf447559
Commit
bf447559
authored
Nov 27, 2023
by
Rafael Monnerat
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
erp5_web: Write tests for caching policy configuration
parent
fb869e0a
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
400 additions
and
8 deletions
+400
-8
bt5/erp5_web/TestTemplateItem/portal_components/test.erp5.testERP5Web.py
...stTemplateItem/portal_components/test.erp5.testERP5Web.py
+400
-8
No files found.
bt5/erp5_web/TestTemplateItem/portal_components/test.erp5.testERP5Web.py
View file @
bf447559
...
...
@@ -252,8 +252,6 @@ class TestERP5Web(ERP5TypeTestCase):
except
Exception
:
self
.
fail
(
'Cataloging of the Web Site failed.'
)
def
test_02_EditSimpleWebPage
(
self
):
"""
Simple Case of creating a web page.
...
...
@@ -1257,9 +1255,8 @@ Hé Hé Hé!""", page.asText().strip())
def
test_15_Check_LastModified_Header
(
self
):
"""Checks that Last-Modified header set by caching policy manager
is correctly filled with getModificationDate of content.
This test check
2
Policy installed by erp5_web:
This test check
1
Policy installed by erp5_web:
Policy ID - unauthenticated web pages
authenticated
"""
website
=
self
.
setupWebSite
()
web_section_portal_type
=
'Web Section'
...
...
@@ -1285,15 +1282,52 @@ Hé Hé Hé!""", page.asText().strip())
modification_date
=
rfc1123_date
(
document
.
getModificationDate
())
self
.
assertEqual
(
modification_date
,
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=600, stale-while-revalidate=360000, public'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
'Cookie, Authorization'
)
def
test_15a_Check_LastModified_Header_authenticated
(
self
):
"""Checks that Last-Modified header is NOT set by caching policy manager
This test check 1 Policy installed by erp5_web:
Policy ID - authenticated
"""
website
=
self
.
setupWebSite
()
web_section_portal_type
=
'Web Section'
website
.
newContent
(
portal_type
=
web_section_portal_type
)
content
=
'<p>initial text</p>'
document
=
self
.
portal
.
web_page_module
.
newContent
(
portal_type
=
'Web Page'
,
id
=
'document_cache'
,
reference
=
'NXD-Document.Cache'
,
text_content
=
content
)
document
.
publish
()
# clear cache used in Base_getWebDocumentDrivenModificationDate
self
.
portal
.
portal_caches
.
clearAllCache
()
self
.
tic
()
path
=
website
.
absolute_url_path
()
+
'/NXD-Document.Cache'
# test Different Policy installed by erp5_web
# authenticated
user
=
self
.
createUser
(
'webmaster'
)
self
.
createUserAssignement
(
user
,
{})
self
.
tic
()
response
=
self
.
publish
(
path
,
'webmaster:webmaster'
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertTrue
(
last_modified_header
)
# Convert the Date into string according RFC 1123 Time Format
modification_date
=
rfc1123_date
(
document
.
getModificationDate
())
self
.
assertEqual
(
modification_date
,
last_modified_header
)
self
.
assertFalse
(
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, no-store'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
None
)
def
test_15a_CheckCachingPolicyManager
(
self
):
"""
...
...
@@ -1646,6 +1680,364 @@ Hé Hé Hé!""", page.asText().strip())
self
.
tic
()
self
.
assertEqual
(
web_site
.
WebSection_getEventResourceItemList
(),
[(
''
,
''
)])
def
test_caching_policy_no_store
(
self
):
"""Even as anonnymous we expect that no Last-Modified
is provided, and no-store on cache control.
This test check 1 Policy installed by erp5_web:
Policy ID - no store
"""
website
=
self
.
setupWebSite
()
web_section_portal_type
=
'Web Section'
website
.
newContent
(
portal_type
=
web_section_portal_type
)
# It expected
website
.
setCachingPolicy
(
'no-store'
)
content
=
'<p>initial text</p>'
document
=
self
.
portal
.
web_page_module
.
newContent
(
portal_type
=
'Web Page'
,
id
=
'document_cache'
,
reference
=
'NXD-Document.Cache'
,
text_content
=
content
)
document
.
publish
()
# clear cache used in Base_getWebDocumentDrivenModificationDate
self
.
portal
.
portal_caches
.
clearAllCache
()
self
.
tic
()
path
=
website
.
absolute_url_path
()
+
'/NXD-Document.Cache'
# test Different Policy installed by erp5_web
# unauthenticated web pages
response
=
self
.
publish
(
path
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertFalse
(
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, no-store'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
None
)
# retry after login
user
=
self
.
createUser
(
'webmaster'
)
self
.
createUserAssignement
(
user
,
{})
self
.
tic
()
response
=
self
.
publish
(
path
,
'webmaster:webmaster'
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertFalse
(
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, no-store'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
None
)
def
test_caching_policy_no_cache
(
self
):
"""This test check 1 Policy installed by erp5_web:
Policy ID - no cache
"""
website
=
self
.
setupWebSite
()
web_section_portal_type
=
'Web Section'
website
.
newContent
(
portal_type
=
web_section_portal_type
)
# It expected
website
.
setCachingPolicy
(
'no-cache'
)
content
=
'<p>initial text</p>'
document
=
self
.
portal
.
web_page_module
.
newContent
(
portal_type
=
'Web Page'
,
id
=
'document_cache'
,
reference
=
'NXD-Document.Cache'
,
text_content
=
content
)
document
.
publish
()
# clear cache used in Base_getWebDocumentDrivenModificationDate
self
.
portal
.
portal_caches
.
clearAllCache
()
self
.
tic
()
path
=
website
.
absolute_url_path
()
+
'/NXD-Document.Cache'
# test Different Policy installed by erp5_web
# unauthenticated web pages
response
=
self
.
publish
(
path
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertFalse
(
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, no-cache'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
None
)
# retry after login
user
=
self
.
createUser
(
'webmaster'
)
self
.
createUserAssignement
(
user
,
{})
self
.
tic
()
response
=
self
.
publish
(
path
,
'webmaster:webmaster'
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertFalse
(
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, no-cache'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
None
)
def
test_caching_policy_one_year_cache
(
self
):
""" Only works as unauthenticated user
This test check 1 Policy installed by erp5_web:
Policy ID - one-year-cache
"""
website
=
self
.
setupWebSite
()
web_section_portal_type
=
'Web Section'
website
.
newContent
(
portal_type
=
web_section_portal_type
)
# It expected
website
.
setCachingPolicy
(
'one-year-cache'
)
content
=
'<p>initial text</p>'
document
=
self
.
portal
.
web_page_module
.
newContent
(
portal_type
=
'Web Page'
,
id
=
'document_cache'
,
reference
=
'NXD-Document.Cache'
,
text_content
=
content
)
document
.
publish
()
# clear cache used in Base_getWebDocumentDrivenModificationDate
self
.
portal
.
portal_caches
.
clearAllCache
()
self
.
tic
()
path
=
website
.
absolute_url_path
()
+
'/NXD-Document.Cache'
# test Different Policy installed by erp5_web
# unauthenticated web pages
response
=
self
.
publish
(
path
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertTrue
(
last_modified_header
)
from
App.Common
import
rfc1123_date
# Convert the Date into string according RFC 1123 Time Format
modification_date
=
rfc1123_date
(
document
.
getModificationDate
())
self
.
assertEqual
(
modification_date
,
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=31536000, stale-while-revalidate=31536000, stale-if-error=31536000, public'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
'Cookie, Authorization, Accept-Encoding'
)
# retry after login
user
=
self
.
createUser
(
'webmaster'
)
self
.
createUserAssignement
(
user
,
{})
self
.
tic
()
response
=
self
.
publish
(
path
,
'webmaster:webmaster'
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertFalse
(
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, no-store'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
None
)
def
test_caching_policy_one_day_max_modification_date_cache
(
self
):
""" Only works as unauthenticated user
This test check 1 Policy installed by erp5_web:
Policy ID - one-day-max-modification-date
"""
website
=
self
.
setupWebSite
()
web_section_portal_type
=
'Web Section'
website
.
newContent
(
portal_type
=
web_section_portal_type
)
# It expected
website
.
setCachingPolicy
(
'one-day-max-modification-date'
)
content
=
'<p>initial text</p>'
document
=
self
.
portal
.
web_page_module
.
newContent
(
portal_type
=
'Web Page'
,
id
=
'document_cache'
,
reference
=
'NXD-Document.Cache'
,
text_content
=
content
)
document
.
publish
()
# clear cache used in Base_getWebDocumentDrivenModificationDate
self
.
portal
.
portal_caches
.
clearAllCache
()
self
.
tic
()
path
=
website
.
absolute_url_path
()
+
'/NXD-Document.Cache'
# test Different Policy installed by erp5_web
# unauthenticated web pages
response
=
self
.
publish
(
path
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertTrue
(
last_modified_header
)
from
App.Common
import
rfc1123_date
# Convert the Date into string according RFC 1123 Time Format
modification_date
=
rfc1123_date
(
document
.
getModificationDate
())
self
.
assertEqual
(
modification_date
,
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=600, stale-while-revalidate=360000, stale-if-error=31536000, public'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
'Cookie, Authorization, Accept-Encoding'
)
# retry after login
user
=
self
.
createUser
(
'webmaster'
)
self
.
createUserAssignement
(
user
,
{})
self
.
tic
()
response
=
self
.
publish
(
path
,
'webmaster:webmaster'
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertFalse
(
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, no-store'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
None
)
def
test_caching_policy_one_hour_max_modification_date_cache
(
self
):
""" Only works as unauthenticated user
This test check 1 Policy installed by erp5_web:
Policy ID - one-hour-max-modification-date
"""
website
=
self
.
setupWebSite
()
web_section_portal_type
=
'Web Section'
website
.
newContent
(
portal_type
=
web_section_portal_type
)
# It expected
website
.
setCachingPolicy
(
'one-hour-max-modification-date'
)
content
=
'<p>initial text</p>'
document
=
self
.
portal
.
web_page_module
.
newContent
(
portal_type
=
'Web Page'
,
id
=
'document_cache'
,
reference
=
'NXD-Document.Cache'
,
text_content
=
content
)
document
.
publish
()
# clear cache used in Base_getWebDocumentDrivenModificationDate
self
.
portal
.
portal_caches
.
clearAllCache
()
self
.
tic
()
path
=
website
.
absolute_url_path
()
+
'/NXD-Document.Cache'
# test Different Policy installed by erp5_web
# unauthenticated web pages
response
=
self
.
publish
(
path
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertTrue
(
last_modified_header
)
from
App.Common
import
rfc1123_date
# Convert the Date into string according RFC 1123 Time Format
modification_date
=
rfc1123_date
(
document
.
getModificationDate
())
self
.
assertEqual
(
modification_date
,
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=600, stale-while-revalidate=360000, stale-if-error=31536000, public'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
'Cookie, Authorization, Accept-Encoding'
)
# retry after login
user
=
self
.
createUser
(
'webmaster'
)
self
.
createUserAssignement
(
user
,
{})
self
.
tic
()
response
=
self
.
publish
(
path
,
'webmaster:webmaster'
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertFalse
(
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, no-store'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
None
)
def
test_caching_policy_must_revalidate_cache
(
self
):
"""
This test check 1 Policy installed by erp5_web:
Policy ID - must-revalidate
"""
website
=
self
.
setupWebSite
()
web_section_portal_type
=
'Web Section'
website
.
newContent
(
portal_type
=
web_section_portal_type
)
# It expected
website
.
setCachingPolicy
(
'must-revalidate'
)
content
=
'<p>initial text</p>'
document
=
self
.
portal
.
web_page_module
.
newContent
(
portal_type
=
'Web Page'
,
id
=
'document_cache'
,
reference
=
'NXD-Document.Cache'
,
text_content
=
content
)
document
.
publish
()
# clear cache used in Base_getWebDocumentDrivenModificationDate
self
.
portal
.
portal_caches
.
clearAllCache
()
self
.
tic
()
path
=
website
.
absolute_url_path
()
+
'/NXD-Document.Cache'
# test Different Policy installed by erp5_web
# unauthenticated web pages
response
=
self
.
publish
(
path
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
self
.
assertTrue
(
last_modified_header
)
from
App.Common
import
rfc1123_date
# Convert the Date into string according RFC 1123 Time Format
modification_date
=
rfc1123_date
(
document
.
getModificationDate
())
self
.
assertEqual
(
modification_date
,
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, public, must-revalidate'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
'Accept-Language, Cookie, Authorization, Accept-Encoding'
)
# retry after login
user
=
self
.
createUser
(
'webmaster'
)
self
.
createUserAssignement
(
user
,
{})
self
.
tic
()
response
=
self
.
publish
(
path
,
'webmaster:webmaster'
)
last_modified_header
=
response
.
getHeader
(
'Last-Modified'
)
modification_date
=
rfc1123_date
(
document
.
getModificationDate
())
self
.
assertEqual
(
modification_date
,
last_modified_header
)
# Check cache control
cache_control_header
=
response
.
getHeader
(
'Cache-Control'
)
self
.
assertEqual
(
cache_control_header
,
'max-age=0, public, must-revalidate'
)
# Check Vary
cache_control_header
=
response
.
getHeader
(
'Vary'
)
self
.
assertEqual
(
cache_control_header
,
"Accept-Language, Cookie, Authorization, Accept-Encoding"
)
class
TestERP5WebWithSimpleSecurity
(
ERP5TypeTestCase
):
"""
Test for erp5_web with simple security.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment