On 6/17/22 4:05 PM, Dylan Hatch wrote:
On Fri, Jun 17, 2022 at 12:38 PM Shuah Khan skhan@linuxfoundation.org wrote:
On 6/17/22 12:45 PM, Dylan Hatch wrote:
On Thu, Jun 16, 2022 at 4:01 PM Shuah Khan skhan@linuxfoundation.org wrote:
It depends on the goal of the test. Is the test looking to see if the probe fails with insufficient permissions, then you are changing the test to not check for that condition.
The goal of the test is to validate the output of /proc/$PID/maps, and the memory probe is only needed as setup to determine what the expected output should be. This used to be sufficient, but now it can no longer fully disambiguate it with the introduction of vsyscall=xonly. The solution proposed here is to disambiguate it by also checking the length read from /proc/$PID/maps.
Makes sense. However the question is does this test need to be enhanced with the addition of vsyscall=xonly?
I would say in this case, the right approach would be to leave the test as is and report expected fail and add other cases.
The goal being adding more coverage and not necessarily opt for a simple solution.
What does it mean to report a test as expected fail? Is this a mechanism unique to kselftest? I agree adding another test case would work, but I'm unsure how to do it within the framework of kselftest. Ideally, there would be separate test cases for vsyscall=none, vsyscall=emulate, and vsyscall=xonly, but these options can be toggled both in the kernel config and on the kernel command line, meaning (to the best of my knowledge) these test cases would have to be built conditionally against the conflig options and also parse the command line for the 'vsyscall' option.
Expected fail isn't unique kselftest. It is a testing criteria where a test is expected to fail. For example if a file can only be opened with privileged user a test that runs and looks for failure is an expected to fail case - we are looking for a failure.
A complete battery of tests for vsyscall=none, vsyscall=emulate, vsyscall=xonly would test for conditions that are expected to pass and fail based on the config.
tools/testing/selftests/proc/config doesn't have any config options that are relevant to VSYSCALL
Can you please send me the how you are running the test and what the failure output looks like?
thanks, -- Shuah