C++程序  |  144行  |  3.75 KB

/*
 * Crackerjack Project
 *
 * Copyright (C) 2007-2008, Hitachi, Ltd.
 * Author(s): Takahiro Yasui <takahiro.yasui.mp@hitachi.com>,
 *            Yumiko Sugita <yumiko.sugita.yf@hitachi.com>,
 *            Satoshi Fujiwara <sa-fuji@sdl.hitachi.co.jp>
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 *
 * $Id: include_j_h.h,v 1.2 2009/09/27 17:34:22 subrata_modak Exp $
 *
 */
#ifndef __CJK_SYSCALL_J_H__
#define __CJK_SYSCALL_J_H__

#include <sys/time.h>
#include <sys/resource.h>


#define REG_RESULT_LOG_FP	stdout
#define REG_DETAIL_LOG_FP	stderr


/*
 * RPRINTF : macro to output test result
 */
#define RPRINTF(...)						\
	do {							\
		fprintf(REG_RESULT_LOG_FP, __VA_ARGS__);	\
	} while (0)


/*
 * PRINTF : macro to output detail log
 */
#define PRINTF(...)						\
	do {							\
		fprintf(REG_DETAIL_LOG_FP, __VA_ARGS__);	\
	} while (0)


/*
 * EPRINTF : macro to output error message
 */
#define EPRINTF(...)						\
	do {							\
		fprintf(REG_DETAIL_LOG_FP, __VA_ARGS__);	\
	} while (0)

/*
 * PRINT_XXX : macro to output test result and expect
 */
#define __PRINT_EXPECT(rc_has_range, rc, errno)				\
	do {								\
		if (rc_has_range)					\
			PRINTF("EXPECT: return value(ret)=%s",		\
			       (rc) >= 0 ? "(N >= 0)" : "(N <  0)");	\
		else							\
			PRINTF("EXPECT: return value(ret)=%d", rc);	\
		PRINTF(" errno=%d (%s)", errno, strerror(errno));	\
	} while (0)

#define __PRINT_RESULT(rc_has_range, rc, errno)				\
	do {								\
		if (rc_has_range)					\
			PRINTF("RESULT: return value(ret)=%8d", rc);	\
		else							\
			PRINTF("RESULT: return value(ret)=%d", rc);	\
		PRINTF(" errno=%d (%s)", errno, strerror(errno));	\
	} while (0)

#define PRINT_RESULT(rc_has_range, e_rc, e_errno, r_rc, r_errno)	\
	do {								\
		__PRINT_EXPECT(rc_has_range, e_rc, e_errno);		\
		PRINTF("\n");						\
		__PRINT_RESULT(rc_has_range, r_rc, r_errno);		\
		PRINTF("\n");						\
	} while (0)

#define PRINT_RESULT_EXTRA(rc_has_range, e_rc, e_errno, r_rc, r_errno,	\
			   str, extra_ok)				\
	do {								\
		__PRINT_EXPECT(rc_has_range, e_rc, e_errno);		\
		if ((extra_ok))						\
			PRINTF("\n");					\
		else							\
			PRINTF(", %s=OK\n", str);			\
		__PRINT_RESULT(rc_has_range, r_rc, r_errno);		\
		if ((extra_ok))						\
			PRINTF("\n");					\
		else							\
			PRINTF(", %s=NG\n", str);			\
	} while (0)

#define PRINT_RESULT_CMP(rc_has_range, e_rc, e_errno, r_rc, r_errno, cmp_ok) \
	PRINT_RESULT_EXTRA(rc_has_range, e_rc, e_errno, r_rc, r_errno,	\
			   "r/w check", cmp_ok)


/*
 * Definitions
 */
enum result_val {
	RESULT_OK,
	RESULT_NG
};


/*
 * Prototype
 */
int setup_uid(char *uname);
int setup_euid(char *uname, uid_t *old_uid);
int cleanup_euid(uid_t old_uid);

pid_t create_sig_proc(unsigned long usec, int sig, unsigned count);

int _setup_file(char *testdir, char *fname, char *path, int flags, mode_t mode);
int setup_file(char *testdir, char *fname, char *path);
int cleanup_file(char *path);

int setup_swapfile(char *testdir, char *fname, char *path, size_t size);
int cleanup_swapfile(char *path);

#define QUEUE_NAME	"/test_mqueue"
pid_t create_echo_msg_proc(void);

pid_t get_unexist_pid(void);

#endif /* __CJK_SYSCALL_J_H__ */