Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src test makecn/freecn



details:   https://anonhg.NetBSD.org/src/rev/4c56095c76f8
branches:  trunk
changeset: 759157:4c56095c76f8
user:      pooka <pooka%NetBSD.org@localhost>
date:      Tue Nov 30 16:16:33 2010 +0000

description:
test makecn/freecn

diffstat:

 distrib/sets/lists/tests/mi   |   4 +-
 tests/rump/rumpvfs/Makefile   |   3 +-
 tests/rump/rumpvfs/t_p2kifs.c |  94 +++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 99 insertions(+), 2 deletions(-)

diffs (139 lines):

diff -r 8ba6af563fed -r 4c56095c76f8 distrib/sets/lists/tests/mi
--- a/distrib/sets/lists/tests/mi       Tue Nov 30 16:05:55 2010 +0000
+++ b/distrib/sets/lists/tests/mi       Tue Nov 30 16:16:33 2010 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.161 2010/11/29 19:29:47 njoly Exp $
+# $NetBSD: mi,v 1.162 2010/11/30 16:16:33 pooka Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 #
@@ -411,6 +411,7 @@
 ./usr/libdata/debug/usr/tests/rump/rumpkern/t_vm.debug                 tests-syscall-debug     debug,atf
 ./usr/libdata/debug/usr/tests/rump/rumpvfs                             tests-syscall-debug
 ./usr/libdata/debug/usr/tests/rump/rumpvfs/t_etfs.debug                tests-syscall-debug     debug,atf
+./usr/libdata/debug/usr/tests/rump/rumpvfs/t_p2kifs.debug              tests-syscall-debug     debug,atf
 ./usr/libdata/debug/usr/tests/syscall                                  tests-syscall-debug
 ./usr/libdata/debug/usr/tests/syscall/t_cmsg.debug                     tests-syscall-debug     debug,atf
 ./usr/libdata/debug/usr/tests/syscall/t_timer.debug                    tests-syscall-debug     debug,atf
@@ -1638,6 +1639,7 @@
 ./usr/tests/rump/rumpvfs                       tests-rump-tests
 ./usr/tests/rump/rumpvfs/Atffile               tests-rump-tests        atf
 ./usr/tests/rump/rumpvfs/t_etfs                tests-rump-tests        atf
+./usr/tests/rump/rumpvfs/t_p2kifs              tests-rump-tests        atf
 ./usr/tests/sys                                tests-sys-tests
 ./usr/tests/sys/Atffile                        tests-sys-tests atf
 ./usr/tests/sys/rc                             tests-sys-tests
diff -r 8ba6af563fed -r 4c56095c76f8 tests/rump/rumpvfs/Makefile
--- a/tests/rump/rumpvfs/Makefile       Tue Nov 30 16:05:55 2010 +0000
+++ b/tests/rump/rumpvfs/Makefile       Tue Nov 30 16:16:33 2010 +0000
@@ -1,10 +1,11 @@
-# $NetBSD: Makefile,v 1.1 2010/06/16 19:29:33 pooka Exp $
+# $NetBSD: Makefile,v 1.2 2010/11/30 16:16:33 pooka Exp $
 
 .include <bsd.own.mk>
 
 TESTSDIR=      ${TESTSBASE}/rump/rumpvfs
 
 TESTS_C=       t_etfs
+TESTS_C+=      t_p2kifs
 
 LDADD= -lrumpvfs -lrump -lrumpuser -lpthread
 
diff -r 8ba6af563fed -r 4c56095c76f8 tests/rump/rumpvfs/t_p2kifs.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/rump/rumpvfs/t_p2kifs.c     Tue Nov 30 16:16:33 2010 +0000
@@ -0,0 +1,94 @@
+/*     $NetBSD: t_p2kifs.c,v 1.1 2010/11/30 16:16:33 pooka Exp $       */
+
+/*-
+ * Copyright (c) 2010 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND
+ * CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
+ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
+ * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
+ * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <sys/types.h>
+#include <sys/mount.h>
+#include <sys/sysctl.h>
+
+#include <rump/rump.h>
+#include <rump/rump_syscalls.h>
+
+#include <atf-c.h>
+#include <fcntl.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+
+#include "../../h_macros.h"
+
+ATF_TC(makecn);
+ATF_TC_HEAD(makecn, tc)
+{
+
+       atf_tc_set_md_var(tc, "descr", "Tests makecn/LOOKUP/freecn");
+}
+
+#define TESTFILE "testi"
+
+ATF_TC_BODY(makecn, tc)
+{
+       struct componentname *cn;
+       char pathstr[] = TESTFILE;
+       struct vnode *vp;
+       extern struct vnode *rumpns_rootvnode;
+
+       rump_init();
+
+       /*
+        * Strategy is to create a componentname, edit the passed
+        * string, and then do a lookup with the componentname.
+        */
+       RL(rump_sys_mkdir("/" TESTFILE, 0777));
+
+       /* need stable lwp for componentname */
+       RZ(rump_pub_lwproc_newproc());
+
+       /* try it once with the right path */
+       cn = rump_pub_makecn(RUMP_NAMEI_LOOKUP, 0, pathstr, strlen(pathstr),
+           rump_pub_cred_create(0, 0, 0, NULL), rump_pub_lwproc_curlwp());
+       RZ(RUMP_VOP_LOOKUP(rumpns_rootvnode, &vp, cn));
+       RUMP_VOP_UNLOCK(vp);
+       rump_pub_freecn(cn, RUMPCN_FREECRED);
+
+       /* and then with modification-in-the-middle */
+       cn = rump_pub_makecn(RUMP_NAMEI_LOOKUP, 0, pathstr, strlen(pathstr),
+           rump_pub_cred_create(0, 0, 0, NULL), rump_pub_lwproc_curlwp());
+       strcpy(pathstr, "/muuta");
+       RZ(RUMP_VOP_LOOKUP(rumpns_rootvnode, &vp, cn));
+       RUMP_VOP_UNLOCK(vp);
+       rump_pub_freecn(cn, RUMPCN_FREECRED);
+}
+
+ATF_TP_ADD_TCS(tp)
+{
+
+       ATF_TP_ADD_TC(tp, makecn);
+
+       return atf_no_error();
+}



Home | Main Index | Thread Index | Old Index