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
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
Kirill Smelkov
wendelin.core
Commits
0f398ab8
Commit
0f398ab8
authored
Jun 06, 2019
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
f2b8e63b
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
33 additions
and
18 deletions
+33
-18
wcfs/misc.go
wcfs/misc.go
+1
-1
wcfs/wcfs.go
wcfs/wcfs.go
+27
-16
wcfs/wcfs_test.py
wcfs/wcfs_test.py
+5
-1
No files found.
wcfs/misc.go
View file @
0f398ab8
...
...
@@ -641,7 +641,7 @@ func parseWatch(msg string) (oid zodb.Oid, at zodb.Tid, err error) {
}()
if
!
strings
.
HasPrefix
(
msg
,
"watch "
)
{
return
0
,
0
,
fmt
.
Errorf
(
"not a watch request
"
)
return
0
,
0
,
fmt
.
Errorf
(
"not a watch request
: %q"
,
msg
)
}
argv
:=
strings
.
Split
(
msg
[
len
(
"watch "
)
:
],
" "
)
if
len
(
argv
)
!=
2
{
...
...
wcfs/wcfs.go
View file @
0f398ab8
...
...
@@ -423,6 +423,7 @@ import (
"context"
"flag"
"fmt"
"io"
stdlog
"log"
"os"
// "runtime"
...
...
@@ -1336,7 +1337,7 @@ func (w *Watch) pin(ctx context.Context, blk int64, rev zodb.Tid) (err error) {
if
rev
==
zodb
.
TidMax
{
panicf
(
"f<%s>: wlink%d: pinned[#%d] = @head"
,
foid
,
w
.
link
.
id
,
blk
)
}
return
// already pinned XXX for simultaneous calls?
return
nil
// already pinned XXX for simultaneous calls?
}
ack
,
err
:=
w
.
link
.
sendReq
(
ctx
,
fmt
.
Sprintf
(
"pin %s #%d @%s"
,
foid
,
blk
,
revstr
))
...
...
@@ -1379,7 +1380,7 @@ func (wlink *WatchLink) setupWatch(ctx context.Context, foid zodb.Oid, at zodb.T
f
:=
bfdir
.
fileTab
[
foid
]
if
f
==
nil
{
// by "invalidation protocol" watch is setup after data file was opened
return
fmt
.
Errorf
(
"file not yet known or is not a ZBigFile"
)
return
fmt
.
Errorf
(
"file not yet known
to wcfs
or is not a ZBigFile"
)
}
w
=
&
Watch
{
...
...
@@ -1404,7 +1405,8 @@ func (wlink *WatchLink) setupWatch(ctx context.Context, foid zodb.Oid, at zodb.T
// XXX <~> f.δtail.Head() ≥ at (?)
if
at
<
bfdir
.
δFtail
.
Tail
()
{
return
fmt
.
Errorf
(
"at is too far away back from head/at (%s)"
,
headAt
)
return
fmt
.
Errorf
(
"too far away back from head/at (@%s); δt = %s"
,
headAt
,
headAt
.
Time
()
.
Sub
(
at
.
Time
()
.
Time
))
}
// TODO register w to f here early, so that READs going in parallel to
...
...
@@ -1482,14 +1484,14 @@ func (wnode *WatchNode) Open(flags uint32, fctx *fuse.Context) (nodefs.File, fus
// XXX del wlinkTab[w] on w.sk.File.Release
head
.
wlinkTab
[
wlink
]
=
struct
{}{}
go
wlink
.
serve
RX
()
go
wlink
.
serve
()
return
wlink
.
sk
.
File
(),
fuse
.
OK
}
// serve
RX
serves client initiated watch requests and routes client replies to
// wcfs initiated requests.
func
(
wlink
*
WatchLink
)
serve
RX
()
{
err
:=
wlink
.
_serve
RX
()
// serve serves client initiated watch requests and routes client replies to
// wcfs initiated
pin
requests.
func
(
wlink
*
WatchLink
)
serve
()
{
err
:=
wlink
.
_serve
()
// XXX log error if !close
if
err
!=
nil
{
log
.
Error
(
err
)
...
...
@@ -1498,14 +1500,11 @@ func (wlink *WatchLink) serveRX() {
delete
(
wlink
.
head
.
wlinkTab
,
wlink
)
}
func
(
wlink
*
WatchLink
)
_serve
RX
()
(
err
error
)
{
func
(
wlink
*
WatchLink
)
_serve
()
(
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"wlink %d: serve rx"
,
wlink
.
id
)
r
:=
bufio
.
NewReader
(
wlink
.
sk
)
ctx
:=
context
.
TODO
()
// XXX ctx = ? -> ctx of wcfs running
// XXX write to peer if it was logical error on client side
// XXX on which stream? -1?
ctx
:=
context
.
TODO
()
// XXX ctx = ? -> merge(ctx of wcfs running, ctx of wlink timeout)
wg
,
ctx
:=
errgroup
.
WithContext
(
ctx
)
...
...
@@ -1514,10 +1513,14 @@ func (wlink *WatchLink) _serveRX() (err error) {
if
err
==
nil
{
err
=
err2
}
// XXX write to peer if it was logical error on client side
// XXX on which stream? -1? -> better 0 as in HTTP/2?
// XXX then -> CloseWrite
}()
// close .sk
on error/wcfs stopping or return. closing .sk wakes up rx
//
on it and rx on client side
. make sure to stop wg on error return.
// close .sk
.rx on error/wcfs stopping or return. closing .sk.rx wakes up read(sk)
//
(XXX and rx on client side)
. make sure to stop wg on error return.
retq
:=
make
(
chan
struct
{})
defer
close
(
retq
)
wg
.
Go
(
func
()
error
{
...
...
@@ -1529,7 +1532,8 @@ func (wlink *WatchLink) _serveRX() (err error) {
e
=
err
// returned error
}
e2
:=
wlink
.
sk
.
Close
()
//e2 := wlink.sk.Close() // XXX -> CloseRead
e2
:=
wlink
.
sk
.
CloseRead
()
if
e
==
nil
{
e
=
e2
}
...
...
@@ -1543,6 +1547,10 @@ func (wlink *WatchLink) _serveRX() (err error) {
for
{
l
,
err
:=
r
.
ReadString
(
'\n'
)
// XXX limit accepted line len to prevent DOS
if
err
!=
nil
{
// r.Read is woken up by sk.CloseRead when serve decides to exit
if
err
==
io
.
ErrClosedPipe
{
err
=
nil
}
return
err
}
...
...
@@ -1593,6 +1601,9 @@ func (wlink *WatchLink) _serveRX() (err error) {
func
(
wlink
*
WatchLink
)
handleWatch
(
ctx
context
.
Context
,
stream
uint64
,
msg
string
)
(
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"%d"
,
stream
)
// FIXME error "at is too far away" from setupWatch shuold be not fatal
// (XXX bad parse watch -> fatal (not following protocol))
// XXX kill fatal replies? (i.e. make almost everything non-fatal ?)
err
=
wlink
.
_handleWatch
(
ctx
,
msg
)
reply
:=
"ok"
if
err
!=
nil
{
...
...
wcfs/wcfs_test.py
View file @
0f398ab8
...
...
@@ -878,8 +878,12 @@ def test_wcfs():
print
(
'
\
n
\
n
inv. protocol
\
n
\
n
'
)
# invalid requests -> wcfs replies error
# XXX invalid request not following frame structure `<stream> ...`
wl
=
t
.
openwatch
()
assert
wl
.
sendReq
(
context
.
background
(),
b'bla bla'
)
==
b"error bad watch: not a watch request"
assert
wl
.
sendReq
(
context
.
background
(),
b'bla bla'
)
==
\
b'error bad watch: not a watch request: "bla bla"'
# wcfs must close watch link after invalid request
_
,
_rx
=
select
(
...
...
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