Browse Source

fs: re-enable watch facility in AIX

On AIX, watch feature depends on AHAFS based Event infrastructure.
While in principle the watch use case is same across platforms, there
are subtle differences in the way AIX deals with this, with few
behavioral changes (external).

This commit addresses an assertion failure on folder watch, enabling the
AIX code for watch feature which was masked under a macro, open up
relevant test cases, skip tests which comes under the AIX limitation,
and make the document changes as appropriate.

Refs: https://github.com/nodejs/node/pull/11094
Refs: https://github.com/nodejs/node/issues/5085
PR-URL: https://github.com/nodejs/node/pull/10085
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Sakthipriyan Vairamani <thechargingvolcano@gmail.com>
Reviewed-By: Santiago Gimeno <santiago.gimeno@gmail.com>
v6.x
Gireesh Punathil 8 years ago
committed by Myles Borins
parent
commit
ae1f6fd03a
No known key found for this signature in database GPG Key ID: 933B01F40B5CA946
  1. 7
      doc/api/fs.md
  2. 9
      test/parallel/parallel.status
  3. 9
      test/parallel/test-fs-watch-encoding.js

7
doc/api/fs.md

@ -1752,6 +1752,13 @@ a new inode. The watch will emit an event for the delete but will continue
watching the *original* inode. Events for the new inode will not be emitted. watching the *original* inode. Events for the new inode will not be emitted.
This is expected behavior. This is expected behavior.
In AIX, save and close of a file being watched causes two notifications -
one for adding new content, and one for truncation. Moreover, save and
close operations on some platforms cause inode changes that force watch
operations to become invalid and ineffective. AIX retains inode for the
lifetime of a file, that way though this is different from Linux / OS X,
this improves the usability of file watching. This is expected behavior.
#### Filename Argument #### Filename Argument
<!--type=misc--> <!--type=misc-->

9
test/parallel/parallel.status

@ -19,14 +19,7 @@ test-debug-signal-cluster : PASS,FLAKY
[$system==freebsd] [$system==freebsd]
# fs-watch currently needs special configuration on AIX and we
# want to improve under https://github.com/nodejs/node/issues/5085.
# Tests are disabled so CI can be green and we can spot other
# regressions until this work is complete
[$system==aix] [$system==aix]
test-fs-watch-enoent : FAIL, PASS
test-fs-watch-encoding : FAIL, PASS
#covered by https://github.com/nodejs/node/issues/3796 #covered by https://github.com/nodejs/node/issues/3796
# but more frequent on AIX ? # but more frequent on AIX ?
test-debug-signal-cluster : PASS, FLAKY test-debug-signal-cluster : PASS, FLAKY

9
test/parallel/test-fs-watch-encoding.js

@ -14,6 +14,15 @@ const common = require('../common');
const fs = require('fs'); const fs = require('fs');
const path = require('path'); const path = require('path');
// fs-watch on folders have limited capability in AIX.
// The testcase makes use of folder watching, and causes
// hang. This behavior is documented. Skip this for AIX.
if (common.isAix) {
common.skip('folder watch capability is limited in AIX.');
return;
}
common.refreshTmpDir(); common.refreshTmpDir();
const fn = '新建文夹件.txt'; const fn = '新建文夹件.txt';

Loading…
Cancel
Save