.forget = tfs_forget,
};
-static void* update_fs(void *data) {
- struct fuse_session *se = (struct fuse_session*) data;
- struct tm *now;
- char *old_name;
+static void update_fs(void) {
time_t t;
+ struct tm *now;
ssize_t ret;
- while(1) {
- t = time(NULL);
- now = localtime(&t);
- assert(now != NULL);
+ t = time(NULL);
+ now = localtime(&t);
+ assert(now != NULL);
- old_name = strdup(file_name);
- ret = strftime(file_name, MAX_STR_LEN,
- "Time_is_%Hh_%Mm_%Ss", now);
- assert(ret != 0);
+ ret = strftime(file_name, MAX_STR_LEN,
+ "Time_is_%Hh_%Mm_%Ss", now);
+ assert(ret != 0);
+}
+static void* update_fs_loop(void *data) {
+ struct fuse_session *se = (struct fuse_session*) data;
+ char *old_name;
+
+ while(1) {
+ old_name = strdup(file_name);
+ update_fs();
if (!options.no_notify && lookup_cnt)
assert(fuse_lowlevel_notify_inval_entry
(se, FUSE_ROOT_ID, old_name, strlen(old_name)) == 0);
goto err_out1;
}
+ /* Initial contents */
+ update_fs();
+
se = fuse_session_new(&args, &tfs_oper,
sizeof(tfs_oper), NULL);
if (se == NULL)
fuse_daemonize(opts.foreground);
/* Start thread to update file contents */
- ret = pthread_create(&updater, NULL, update_fs, (void *)se);
+ ret = pthread_create(&updater, NULL, update_fs_loop, (void *)se);
if (ret != 0) {
fprintf(stderr, "pthread_create failed with %s\n",
strerror(ret));
.forget = tfs_forget,
};
-static void* update_fs(void *data) {
- struct fuse_session *se = (struct fuse_session*) data;
+static void update_fs(void) {
struct tm *now;
time_t t;
+ t = time(NULL);
+ now = localtime(&t);
+ assert(now != NULL);
- while(1) {
- t = time(NULL);
- now = localtime(&t);
- assert(now != NULL);
+ file_size = strftime(file_contents, MAX_STR_LEN,
+ "The current time is %H:%M:%S\n", now);
+ assert(file_size != 0);
+}
- file_size = strftime(file_contents, MAX_STR_LEN,
- "The current time is %H:%M:%S\n", now);
- assert(file_size != 0);
+static void* update_fs_loop(void *data) {
+ struct fuse_session *se = (struct fuse_session*) data;
+
+ while(1) {
+ update_fs();
if (!options.no_notify && lookup_cnt) {
/* Only send notification if the kernel
is aware of the inode */
goto err_out1;
}
+ /* Initial contents */
+ update_fs();
+
se = fuse_session_new(&args, &tfs_oper,
sizeof(tfs_oper), NULL);
if (se == NULL)
fuse_daemonize(opts.foreground);
/* Start thread to update file contents */
- ret = pthread_create(&updater, NULL, update_fs, (void *)se);
+ ret = pthread_create(&updater, NULL, update_fs_loop, (void *)se);
if (ret != 0) {
fprintf(stderr, "pthread_create failed with %s\n",
strerror(ret));
.retrieve_reply = tfs_retrieve_reply,
};
-static void* update_fs(void *data) {
- struct fuse_session *se = (struct fuse_session*) data;
+static void update_fs(void) {
struct tm *now;
time_t t;
+ t = time(NULL);
+ now = localtime(&t);
+ assert(now != NULL);
+
+ file_size = strftime(file_contents, MAX_STR_LEN,
+ "The current time is %H:%M:%S\n", now);
+ assert(file_size != 0);
+}
+
+static void* update_fs_loop(void *data) {
+ struct fuse_session *se = (struct fuse_session*) data;
struct fuse_bufvec bufv;
while(1) {
- t = time(NULL);
- now = localtime(&t);
- assert(now != NULL);
-
- file_size = strftime(file_contents, MAX_STR_LEN,
- "The current time is %H:%M:%S\n", now);
- assert(file_size != 0);
+ update_fs();
if (!options.no_notify && lookup_cnt) {
/* Only send notification if the kernel
is aware of the inode */
goto err_out1;
}
+ /* Initial contents */
+ update_fs();
+
se = fuse_session_new(&args, &tfs_oper,
sizeof(tfs_oper), NULL);
if (se == NULL)
fuse_daemonize(opts.foreground);
/* Start thread to update file contents */
- ret = pthread_create(&updater, NULL, update_fs, (void *)se);
+ ret = pthread_create(&updater, NULL, update_fs_loop, (void *)se);
if (ret != 0) {
fprintf(stderr, "pthread_create failed with %s\n",
strerror(ret));
mnt_dir = str(tmpdir)
cmdline = base_cmdline + \
[ pjoin(basename, 'example', name),
- '-f', '--update-interval=2', mnt_dir ] + options
+ '-f', '--update-interval=1', mnt_dir ] + options
if not notify:
cmdline.append('--no-notify')
mount_process = subprocess.Popen(cmdline)
try:
wait_for_mount(mount_process, mnt_dir)
filename = pjoin(mnt_dir, 'current_time')
- # Wait until first update
- while True:
- with open(filename, 'r') as fh:
- read1 = fh.read()
- if read1:
- break
- safe_sleep(2)
- safe_sleep(6)
+ with open(filename, 'r') as fh:
+ read1 = fh.read()
+ safe_sleep(2)
with open(filename, 'r') as fh:
read2 = fh.read()
if notify:
mnt_dir = str(tmpdir)
cmdline = base_cmdline + \
[ pjoin(basename, 'example', 'notify_inval_entry'),
- '-f', '--update-interval=2',
- '--timeout=10', mnt_dir ]
+ '-f', '--update-interval=1',
+ '--timeout=5', mnt_dir ]
if not notify:
cmdline.append('--no-notify')
mount_process = subprocess.Popen(cmdline)
fname = pjoin(mnt_dir, os.listdir(mnt_dir)[0])
os.stat(fname)
- safe_sleep(4)
+ safe_sleep(2)
if not notify:
os.stat(fname)
- safe_sleep(10)
+ safe_sleep(5)
with pytest.raises(FileNotFoundError):
os.stat(fname)
except: