commit | 04768696b0579249beddb7546ed23e03b4ceff69 | [log] [tgz] |
---|---|---|
author | Brandon Castellano <bcastell@google.com> | Tue Mar 25 09:11:08 2025 -0700 |
committer | CQ Bot <fuchsia-internal-scoped@luci-project-accounts.iam.gserviceaccount.com> | Tue Mar 25 09:11:08 2025 -0700 |
tree | 25ce56cf0d0e58feab6d54fbcc74906732b5d7ca | |
parent | 35d6b311ecd1683a9d2210639f3a65acc738c93c [diff] |
[package-directory] Rework tests to use VFS connections Ensure package directory tests serve a connection to the directories being tested, and all child nodes are opened through fuchsia.io. This ensures that the VFS connection logic (including hierarchal rights enforcement and path handling) is also tested. This results in a few test-only changes: * Hierarchal rights are now enforced, so in cases where NOT_SUPPORTED was being checked before, we now need ACCESS_DENIED. * The VFS handles checking certain flags already reducing the verbosity of these tests. This includes attempts to create new nodes, which requires the parent connection to be served as writable. This is not possible with how the nodes are implemented, so these tests have been removed in lieu of assertions that guarantee we cannot create new files, and tests that ensure we cannot create mutable connections * Callers of the fuchsia.io/Directory.DeprecatedOpen method now reject requests to open files where the path ends with a trailing slash, since the VFS adds OpenFlags.DIRECTORY in these cases. This is NOT done for the new fuchsia.io/Directory.Open method, so that is still allowed for those tests. As we are now testing through a DirectoryProxy instead of calling the VFS Node trait methods directly, we can simplify a lot of test code by using the helpers in the fuchsia-fs crate. This improves test readability significantly in some cases, and also ensures that we test end-to-end behavior that clients will encounter. There should be no change to code coverage with these tests, but there is a small functional change: in certain cases when calling fuchsia.io/Directory.DeprecatedOpen, the APPEND flag was erroneously allowed. We cannot easily fix this without disabling the old CTF tests, so for now we just update them going forwards and leave the old behavior. We need to address this as part of the io2 migration soon. Remove redundant test cases where the VFS already enforces certain checks, and instead add assertions which ensure no regressions in behavior can occur. Bug: 324111518 Test: fx test package-directory-tests Change-Id: Idac8441d889ffdec3a3f93dc92ab0c7b0aaff036 Reviewed-on: https://fuchsia-review.googlesource.com/c/fuchsia/+/1234244 Reviewed-by: Ben Keller <galbanum@google.com> Commit-Queue: Brandon Castellano <bcastell@google.com>
Fuchsia is an open source, general purpose operating system supporting modern 64-bit Intel and ARM processors.
We expect everyone interacting with our project to respect our code of conduct.
Read more about Fuchsia's principles.
See Getting Started.
See fuchsia.dev.