From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-13.7 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,UNPARSEABLE_RELAY,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id DC961C63697 for ; Mon, 23 Nov 2020 16:23:57 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 810BD2080A for ; Mon, 23 Nov 2020 16:23:57 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730919AbgKWQX4 convert rfc822-to-8bit (ORCPT ); Mon, 23 Nov 2020 11:23:56 -0500 Received: from mx2.suse.de ([195.135.220.15]:46298 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729881AbgKWQX4 (ORCPT ); Mon, 23 Nov 2020 11:23:56 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 85411AD72; Mon, 23 Nov 2020 16:23:54 +0000 (UTC) Received: from localhost (brahms [local]) by brahms (OpenSMTPD) with ESMTPA id 4d697700; Mon, 23 Nov 2020 16:24:10 +0000 (UTC) From: Luis Henriques To: Jeff Layton Cc: Eryu Guan , fstests@vger.kernel.org, ceph-devel@vger.kernel.org Subject: Re: [PATCH v2] ceph: add a new test for cross quota realms renames References: <87sg90s8el.fsf@suse.de> <20201123103439.27908-1-lhenriques@suse.de> <87im9wrv5p.fsf@suse.de> <592a539905ba13d26bd12d8fa74cc4942b68c8ea.camel@kernel.org> Date: Mon, 23 Nov 2020 16:24:10 +0000 In-Reply-To: <592a539905ba13d26bd12d8fa74cc4942b68c8ea.camel@kernel.org> (Jeff Layton's message of "Mon, 23 Nov 2020 10:39:05 -0500") Message-ID: <87eekkrqhh.fsf@suse.de> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8BIT Precedence: bulk List-ID: X-Mailing-List: fstests@vger.kernel.org Jeff Layton writes: > On Mon, 2020-11-23 at 14:43 +0000, Luis Henriques wrote: >> Jeff Layton writes: >> >> > On Mon, 2020-11-23 at 10:34 +0000, Luis Henriques wrote: >> > > For the moment cross quota realms renames has been disabled in CephFS >> > > after a bug has been found while renaming files created and truncated. >> > > This allowed clients to easily circumvent quotas. >> > > >> > > Link: https://tracker.ceph.com/issues/48203 >> > > Signed-off-by: Luis Henriques >> > > --- >> > > v2: implemented Eryu review comments: >> > > - Added _require_test_program "rename" >> > > - Use _fail instead of _fatal >> > > >> > >  tests/ceph/004 | 95 ++++++++++++++++++++++++++++++++++++++++++++++ >> > >  tests/ceph/004.out | 2 + >> > >  tests/ceph/group | 1 + >> > >  3 files changed, 98 insertions(+) >> > >  create mode 100755 tests/ceph/004 >> > >  create mode 100644 tests/ceph/004.out >> > > >> > > diff --git a/tests/ceph/004 b/tests/ceph/004 >> > > new file mode 100755 >> > > index 000000000000..53094d8dfadc >> > > --- /dev/null >> > > +++ b/tests/ceph/004 >> > > @@ -0,0 +1,95 @@ >> > > +#! /bin/bash >> > > +# SPDX-License-Identifier: GPL-2.0 >> > > +# Copyright (c) 2020 SUSE Linux Products GmbH. All Rights Reserved. >> > > +# >> > > +# FS QA Test 004 >> > > +# >> > > +# Tests a bug fix found in cephfs quotas handling. Here's a simplified testcase >> > > +# that *should* fail: >> > > +# >> > > +# mkdir files limit >> > > +# truncate files/file -s 10G >> > > +# setfattr limit -n ceph.quota.max_bytes -v 1000000 >> > > +# mv files limit/ >> > > +# >> > > +# Because we're creating a new file and truncating it, we have Fx caps and thus >> > > +# the truncate operation will be cached. This prevents the MDSs from updating >> > > +# the quota realms and thus the client will allow the above rename(2) to happen. >> > > +# >> > >> > Note that it can be difficult to predict which caps you get from the >> > MDS. It's not _required_ to pass out anything like Fx if it doesn't want >> > to, but in general, it does if it can. >> > >> > It's not a blocker for merging this test, but I wonder if we ought to >> > come up with some way to ensure that the client was given the caps we >> > expect when testing stuff like this. >> > >> > Maybe we ought to consider adding a new ceph.caps vxattr that shows the >> > caps we hold for a particular file? Then we could consult that when >> > doing a test like this to make sure we got what we expected. >> >> Sure, I can hack a patch for doing that and send it out for review. >> That's actually trivial, I believe. >> >> This test assumes the caps for the truncated file will be 'Fsxcrwb' but I >> didn't confirm with the MDS which conditions are actually required for >> this to happen. Also, I guess that if the test is executed with several >> clients, these caps may change pretty quickly (and maybe even with a >> single very slow client with a very short caps timeout). >> >> Obviously, ensuring the client has the caps we expect at the time we do >> the actual rename is racy and they can change in the meantime. Is it >> worth the trouble? > > > I think it's useful. Cap/mds lock handling is an area where we have > really poor visibility in cephfs. > > a/ It's not always 100% clear what metadata is under which cap. > Sometimes it's really weird. For example, you need Fs to get the link > count on a directory -- Ls has no meaning there, which is not intuitive > at all. > > b/ Subtle changes in the MDS or client can affect what caps are granted > or revoked in a given situation. > > Having better visibility into the caps held by the client is potentially > very useful for troubleshooting _why_ certain tests might fail, and may > also help us catch subtle changes that prevent problems in the future. Sure, I completely agree with this. My question was more about adding an extra check to the test. Basically, the new test will be something like: (0. ensure 'getfattr -n ceph.caps' works; skip test if it doesn't) 1. truncate file 2. check that file caps includes Fsxcrwb 3. do the rename I'll send out v3 if that's what you had in mind. Cheers, -- Luis