Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
W
wendelin.core
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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Joshua
wendelin.core
Commits
af0a64cb
Commit
af0a64cb
authored
Jun 11, 2019
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
X test for "bye" canceling blocked handlers
parent
12628943
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
40 additions
and
10 deletions
+40
-10
wcfs/wcfs.go
wcfs/wcfs.go
+7
-2
wcfs/wcfs_test.py
wcfs/wcfs_test.py
+33
-8
No files found.
wcfs/wcfs.go
View file @
af0a64cb
...
...
@@ -1325,12 +1325,17 @@ retry:
//
// XXX error - when? or close watch on any error?
func
(
w
*
Watch
)
pin
(
ctx
context
.
Context
,
blk
int64
,
rev
zodb
.
Tid
)
(
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"wlink%d: f<%s>"
,
w
.
link
.
id
,
w
.
file
.
zfile
.
POid
())
return
w
.
_pin
(
ctx
,
blk
,
rev
)
}
func
(
w
*
Watch
)
_pin
(
ctx
context
.
Context
,
blk
int64
,
rev
zodb
.
Tid
)
(
err
error
)
{
foid
:=
w
.
file
.
zfile
.
POid
()
revstr
:=
rev
.
String
()
if
rev
==
zodb
.
TidMax
{
revstr
=
"head"
}
defer
xerr
.
Contextf
(
&
err
,
"
f<%s>: wlink%d: pin #%d @%s"
,
foid
,
w
.
link
.
id
,
blk
,
revstr
)
defer
xerr
.
Contextf
(
&
err
,
"
pin #%d @%s"
,
blk
,
revstr
)
// XXX locking?
// XXX simultaneous calls?
...
...
@@ -1464,7 +1469,7 @@ func (wlink *WatchLink) setupWatch(ctx context.Context, foid zodb.Oid, at zodb.T
blk
:=
blk
rev
:=
rev
wg
.
Go
(
func
()
error
{
return
w
.
pin
(
ctx
,
blk
,
rev
)
return
w
.
_
pin
(
ctx
,
blk
,
rev
)
})
}
err
=
wg
.
Wait
()
...
...
wcfs/wcfs_test.py
View file @
af0a64cb
...
...
@@ -641,6 +641,7 @@ class tWatchLink:
t
.
_accepted
=
set
()
# of stream streams we accepted but did not replied yet
t
.
_txmu
=
threading
.
Lock
()
# serializes writes
t
.
_txclosed
=
False
serveCtx
,
t
.
_serveCancel
=
context
.
with_cancel
(
context
.
background
())
t
.
_serveWG
=
sync
.
WorkGroup
(
serveCtx
)
...
...
@@ -651,17 +652,25 @@ class tWatchLink:
tdb
.
_wlinks
.
add
(
t
)
def
close
(
t
):
t
.
tdb
.
_wlinks
.
remove
(
t
)
def
_closeTX
(
t
):
if
t
.
_txclosed
:
return
t
.
_serveCancel
()
# ask wcfs to close its tx & rx sides; close(wcfs.tx) wakes up
# _serveRX on client (= on us). The connection can be already closed by
# wcfs - so ignore errorswhen sending bye.
# wcfs - so ignore errors
when sending bye.
try
:
t
.
_send
(
1
,
b'bye'
)
except
IOError
:
pass
t
.
_wtx
.
close
()
t
.
_txclosed
=
True
def
close
(
t
):
t
.
tdb
.
_wlinks
.
remove
(
t
)
t
.
_closeTX
()
t
.
_serveCancel
()
# XXX we can get stuck here if wcfs does not behave as we want.
# XXX in particular if there is a silly - e.g. syntax or type error in
# test code - we curently get stuck here.
...
...
@@ -674,7 +683,6 @@ class tWatchLink:
if
e
!=
context
.
canceled
:
reraise
(
e
,
None
,
e
.
__traceback__
)
t
.
_wtx
.
close
()
t
.
_wrx
.
close
()
...
...
@@ -1133,13 +1141,30 @@ def test_wcfs():
# >>> XXX commit data to not yet accessed f part - nothing happens
"""
#
"""
# >>> invalidation protocol
print
(
'
\
n
\
n
inv. protocol
\
n
\
n
'
)
# closeTX/bye cancels blocked pin handlers
wl
=
t
.
openwatch
()
wg
=
sync
.
WorkGroup
(
timeout
())
def
_
(
ctx
):
assert
wl
.
sendReq
(
ctx
,
b"watch %s @%s"
%
(
h
(
zf
.
_p_oid
),
h
(
at2
)))
==
\
"error setup watch f<%s> @%s: pin #%d @%s: context canceled"
%
\
(
h
(
zf
.
_p_oid
),
h
(
at2
),
2
,
h
(
at2
))
wg
.
go
(
_
)
def
_
(
ctx
):
req
=
wl
.
recvReq
(
ctx
)
assert
req
is
not
None
assert
req
.
msg
==
b"pin %s #%d @%s"
%
(
h
(
zf
.
_p_oid
),
2
,
h
(
at2
))
# don't reply to req - close instead
wl
.
_closeTX
()
wg
.
go
(
_
)
wg
.
wait
()
# invalid requests -> wcfs replies error
wl
=
t
.
openwatch
()
assert wl.sendReq(
context.background
(), b'bla bla') ==
\
assert
wl
.
sendReq
(
timeout
(),
b'bla bla'
)
==
\
b'error bad watch: not a watch request: "bla bla"'
# invalid request not following frame structure -> fatal + wcfs must close watch link
...
...
@@ -1181,7 +1206,7 @@ def test_wcfs():
for
at
in
revv
[
1
:]:
wl
.
watch
(
zf
,
at
)
wl
.
close
()
"""
#
"""
# XXX move before setup watch?
print
(
'
\
n
\
n
\
n
\
n
WATCH+COMMIT
\
n
\
n
'
)
...
...
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