diff mbox series

common/rc: Check SCRATCH_DEV in _require_dm_target()

Message ID 20210907074116.1799114-1-shinichiro.kawasaki@wdc.com (mailing list archive)
State New, archived
Headers show
Series common/rc: Check SCRATCH_DEV in _require_dm_target() | expand

Commit Message

Shin'ichiro Kawasaki Sept. 7, 2021, 7:41 a.m. UTC
When SCRATCH_DEV is not set and the test case does not call
_require_scratch*() before _require_dm_target(), _require_block_device()
called from _require_dm_target() fails to evaluate SCRATCH_DEV and
results in the test case failure. This failure was observed with
generic/628 and generic/629.

To avoid the failures, check SCRATCH_DEV in _require_dm_target(). With
this change, test cases do not need to call _require_scratch*() before
_require_dm_target(). To check SCRATCH_DEV, use simple variable check
instead of _require_scratch*() helper functions, so that each test case
can choose an appropriate function from _require_scratch*().

Signed-off-by: Shin'ichiro Kawasaki <shinichiro.kawasaki@wdc.com>
---
 common/rc | 3 +++
 1 file changed, 3 insertions(+)

Comments

Dave Chinner Sept. 7, 2021, 8:15 a.m. UTC | #1
On Tue, Sep 07, 2021 at 04:41:16PM +0900, Shin'ichiro Kawasaki wrote:
> When SCRATCH_DEV is not set and the test case does not call
> _require_scratch*() before _require_dm_target(), _require_block_device()

That is the bug that needs fixing.

Cheers,

Dave.
Shin'ichiro Kawasaki Sept. 7, 2021, 9:28 a.m. UTC | #2
On Sep 07, 2021 / 18:15, Dave Chinner wrote:
> On Tue, Sep 07, 2021 at 04:41:16PM +0900, Shin'ichiro Kawasaki wrote:
> > When SCRATCH_DEV is not set and the test case does not call
> > _require_scratch*() before _require_dm_target(), _require_block_device()
> 
> That is the bug that needs fixing.

Thanks for the comment. Do you mean the test cases (generic/628 and generic/629)
need fix to call _require_scratch*() before _require_dm_target()? I think that
fix approach will leave the possibility that the newly added test cases in the
future may have the same failure. IMO, the patch posted will be more effective
to prevent the failures.
Dave Chinner Sept. 7, 2021, 10:36 a.m. UTC | #3
On Tue, Sep 07, 2021 at 09:28:44AM +0000, Shinichiro Kawasaki wrote:
> On Sep 07, 2021 / 18:15, Dave Chinner wrote:
> > On Tue, Sep 07, 2021 at 04:41:16PM +0900, Shin'ichiro Kawasaki wrote:
> > > When SCRATCH_DEV is not set and the test case does not call
> > > _require_scratch*() before _require_dm_target(), _require_block_device()
> > 
> > That is the bug that needs fixing.
> 
> Thanks for the comment. Do you mean the test cases (generic/628 and generic/629)
> need fix to call _require_scratch*() before _require_dm_target()? I think that

Yes.

Indeed,  generic/628 does:

_require_dm_target error
_require_scratch_reflink

and g629 does:

_supported_fs generic
_require_dm_target error
_require_xfs_io_command "chattr" "s"
_require_xfs_io_command "copy_range"
_require_scratch

i.e. these two cases are just incorrectly ordered require rules.

Oh, and a quick check of all the dm_target tests:

$ git grep -l _require_dm_target tests/ > t.t
$ git grep -l _require_scratch `cat t.t` > t.tt
$ diff -u t.t t.tt
$

Every test that has require_dm_target rule also has a
_require_scratch rule in it somewhere...

Cheers,

Dave.
Shin'ichiro Kawasaki Sept. 8, 2021, 2:57 a.m. UTC | #4
On Sep 07, 2021 / 20:36, Dave Chinner wrote:
> On Tue, Sep 07, 2021 at 09:28:44AM +0000, Shinichiro Kawasaki wrote:
> > On Sep 07, 2021 / 18:15, Dave Chinner wrote:
> > > On Tue, Sep 07, 2021 at 04:41:16PM +0900, Shin'ichiro Kawasaki wrote:
> > > > When SCRATCH_DEV is not set and the test case does not call
> > > > _require_scratch*() before _require_dm_target(), _require_block_device()
> > > 
> > > That is the bug that needs fixing.
> > 
> > Thanks for the comment. Do you mean the test cases (generic/628 and generic/629)
> > need fix to call _require_scratch*() before _require_dm_target()? I think that
> 
> Yes.
> 
> Indeed,  generic/628 does:
> 
> _require_dm_target error
> _require_scratch_reflink
> 
> and g629 does:
> 
> _supported_fs generic
> _require_dm_target error
> _require_xfs_io_command "chattr" "s"
> _require_xfs_io_command "copy_range"
> _require_scratch
> 
> i.e. these two cases are just incorrectly ordered require rules.
> 
> Oh, and a quick check of all the dm_target tests:
> 
> $ git grep -l _require_dm_target tests/ > t.t
> $ git grep -l _require_scratch `cat t.t` > t.tt
> $ diff -u t.t t.tt
> $
> 
> Every test that has require_dm_target rule also has a
> _require_scratch rule in it somewhere...

Thanks for the clarification. I will repost a patch to fix the order of
_require_scratch* and _require_dm_target in generic/{628,629}.

Regarding the future test cases, I think we can improve error check and error
message in _require_dm_target. I will post another patch for it. Comment on it
will be appreciated also.
diff mbox series

Patch

diff --git a/common/rc b/common/rc
index dda5da06..b4966af7 100644
--- a/common/rc
+++ b/common/rc
@@ -1971,6 +1971,9 @@  _require_dm_target()
 
 	# require SCRATCH_DEV to be a valid block device with sane BLKFLSBUF
 	# behaviour
+	if [ -z "$SCRATCH_DEV" ]; then
+		_notrun "This test requires a valid \$SCRATCH_DEV for dm $target"
+	fi
 	_require_block_device $SCRATCH_DEV
 	_require_sane_bdev_flush $SCRATCH_DEV
 	_require_command "$DMSETUP_PROG" dmsetup