From patchwork Fri May 13 06:39:38 2011 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Brian Chrisman X-Patchwork-Id: 781802 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by demeter1.kernel.org (8.14.4/8.14.3) with ESMTP id p4D6dxfE027595 for ; Fri, 13 May 2011 06:40:00 GMT Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756515Ab1EMGj6 (ORCPT ); Fri, 13 May 2011 02:39:58 -0400 Received: from mail-pz0-f46.google.com ([209.85.210.46]:54628 "EHLO mail-pz0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756159Ab1EMGj5 (ORCPT ); Fri, 13 May 2011 02:39:57 -0400 Received: by mail-pz0-f46.google.com with SMTP id 9so1043834pzk.19 for ; Thu, 12 May 2011 23:39:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:from:to:cc:subject:date:message-id:x-mailer :in-reply-to:references; bh=HvFnuEFu/m3PmSxXf0ZySeVevbGG6nDKyOvZQxpujyw=; b=MwhZCQlq2UJ73heJbLHiRLLDHBYe9u7daUJFg2UKs6lTu0e3gZ1XpMKkuWYtSfd5wa l5iKJYMEL2xJBCG+j1l8hkPQazbjuIJ7NsSXiDHAgJF9kUy+27KrTI+gZ0CkNJYFbB1p D5g6tsXRxz/wd7Ih8YUhc7g5z1MwMtu9yKADk= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=from:to:cc:subject:date:message-id:x-mailer:in-reply-to:references; b=ttOEnor7q6BDdQbtHQzIFoFVQd4VnfqjNGbyzVDdZ5GtqqUbQExynxsmWxISZCnGOE urQNahTGo/sfDX3HFbNFnLGhpMYybHja/SCOPN7Mj3IaIuXgsyHGVHDby53BjSr3cKZY mXHjCqoqAPCcAOjef/vOrOEZki9EcRrR61ql8= Received: by 10.68.55.7 with SMTP id n7mr1659393pbp.218.1305268797113; Thu, 12 May 2011 23:39:57 -0700 (PDT) Received: from localhost.localdomain (70-35-37-146.static.wiline.com [70.35.37.146]) by mx.google.com with ESMTPS id t7sm1168194pbj.63.2011.05.12.23.39.55 (version=TLSv1/SSLv3 cipher=OTHER); Thu, 12 May 2011 23:39:56 -0700 (PDT) From: Brian Chrisman To: ceph-devel@vger.kernel.org Cc: Brian Chrisman Subject: [PATCH 2/2] add basic test case for readdir_r Date: Thu, 12 May 2011 23:39:38 -0700 Message-Id: <1305268778-18691-3-git-send-email-brchrisman@gmail.com> X-Mailer: git-send-email 1.7.1 In-Reply-To: <1305268778-18691-1-git-send-email-brchrisman@gmail.com> References: <1305268778-18691-1-git-send-email-brchrisman@gmail.com> Sender: ceph-devel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: ceph-devel@vger.kernel.org X-Greylist: IP, sender and recipient auto-whitelisted, not delayed by milter-greylist-4.2.6 (demeter1.kernel.org [140.211.167.41]); Fri, 13 May 2011 06:40:00 +0000 (UTC) Signed-off-by: Brian Chrisman --- src/client/testceph.cc | 36 +++++++++++++++++++++++++++++++++++- 1 files changed, 35 insertions(+), 1 deletions(-) diff --git a/src/client/testceph.cc b/src/client/testceph.cc index 520fa75..c24cc03 100644 --- a/src/client/testceph.cc +++ b/src/client/testceph.cc @@ -17,6 +17,7 @@ #include #include +#include #include #include #include @@ -190,8 +191,41 @@ int main(int argc, const char **argv) } else { cout << "ceph_lstat: success" << std::endl; } + cout << "Attempting readdir_r" << std::endl; + ret = ceph_mkdir(cmount, "readdir_r_test", 0777); + if (ret) { + cerr << "ceph_mkdir error: " << cpp_strerror(ret) << std::endl; + return 1; + } else { + cout << "ceph_mkdir: success" << std::endl; + } + struct ceph_dir_result *readdir_r_test_dir; + ret = ceph_opendir(cmount, "readdir_r_test", &readdir_r_test_dir); + if (ret != 0) { + cerr << "ceph_opendir error: unexpected result from trying to open readdir_r_test: " + << cpp_strerror(ret) << std::endl; + return 1; + } else { + cout << "ceph_opendir: success" << std::endl; + } + ret = ceph_open(cmount, "readdir_r_test/opened_file", O_CREAT, 0666); + if (ret < 0) { + cerr << "ceph_open O_CREAT error: " << cpp_strerror(ret) << std::endl; + return 1; + } else { + cout << "ceph_open: success" << std::endl; + } - + struct dirent * result; + result = (struct dirent *) malloc(sizeof(struct dirent)); + ret = ceph_readdir_r(cmount, readdir_r_test_dir, result); + if (ret != 0) { + cerr << "ceph_readdir_r: fail, returned: " << ret << std::endl; + } else { + cerr << "ceph_readdir_r: success: " << *result->d_name << std::endl; + return 1; + } + ceph_shutdown(cmount); return 0;