xref: /xnu-11215.81.4/tests/xnu_quick_test.c (revision d4514f0bc1d3f944c22d92e68b646ac3fb40d452)
1*d4514f0bSApple OSS Distributions #include <darwintest.h>
2*d4514f0bSApple OSS Distributions #include "xnu_quick_test_helpers.h"
3*d4514f0bSApple OSS Distributions 
4*d4514f0bSApple OSS Distributions #include <fcntl.h>
5*d4514f0bSApple OSS Distributions #include <stdlib.h>
6*d4514f0bSApple OSS Distributions #include <unistd.h>
7*d4514f0bSApple OSS Distributions #include <mach/mach.h>
8*d4514f0bSApple OSS Distributions #include <sys/stat.h>
9*d4514f0bSApple OSS Distributions #include <sys/syscall.h>
10*d4514f0bSApple OSS Distributions #include <sys/sysctl.h>
11*d4514f0bSApple OSS Distributions #include <sys/wait.h>
12*d4514f0bSApple OSS Distributions 
13*d4514f0bSApple OSS Distributions T_GLOBAL_META(
14*d4514f0bSApple OSS Distributions 	T_META_NAMESPACE("xnu.quicktest"),
15*d4514f0bSApple OSS Distributions 	T_META_CHECK_LEAKS(false),
16*d4514f0bSApple OSS Distributions 	T_META_RUN_CONCURRENTLY(true)
17*d4514f0bSApple OSS Distributions 	);
18*d4514f0bSApple OSS Distributions 
19*d4514f0bSApple OSS Distributions char g_target_path[PATH_MAX];
20*d4514f0bSApple OSS Distributions 
21*d4514f0bSApple OSS Distributions T_DECL(syscall, "xnu_quick_test for syscall", T_META_TAG_VM_NOT_PREFERRED)
22*d4514f0bSApple OSS Distributions {
23*d4514f0bSApple OSS Distributions 	int                             my_fd = -1;
24*d4514f0bSApple OSS Distributions 	char *                  my_pathp;
25*d4514f0bSApple OSS Distributions 	kern_return_t   my_kr;
26*d4514f0bSApple OSS Distributions 
27*d4514f0bSApple OSS Distributions 	T_SETUPBEGIN;
28*d4514f0bSApple OSS Distributions 
29*d4514f0bSApple OSS Distributions 	create_target_directory(TEST_DIRECTORY);
30*d4514f0bSApple OSS Distributions 
31*d4514f0bSApple OSS Distributions 	T_SETUPEND;
32*d4514f0bSApple OSS Distributions 
33*d4514f0bSApple OSS Distributions 	my_kr = vm_allocate((vm_map_t) mach_task_self(), (vm_address_t*)&my_pathp,
34*d4514f0bSApple OSS Distributions 	    PATH_MAX, VM_FLAGS_ANYWHERE);
35*d4514f0bSApple OSS Distributions 	T_ASSERT_MACH_SUCCESS(my_kr, "Allocating vm to path %s", my_pathp);
36*d4514f0bSApple OSS Distributions 
37*d4514f0bSApple OSS Distributions 	*my_pathp = 0x00;
38*d4514f0bSApple OSS Distributions 	strcpy( my_pathp, &g_target_path[0] );
39*d4514f0bSApple OSS Distributions 	strcat( my_pathp, "/" );
40*d4514f0bSApple OSS Distributions 
41*d4514f0bSApple OSS Distributions 	/* create a test file */
42*d4514f0bSApple OSS Distributions 
43*d4514f0bSApple OSS Distributions 	T_ASSERT_MACH_SUCCESS( create_random_name( my_pathp, 1), "Create random test file" );
44*d4514f0bSApple OSS Distributions 	/* use an indirect system call to open our test file.
45*d4514f0bSApple OSS Distributions 	 * I picked open since it uses a path pointer which grows to 64 bits in an LP64 environment.
46*d4514f0bSApple OSS Distributions 	 */
47*d4514f0bSApple OSS Distributions 	T_EXPECT_NE(my_fd = syscall( SYS_open, my_pathp, (O_RDWR | O_EXCL), 0 ),
48*d4514f0bSApple OSS Distributions 	    -1, "Attempt to open file using indirect syscall %s", my_pathp);
49*d4514f0bSApple OSS Distributions 
50*d4514f0bSApple OSS Distributions 	if (my_fd != -1) {
51*d4514f0bSApple OSS Distributions 		close(my_fd);
52*d4514f0bSApple OSS Distributions 	}
53*d4514f0bSApple OSS Distributions 
54*d4514f0bSApple OSS Distributions 	if (my_pathp != NULL) {
55*d4514f0bSApple OSS Distributions 		remove(my_pathp);
56*d4514f0bSApple OSS Distributions 		vm_deallocate(mach_task_self(), (vm_address_t)my_pathp, PATH_MAX);
57*d4514f0bSApple OSS Distributions 	}
58*d4514f0bSApple OSS Distributions 
59*d4514f0bSApple OSS Distributions 	T_ATEND(remove_target_directory);
60*d4514f0bSApple OSS Distributions }
61*d4514f0bSApple OSS Distributions 
62*d4514f0bSApple OSS Distributions T_DECL(fork_wait4_exit,
63*d4514f0bSApple OSS Distributions     "Tests forking off a process and waiting for the child to exit", T_META_TAG_VM_NOT_PREFERRED)
64*d4514f0bSApple OSS Distributions {
65*d4514f0bSApple OSS Distributions 	int                             my_err, my_status;
66*d4514f0bSApple OSS Distributions 	pid_t                       my_pid, my_wait_pid;
67*d4514f0bSApple OSS Distributions 	struct rusage   my_usage;
68*d4514f0bSApple OSS Distributions 
69*d4514f0bSApple OSS Distributions 	strncpy(g_target_path, "/", 2);
70*d4514f0bSApple OSS Distributions 
71*d4514f0bSApple OSS Distributions 	/* spin off another process */
72*d4514f0bSApple OSS Distributions 	T_ASSERT_NE(my_pid = fork(), -1, "Fork off a process");
73*d4514f0bSApple OSS Distributions 
74*d4514f0bSApple OSS Distributions 	if (my_pid == 0) {
75*d4514f0bSApple OSS Distributions 		struct stat             my_sb;
76*d4514f0bSApple OSS Distributions 
77*d4514f0bSApple OSS Distributions 		/* child process does very little then exits */
78*d4514f0bSApple OSS Distributions 		my_err = stat( &g_target_path[0], &my_sb );
79*d4514f0bSApple OSS Distributions 		T_WITH_ERRNO;
80*d4514f0bSApple OSS Distributions 		T_ASSERT_TRUE(my_err == 0, "stat call with path: \"%s\" returned \"%d\"", &g_target_path[0], errno);
81*d4514f0bSApple OSS Distributions 		exit( 44 );
82*d4514f0bSApple OSS Distributions 	}
83*d4514f0bSApple OSS Distributions 
84*d4514f0bSApple OSS Distributions 	/* parent process waits for child to exit */
85*d4514f0bSApple OSS Distributions 	T_ASSERT_NE(my_wait_pid = wait4( my_pid, &my_status, 0, &my_usage ), -1,
86*d4514f0bSApple OSS Distributions 	    "Wait for child to exit\n");
87*d4514f0bSApple OSS Distributions 
88*d4514f0bSApple OSS Distributions 	/* wait4 should return our child's pid when it exits */
89*d4514f0bSApple OSS Distributions 	T_ASSERT_EQ(my_wait_pid, my_pid,
90*d4514f0bSApple OSS Distributions 	    "wait4 should return our child's pid when it exits");
91*d4514f0bSApple OSS Distributions 
92*d4514f0bSApple OSS Distributions 	/* kind of just guessing on these values so if this fails we should take a closer
93*d4514f0bSApple OSS Distributions 	 * look at the returned rusage structure.
94*d4514f0bSApple OSS Distributions 	 */
95*d4514f0bSApple OSS Distributions 	T_ASSERT_FALSE((my_usage.ru_utime.tv_sec > 1 ||
96*d4514f0bSApple OSS Distributions 	    my_usage.ru_stime.tv_sec > 1 || my_usage.ru_majflt > 1000 ||
97*d4514f0bSApple OSS Distributions 	    my_usage.ru_msgsnd > 100), "wait4 returned rusage structure");
98*d4514f0bSApple OSS Distributions 
99*d4514f0bSApple OSS Distributions 	T_ASSERT_TRUE((WIFEXITED( my_status ) && WEXITSTATUS( my_status ) == 44),
100*d4514f0bSApple OSS Distributions 	    "check if wait4 returns right exit status");
101*d4514f0bSApple OSS Distributions }
102*d4514f0bSApple OSS Distributions 
103*d4514f0bSApple OSS Distributions T_DECL(getrusage, "check getrusage works", T_META_TAG_VM_NOT_PREFERRED)
104*d4514f0bSApple OSS Distributions {
105*d4514f0bSApple OSS Distributions 	struct rusage rubuf;
106*d4514f0bSApple OSS Distributions 
107*d4514f0bSApple OSS Distributions 	int ret = getrusage(RUSAGE_SELF, &rubuf);
108*d4514f0bSApple OSS Distributions 	T_ASSERT_POSIX_SUCCESS(ret, "getrusage for self");
109*d4514f0bSApple OSS Distributions 
110*d4514f0bSApple OSS Distributions 	T_EXPECT_LT(rubuf.ru_msgrcv, 1000, "upper bound on messages received");
111*d4514f0bSApple OSS Distributions 	T_EXPECT_GE(rubuf.ru_msgrcv, 0, "lower bound on messages reseived");
112*d4514f0bSApple OSS Distributions 	T_EXPECT_LT(rubuf.ru_nsignals, 1000, "upper bound on signals");
113*d4514f0bSApple OSS Distributions 	T_EXPECT_GE(rubuf.ru_nsignals, 0, "lower bound on signals");
114*d4514f0bSApple OSS Distributions }
115