A number of the filesystem tests create a directory that contains a bad symlink. On AIX recursively setting permissions on said directory will return a non-zero value because of the bad symlink, however the following rm -r still completes successfully. Avoid the assertion on AIX, and rely on the return value of the remove command to detect problems.
Details
- Reviewers
ldionne daltenty - Group Reviewers
Restricted Project - Commits
- rGd193f7be7898: [libc++][AIX] Do not assert chmod return value is non-zero.
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
libcxx/test/support/filesystem_test_helper.h | ||
---|---|---|
145–148 | Please align the comment with the code. Also, we always indent with spaces, not tabs (in case that's the issue). |
I think these tests are still failing, I'm seeing a bunch of failures in recent builds since this was checked in. Can you please take a look and either fix or revert this quickly to avoid blocking the CI pipeline?
Here is an example of a build that's failing: https://buildkite.com/llvm-project/libcxx-ci/builds/8104#3fcf3f17-bdfe-476b-85f7-314c82a378ff. D117512 is completely unrelated to filesystem, so I can't imagine it's an actual issue with D117512.
Yeah, I had noticed that and am looking into it. It seems to be failing at one of the other assertions, before the one modified by this patch.
# command stderr: mkdir: cannot create /tmp/remove.pass.cpp.dir-static_env.6885170422568648249. /tmp/remove.pass.cpp.dir-static_env.6885170422568648249: Too many links Assertion failed: ret == 0, file /scratch/powerllvm/cpap8008/llvm-project/libcxx-ci/libcxx/test/support/filesystem_test_helper.h, line 128 error: command failed with exit status: 250
Looks like this is actually caused by /tmp hitting some filesystem limits on the bots. We've cleaned up and re-dispatched the test run which looks clean. Sorry for the noise.
Please align the comment with the code. Also, we always indent with spaces, not tabs (in case that's the issue).