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
8fd0a998
Commit
8fd0a998
authored
Jun 06, 2019
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
7b2b13c7
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
29 additions
and
14 deletions
+29
-14
wcfs/notes.txt
wcfs/notes.txt
+1
-1
wcfs/wcfs_test.py
wcfs/wcfs_test.py
+28
-13
No files found.
wcfs/notes.txt
View file @
8fd0a998
...
@@ -30,7 +30,7 @@ in the link above), but it turned out that in writeback mode the kernel indeed
...
@@ -30,7 +30,7 @@ in the link above), but it turned out that in writeback mode the kernel indeed
does not invalidate data cache on file size change, but neither it allows the
does not invalidate data cache on file size change, but neither it allows the
filesystem to set the size due to external event (see https://git.kernel.org/linus/8373200b12
filesystem to set the size due to external event (see https://git.kernel.org/linus/8373200b12
"fuse: Trust kernel i_size only"). This prevents us to use writeback workaround
"fuse: Trust kernel i_size only"). This prevents us to use writeback workaround
as we cannot even update the file from being empty to hav
ing
some data.
as we cannot even update the file from being empty to hav
e
some data.
-> we did the patch for FUSE to have proper flag for filesystem server to tell
-> we did the patch for FUSE to have proper flag for filesystem server to tell
the kernel it is fully responsible for invalidating pagecache. The patch will
the kernel it is fully responsible for invalidating pagecache. The patch will
...
...
wcfs/wcfs_test.py
View file @
8fd0a998
...
@@ -853,29 +853,29 @@ def test_wcfs():
...
@@ -853,29 +853,29 @@ def test_wcfs():
f
.
assertData
([],
mtime
=
at0
)
f
.
assertData
([],
mtime
=
at0
)
# >>> (@at1) commit data -> we can see it on wcfs
# >>> (@at1) commit data -> we can see it on wcfs
t
.
change
(
zf
,
{
2
:
b'
alpha
'
})
t
.
change
(
zf
,
{
2
:
b'
1γ
'
})
at1
=
t
.
commit
()
at1
=
t
.
commit
()
f
.
assertCache
([
0
,
0
,
0
])
# initially not cached
f
.
assertCache
([
0
,
0
,
0
])
# initially not cached
f
.
assertData
([
b''
,
b''
,
b'
alpha
'
],
mtime
=
t
.
head
)
f
.
assertData
([
b''
,
b''
,
b'
1γ
'
],
mtime
=
t
.
head
)
# >>> (@at2) commit again -> we can see both latest and snapshotted states
# >>> (@at2) commit again -> we can see both latest and snapshotted states
t
.
change
(
zf
,
{
2
:
b'
beta'
,
3
:
b'gamma
'
})
t
.
change
(
zf
,
{
2
:
b'
2γ'
,
3
:
b'2δ
'
})
at2
=
t
.
commit
()
at2
=
t
.
commit
()
# f @head
# f @head
f
.
assertCache
([
1
,
1
,
0
,
0
])
f
.
assertCache
([
1
,
1
,
0
,
0
])
f
.
assertData
([
b''
,
b''
,
b'
beta'
,
b'gamma
'
],
mtime
=
t
.
head
)
f
.
assertData
([
b''
,
b''
,
b'
2γ'
,
b'2δ
'
],
mtime
=
t
.
head
)
# f @at1
# f @at1
f1
=
t
.
open
(
zf
,
at
=
at1
)
f1
=
t
.
open
(
zf
,
at
=
at1
)
f1
.
assertCache
([
0
,
0
,
1
])
f1
.
assertCache
([
0
,
0
,
1
])
f1
.
assertData
([
b''
,
b''
,
b'
alpha
'
])
# XXX + mtime=at1?
f1
.
assertData
([
b''
,
b''
,
b'
1γ
'
])
# XXX + mtime=at1?
# >>> (@at3) commit again without changing zf size
# >>> (@at3) commit again without changing zf size
f2
=
t
.
open
(
zf
,
at
=
at2
)
f2
=
t
.
open
(
zf
,
at
=
at2
)
t
.
change
(
zf
,
{
2
:
b'
kitty
'
})
t
.
change
(
zf
,
{
2
:
b'
3γ
'
})
at3
=
t
.
commit
()
at3
=
t
.
commit
()
f
.
assertCache
([
1
,
1
,
0
,
1
])
f
.
assertCache
([
1
,
1
,
0
,
1
])
...
@@ -888,15 +888,15 @@ def test_wcfs():
...
@@ -888,15 +888,15 @@ def test_wcfs():
# f @head
# f @head
f
.
assertCache
([
1
,
1
,
0
,
1
])
f
.
assertCache
([
1
,
1
,
0
,
1
])
f
.
assertData
([
b''
,
b''
,
b'
kitty'
,
b'gamma
'
],
mtime
=
t
.
head
)
f
.
assertData
([
b''
,
b''
,
b'
3γ'
,
b'2δ
'
],
mtime
=
t
.
head
)
# f @at2
# f @at2
f2
.
assertCache
([
0
,
0
,
1
,
0
])
f2
.
assertCache
([
0
,
0
,
1
,
0
])
f2
.
assertData
([
b''
,
b''
,
b'
beta'
,
b'gamma
'
])
# XXX mtime=at2
f2
.
assertData
([
b''
,
b''
,
b'
2γ'
,
b'2δ
'
])
# XXX mtime=at2
# f @at1
# f @at1
f1
.
assertCache
([
1
,
1
,
1
])
f1
.
assertCache
([
1
,
1
,
1
])
f1
.
assertData
([
b''
,
b''
,
b'
alpha
'
])
# XXX + mtime=at1?
f1
.
assertData
([
b''
,
b''
,
b'
1γ
'
])
# XXX + mtime=at1?
# >>> f close / open again -> cache must not be lost
# >>> f close / open again -> cache must not be lost
...
@@ -906,6 +906,7 @@ def test_wcfs():
...
@@ -906,6 +906,7 @@ def test_wcfs():
f
=
t
.
open
(
zf
)
f
=
t
.
open
(
zf
)
assert
f
.
cached
()
!=
[
0
,
0
,
0
,
0
]
assert
f
.
cached
()
!=
[
0
,
0
,
0
,
0
]
return
# XXX temp
# >>> XXX commit data to not yet accessed f part - nothing happens
# >>> XXX commit data to not yet accessed f part - nothing happens
...
@@ -950,10 +951,26 @@ def test_wcfs():
...
@@ -950,10 +951,26 @@ def test_wcfs():
print
()
print
()
# watched + commit -> receive pin messages
wl
=
t
.
openwatch
()
wl
.
watch
(
zf
,
t
.
head
)
f
.
assertCache
([
1
,
1
,
1
,
1
])
t
.
change
(
zf
,
{
1
:
b'rio'
,
2
:
b'tty'
,
5
:
b'big'
})
at4
=
t
.
commit
()
f
.
assertCache
([
1
,
0
,
0
,
1
,
0
,
0
])
# XXX going not only up, but also down at1 <- at2 <- at3 ? -> forbid?
# XXX watched + commit -> receive pin messages
# XXX commit after current file size -> watch
# XXX access to block not previously accessed but invalidated in ZODB
# XXX going not only up, but also down at1 <- at2 <- at3 ? -> forbid?
# XXX 2 (or more) opened watch for 1 file at the same time
# XXX 2 (or more) opened watch for 1 file at the same time
...
@@ -966,8 +983,6 @@ def test_wcfs():
...
@@ -966,8 +983,6 @@ def test_wcfs():
# XXX mmap f; change f[blk] on pin message while under pagefault - should get changed page
# XXX mmap f; change f[blk] on pin message while under pagefault - should get changed page
# XXX access to block not previously accessed but invalidated in ZODB
# XXX new watch request while previous watch request is in progress (over the same /head/watch handle)
# XXX new watch request while previous watch request is in progress (over the same /head/watch handle)
# XXX blk not initially covered by f.δtail (blk never accessed - f.δtail
# XXX blk not initially covered by f.δtail (blk never accessed - f.δtail
...
...
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