xref: /freebsd/contrib/netbsd-tests/fs/kernfs/t_basic.c (revision 1a36faad54665288ed4eb839d2a4699ae2ead45e)
1*63d1fd59SEnji Cooper /*	$NetBSD: t_basic.c,v 1.4 2017/01/13 21:30:40 christos Exp $	*/
257718be8SEnji Cooper 
357718be8SEnji Cooper #include <sys/types.h>
457718be8SEnji Cooper #include <sys/mount.h>
557718be8SEnji Cooper #include <sys/module.h>
657718be8SEnji Cooper #include <sys/dirent.h>
757718be8SEnji Cooper #include <sys/sysctl.h>
857718be8SEnji Cooper 
957718be8SEnji Cooper #include <atf-c.h>
1057718be8SEnji Cooper #include <err.h>
1157718be8SEnji Cooper #include <errno.h>
1257718be8SEnji Cooper #include <fcntl.h>
1357718be8SEnji Cooper #include <stdio.h>
1457718be8SEnji Cooper #include <unistd.h>
1557718be8SEnji Cooper #include <string.h>
1657718be8SEnji Cooper #include <stdlib.h>
1757718be8SEnji Cooper 
1857718be8SEnji Cooper #include <rump/rump.h>
1957718be8SEnji Cooper #include <rump/rump_syscalls.h>
2057718be8SEnji Cooper 
2157718be8SEnji Cooper #include <miscfs/kernfs/kernfs.h>
2257718be8SEnji Cooper 
23*63d1fd59SEnji Cooper #include "h_macros.h"
2457718be8SEnji Cooper 
2557718be8SEnji Cooper ATF_TC(getdents);
ATF_TC_HEAD(getdents,tc)2657718be8SEnji Cooper ATF_TC_HEAD(getdents, tc)
2757718be8SEnji Cooper {
2857718be8SEnji Cooper 
2957718be8SEnji Cooper 	atf_tc_set_md_var(tc, "descr", "kernfs directory contains files");
3057718be8SEnji Cooper }
3157718be8SEnji Cooper 
3257718be8SEnji Cooper static void
mountkernfs(void)3357718be8SEnji Cooper mountkernfs(void)
3457718be8SEnji Cooper {
3557718be8SEnji Cooper 
3657718be8SEnji Cooper 	rump_init();
3757718be8SEnji Cooper 
3857718be8SEnji Cooper 	if (rump_sys_mkdir("/kern", 0777) == -1)
3957718be8SEnji Cooper 		atf_tc_fail_errno("mkdir /kern");
4057718be8SEnji Cooper 	if (rump_sys_mount(MOUNT_KERNFS, "/kern", 0, NULL, 0) == -1)
4157718be8SEnji Cooper 		atf_tc_fail_errno("could not mount kernfs");
4257718be8SEnji Cooper }
4357718be8SEnji Cooper 
ATF_TC_BODY(getdents,tc)4457718be8SEnji Cooper ATF_TC_BODY(getdents, tc)
4557718be8SEnji Cooper {
4657718be8SEnji Cooper 	struct dirent *dent;
4757718be8SEnji Cooper 	char buf[8192];
4857718be8SEnji Cooper 	int dfd;
4957718be8SEnji Cooper 
5057718be8SEnji Cooper 	mountkernfs();
5157718be8SEnji Cooper 
5257718be8SEnji Cooper 	if ((dfd = rump_sys_open("/kern", O_RDONLY)) == -1)
5357718be8SEnji Cooper 		atf_tc_fail_errno("can't open directory");
5457718be8SEnji Cooper 	if (rump_sys_getdents(dfd, buf, sizeof(buf)) == -1)
5557718be8SEnji Cooper 		atf_tc_fail_errno("getdents");
5657718be8SEnji Cooper 
5757718be8SEnji Cooper 	/*
5857718be8SEnji Cooper 	 * Check that we get the first three values (., .., boottime).
5957718be8SEnji Cooper 	 * Make more complete by autogenerating list from kernfs_vnops.c?
6057718be8SEnji Cooper 	 */
6157718be8SEnji Cooper 	dent = (void *)buf;
6257718be8SEnji Cooper 	ATF_REQUIRE_STREQ(dent->d_name, ".");
6357718be8SEnji Cooper 	dent = _DIRENT_NEXT(dent);
6457718be8SEnji Cooper 	ATF_REQUIRE_STREQ(dent->d_name, "..");
6557718be8SEnji Cooper 	dent = _DIRENT_NEXT(dent);
6657718be8SEnji Cooper 	ATF_REQUIRE_STREQ(dent->d_name, "boottime");
6757718be8SEnji Cooper 
6857718be8SEnji Cooper 	/* done */
6957718be8SEnji Cooper }
7057718be8SEnji Cooper 
7157718be8SEnji Cooper ATF_TC(hostname);
ATF_TC_HEAD(hostname,tc)7257718be8SEnji Cooper ATF_TC_HEAD(hostname, tc)
7357718be8SEnji Cooper {
7457718be8SEnji Cooper 
7557718be8SEnji Cooper 	atf_tc_set_md_var(tc, "descr", "/kern/hostname changes hostname");
7657718be8SEnji Cooper }
7757718be8SEnji Cooper 
7857718be8SEnji Cooper static char *
getthehost(void)7957718be8SEnji Cooper getthehost(void)
8057718be8SEnji Cooper {
8157718be8SEnji Cooper 	static char buf[8192];
8257718be8SEnji Cooper 	int mib[2];
8357718be8SEnji Cooper 	size_t blen;
8457718be8SEnji Cooper 
8557718be8SEnji Cooper 	mib[0] = CTL_KERN;
8657718be8SEnji Cooper 	mib[1] = KERN_HOSTNAME;
8757718be8SEnji Cooper 	blen = sizeof(buf);
8857718be8SEnji Cooper 	if (rump_sys___sysctl(mib, 2, buf, &blen, NULL, 0) == -1)
8957718be8SEnji Cooper 		atf_tc_fail_errno("sysctl gethostname");
9057718be8SEnji Cooper 
9157718be8SEnji Cooper 	return buf;
9257718be8SEnji Cooper }
9357718be8SEnji Cooper 
9457718be8SEnji Cooper #define NEWHOSTNAME "turboton roos-berg"
ATF_TC_BODY(hostname,tc)9557718be8SEnji Cooper ATF_TC_BODY(hostname, tc)
9657718be8SEnji Cooper {
9757718be8SEnji Cooper 	char buf[8192];
9857718be8SEnji Cooper 	char *shost, *p;
9957718be8SEnji Cooper 	int fd;
10057718be8SEnji Cooper 
10157718be8SEnji Cooper 	mountkernfs();
10257718be8SEnji Cooper 	if ((fd = rump_sys_open("/kern/hostname", O_RDWR)) == -1)
10357718be8SEnji Cooper 		atf_tc_fail_errno("open hostname");
10457718be8SEnji Cooper 
10557718be8SEnji Cooper 	/* check initial match */
10657718be8SEnji Cooper 	shost = getthehost();
10757718be8SEnji Cooper 	buf[0] = '\0';
10857718be8SEnji Cooper 	if (rump_sys_read(fd, buf, sizeof(buf)) == -1)
10957718be8SEnji Cooper 		atf_tc_fail_errno("read hostname");
11057718be8SEnji Cooper 	p = strchr(buf, '\n');
11157718be8SEnji Cooper 	if (p)
11257718be8SEnji Cooper 		 *p = '\0';
11357718be8SEnji Cooper 	ATF_REQUIRE_STREQ_MSG(buf, shost, "initial hostname mismatch");
11457718be8SEnji Cooper 
11557718be8SEnji Cooper 	/* check changing hostname works */
11657718be8SEnji Cooper 	if (rump_sys_pwrite(fd, NEWHOSTNAME, strlen(NEWHOSTNAME), 0)
11757718be8SEnji Cooper 	    != strlen(NEWHOSTNAME)) {
11857718be8SEnji Cooper 		atf_tc_fail_errno("write new hostname");
11957718be8SEnji Cooper 	}
12057718be8SEnji Cooper 
12157718be8SEnji Cooper 	shost = getthehost();
12257718be8SEnji Cooper 	ATF_REQUIRE_STREQ_MSG(NEWHOSTNAME, shost, "modified hostname mismatch");
12357718be8SEnji Cooper 
12457718be8SEnji Cooper 	/* done */
12557718be8SEnji Cooper }
12657718be8SEnji Cooper 
ATF_TP_ADD_TCS(tp)12757718be8SEnji Cooper ATF_TP_ADD_TCS(tp)
12857718be8SEnji Cooper {
12957718be8SEnji Cooper 	ATF_TP_ADD_TC(tp, hostname);
13057718be8SEnji Cooper 	ATF_TP_ADD_TC(tp, getdents);
13157718be8SEnji Cooper 
13257718be8SEnji Cooper 	return atf_no_error();
13357718be8SEnji Cooper }
134