Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
ZEO
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
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
ZEO
Commits
2a8691c1
Commit
2a8691c1
authored
Jun 13, 2003
by
Tim Peters
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
An obsolete version of this file got added from the 3.1 branch. Bringing
it up to date.
parent
2742c58f
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
31 additions
and
8 deletions
+31
-8
src/ZEO/tests/InvalidationTests.py
src/ZEO/tests/InvalidationTests.py
+31
-8
No files found.
src/ZEO/tests/InvalidationTests.py
View file @
2a8691c1
...
@@ -27,8 +27,27 @@ from ZODB.POSException \
...
@@ -27,8 +27,27 @@ from ZODB.POSException \
import
ReadConflictError
,
ConflictError
,
VersionLockError
import
ReadConflictError
,
ConflictError
,
VersionLockError
import
zLOG
import
zLOG
# The tests here let several threads have a go at one or more database
# instances simultaneously. Each thread appends a disjoint (from the
# other threads) sequence of increasing integers to an OOBTree, one at
# at time (per thread). This provokes lots of conflicts, and BTrees
# work hard at conflict resolution too. An OOBTree is used because
# that flavor has the smallest maximum bucket size, and so splits buckets
# more often than other BTree flavors.
#
# When these tests were first written, they provoked an amazing number
# of obscure timing-related bugs in cache consistency logic, revealed
# by failure of the BTree to pass internal consistency checks at the end,
# and/or by failure of the BTree to contain all the keys the threads
# thought they added (i.e., the keys for which get_transaction().commit()
# did not raise any exception).
class
StressThread
(
TestThread
):
class
StressThread
(
TestThread
):
# Append integers startnum, startnum + step, startnum + 2*step, ...
# to 'tree' until Event stop is set. If sleep is given, sleep
# that long after each append. At the end, instance var .added_keys
# is a list of the ints the thread believes it added successfully.
def
__init__
(
self
,
testcase
,
db
,
stop
,
threadnum
,
startnum
,
def
__init__
(
self
,
testcase
,
db
,
stop
,
threadnum
,
startnum
,
step
=
2
,
sleep
=
None
):
step
=
2
,
sleep
=
None
):
TestThread
.
__init__
(
self
,
testcase
)
TestThread
.
__init__
(
self
,
testcase
)
...
@@ -66,11 +85,11 @@ class StressThread(TestThread):
...
@@ -66,11 +85,11 @@ class StressThread(TestThread):
cn
.
sync
()
cn
.
sync
()
else
:
else
:
self
.
added_keys
.
append
(
key
)
self
.
added_keys
.
append
(
key
)
key
+=
self
.
step
key
+=
self
.
step
cn
.
close
()
cn
.
close
()
class
VersionStressThread
(
TestThread
):
class
VersionStressThread
(
TestThread
):
def
__init__
(
self
,
testcase
,
db
,
stop
,
threadnum
,
startnum
,
def
__init__
(
self
,
testcase
,
db
,
stop
,
threadnum
,
startnum
,
step
=
2
,
sleep
=
None
):
step
=
2
,
sleep
=
None
):
TestThread
.
__init__
(
self
,
testcase
)
TestThread
.
__init__
(
self
,
testcase
)
...
@@ -103,7 +122,7 @@ class VersionStressThread(TestThread):
...
@@ -103,7 +122,7 @@ class VersionStressThread(TestThread):
# of VersionLockErrors, based on empirical observation.
# of VersionLockErrors, based on empirical observation.
# It looks like the threads don't switch enough without
# It looks like the threads don't switch enough without
# the sleeps.
# the sleeps.
cn
=
self
.
db
.
open
(
version
)
cn
=
self
.
db
.
open
(
version
)
while
not
self
.
stop
.
isSet
():
while
not
self
.
stop
.
isSet
():
try
:
try
:
...
@@ -154,10 +173,10 @@ class VersionStressThread(TestThread):
...
@@ -154,10 +173,10 @@ class VersionStressThread(TestThread):
class
InvalidationTests
(
CommonSetupTearDown
):
class
InvalidationTests
(
CommonSetupTearDown
):
level
=
2
level
=
2
DELAY
=
15
DELAY
=
15
# number of seconds the main thread lets the workers run
def
_check_tree
(
self
,
cn
,
tree
):
def
_check_tree
(
self
,
cn
,
tree
):
# Make sure the BTree is sane and that all the updates persisted
# Make sure the BTree is sane and that all the updates persisted
.
retries
=
3
retries
=
3
while
retries
:
while
retries
:
retries
-=
1
retries
-=
1
...
@@ -177,11 +196,15 @@ class InvalidationTests(CommonSetupTearDown):
...
@@ -177,11 +196,15 @@ class InvalidationTests(CommonSetupTearDown):
def
_check_threads
(
self
,
tree
,
*
threads
):
def
_check_threads
(
self
,
tree
,
*
threads
):
# Make sure the thread's view of the world is consistent with
# Make sure the thread's view of the world is consistent with
# the actual database state.
# the actual database state.
all_keys
=
[]
for
t
in
threads
:
for
t
in
threads
:
# If the test didn't add any keys, it didn't do what we expected.
# If the test didn't add any keys, it didn't do what we expected.
self
.
assert_
(
t
.
added_keys
)
self
.
assert_
(
t
.
added_keys
)
for
key
in
t
.
added_keys
:
for
key
in
t
.
added_keys
:
self
.
assert_
(
tree
.
has_key
(
key
),
key
)
self
.
assert_
(
tree
.
has_key
(
key
),
key
)
all_keys
.
extend
(
t
.
added_keys
)
all_keys
.
sort
()
self
.
assertEqual
(
all_keys
,
list
(
tree
.
keys
()))
def
go
(
self
,
stop
,
*
threads
):
def
go
(
self
,
stop
,
*
threads
):
# Run the threads
# Run the threads
...
@@ -191,7 +214,7 @@ class InvalidationTests(CommonSetupTearDown):
...
@@ -191,7 +214,7 @@ class InvalidationTests(CommonSetupTearDown):
stop
.
set
()
stop
.
set
()
for
t
in
threads
:
for
t
in
threads
:
t
.
cleanup
()
t
.
cleanup
()
def
checkConcurrentUpdates2Storages
(
self
):
def
checkConcurrentUpdates2Storages
(
self
):
self
.
_storage
=
storage1
=
self
.
openClientStorage
()
self
.
_storage
=
storage1
=
self
.
openClientStorage
()
storage2
=
self
.
openClientStorage
(
cache
=
"2"
)
storage2
=
self
.
openClientStorage
(
cache
=
"2"
)
...
@@ -251,7 +274,7 @@ class InvalidationTests(CommonSetupTearDown):
...
@@ -251,7 +274,7 @@ class InvalidationTests(CommonSetupTearDown):
# Two of the threads share a single storage so that it
# Two of the threads share a single storage so that it
# is possible for both threads to read the same object
# is possible for both threads to read the same object
# at the same time.
# at the same time.
t1
=
StressThread
(
self
,
db1
,
stop
,
1
,
1
,
3
)
t1
=
StressThread
(
self
,
db1
,
stop
,
1
,
1
,
3
)
t2
=
StressThread
(
self
,
db2
,
stop
,
2
,
2
,
3
,
0.001
)
t2
=
StressThread
(
self
,
db2
,
stop
,
2
,
2
,
3
,
0.001
)
t3
=
StressThread
(
self
,
db2
,
stop
,
3
,
3
,
3
,
0.001
)
t3
=
StressThread
(
self
,
db2
,
stop
,
3
,
3
,
3
,
0.001
)
...
@@ -279,7 +302,7 @@ class InvalidationTests(CommonSetupTearDown):
...
@@ -279,7 +302,7 @@ class InvalidationTests(CommonSetupTearDown):
# Two of the threads share a single storage so that it
# Two of the threads share a single storage so that it
# is possible for both threads to read the same object
# is possible for both threads to read the same object
# at the same time.
# at the same time.
t1
=
VersionStressThread
(
self
,
db1
,
stop
,
1
,
1
,
3
)
t1
=
VersionStressThread
(
self
,
db1
,
stop
,
1
,
1
,
3
)
t2
=
VersionStressThread
(
self
,
db2
,
stop
,
2
,
2
,
3
,
0.001
)
t2
=
VersionStressThread
(
self
,
db2
,
stop
,
2
,
2
,
3
,
0.001
)
t3
=
VersionStressThread
(
self
,
db2
,
stop
,
3
,
3
,
3
,
0.001
)
t3
=
VersionStressThread
(
self
,
db2
,
stop
,
3
,
3
,
3
,
0.001
)
...
...
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