Top | ![]() |
![]() |
![]() |
![]() |
If your test target supports multi-process and/or multi-thread, you need to test them. You can use CutSubProcess and CutSubProcessGroup to do it.
CutSubProcess runs your test on another process and forwards results of it to a test on your main process. You will get results of test on another process as results of test on your main process.
CutSubProcessGroup is a convenience object to run some CutSubProcess.
CutSubProcess *
cut_take_new_sub_process (const char *test_directory
);
Creates sub cutter process that runs tests under
test_directory
and returns it. A created sub process
is owned by Cutter.
Since 1.0.4
cut_boolean
cut_sub_process_run (CutSubProcess *sub_process
);
Runs sub cutter process.
Since 1.0.4
void
cut_sub_process_run_async (CutSubProcess *sub_process
);
Runs sub cutter process asynchronously. The result of
sub_process
can be gotten by cut_sub_process_wait()
.
Since 1.0.4
cut_boolean
cut_sub_process_wait (CutSubProcess *sub_process
);
Waits for sub cutter process that is ran asynchronously to complete and returns the result.
Since 1.0.4
cut_boolean
cut_sub_process_is_success (CutSubProcess *sub_process
);
Returns whether sub_process
is completed successfully or
not.
Since 1.0.4
cut_boolean
cut_sub_process_is_running (CutSubProcess *sub_process
);
Returns whether sub_process
is running or not.
Since 1.0.4
const char *
cut_sub_process_get_test_directory (CutSubProcess *sub_process
);
Returns a test directory that has tests to be ran.
Since 1.0.4
void cut_sub_process_set_test_directory (CutSubProcess *sub_process
,const char *test_directory
);
Sets test_directory
as a test directory that has tests
to be ran. This is same as TEST_DIRECTORY required
command line argument.
Since 1.0.4
const char *
cut_sub_process_get_source_directory (CutSubProcess *sub_process
);
Returns a source directory that has source files.
Since 1.0.4
void cut_sub_process_set_source_directory (CutSubProcess *sub_process
,const char *source_directory
);
Sets source_directory
as a source directory that has
source files. This is same as --source-directory command
line option.
Since 1.0.4
cut_boolean
cut_sub_process_get_multi_thread (CutSubProcess *sub_process
);
Returns whether sub_process
is ran in multi-thread mode.
Since 1.0.4
void cut_sub_process_set_multi_thread (CutSubProcess *sub_process
,cut_boolean multi_thread
);
Sets whether sub_process
is ran in multi-thread mode or
not. This is same as --multi-thread command line option.
Since 1.0.4
int
cut_sub_process_get_max_threads (CutSubProcess *sub_process
);
Returns how many threads are used concurrently at a
maximum in sub_process
.
Since 1.0.5
void cut_sub_process_set_max_threads (CutSubProcess *sub_process
,int max_threads
);
Sets how many threads are used concurrently at a
maximum in sub_process
. -1 means no limit. This is same
as --max-threads command line option.
Since 1.0.5
const char **
cut_sub_process_get_exclude_files (CutSubProcess *sub_process
);
Returns file names that are excluded from target test files.
Since 1.0.4
void cut_sub_process_set_exclude_files (CutSubProcess *sub_process
,const char **files
);
Sets file names that are excluded from target test files. This is same as --exclude-file command line option.
Since 1.0.4
const char **
cut_sub_process_get_exclude_directories
(CutSubProcess *sub_process
);
Returns directory names that are excluded from target test directories.
Since 1.0.4
void cut_sub_process_set_exclude_directories (CutSubProcess *sub_process
,const char **directories
);
Sets directory names that are excluded from target test directories. This is same as --exclude-directory command line option.
Since 1.0.4
const char **
cut_sub_process_get_target_test_case_names
(CutSubProcess *sub_process
);
Returns test case names that are ran.
Since 1.0.4
void cut_sub_process_set_target_test_case_names (CutSubProcess *sub_process
,const char **names
);
Sets test case names that are ran. This is same as --test-case command line option.
Since 1.0.4
const char **
cut_sub_process_get_target_test_names (CutSubProcess *sub_process
);
Returns test names that are ran.
Since 1.0.4
void cut_sub_process_set_target_test_names (CutSubProcess *sub_process
,const char **names
);
Sets test names that are ran. This is same as --test command line option.
Since 1.0.4
double
cut_sub_process_get_elapsed (CutSubProcess *sub_process
);
Gets the time while sub_process
was running.
Since 1.0.4
double
cut_sub_process_get_total_elapsed (CutSubProcess *sub_process
);
Gets the sum of times that are used by each test.
Since 1.0.4
cut_boolean
cut_sub_process_is_crashed (CutSubProcess *sub_process
);
Returns whether sub_process
was crashed or not.
Since 1.0.4
cut_boolean
cut_sub_process_get_fatal_failures (CutSubProcess *sub_process
);
Returns whether sub_process
is ran in fatal-failures
mode. See cut_sub_process_set_fatal_failures()
more
details of fatal-failures mode.
Since 1.0.4
void cut_sub_process_set_fatal_failures (CutSubProcess *sub_process
,cut_boolean fatal_failures
);
Sets whether sub_process
is ran in fatal-failures mode or
not. In this mode, all failures are treated as fatal
problems. It means that test is aborted on failure. On
some environments, breakpoint is set.
This is same as --fatal-failures command line option.
Since 1.0.4
CutSubProcessGroup *
cut_take_new_sub_process_group (void
);
Creates a group of sub cutter process. A created group is owned by Cutter.
Since 1.0.4
void cut_sub_process_group_add (CutSubProcessGroup *group
,CutSubProcess *sub_process
);
Adds sub_process
to group
.
Since 1.0.4
cut_boolean
cut_sub_process_group_run (CutSubProcessGroup *group
);
Runs all sub cutter processes of group
and returns the
result of them.
CUT_TRUE
if all sub cutter processes of group
are completed successfully, CUT_FALSE
otherwise.
Since 1.0.4
void
cut_sub_process_group_run_async (CutSubProcessGroup *group
);
Runs all sub cutter processes of group
asynchronously. The result of them can be gotten by
cut_sub_process_group_wait()
.
Since 1.0.4
cut_boolean
cut_sub_process_group_wait (CutSubProcessGroup *group
);
Waits for all sub cutter processes of group
that are ran
asynchronously to complete and returns the result.
CUT_TRUE
if all sub cutter processes of group
are completed successfully, CUT_FALSE
otherwise.
Since 1.0.4
typedef struct _CutSubProcessGroup CutSubProcessGroup;
An object to run sub cutter processes. This is just for convenience.
e.g.:
CutSubProcess *sub_process1, *sub_process2, *sub_process3; CutSubProcessGroup *group; sub_process1 = cut_take_new_sub_process("test-dir1"); sub_process2 = cut_take_new_sub_process("test-dir2"); sub_process3 = cut_take_new_sub_process("test-dir3"); group = cut_take_new_sub_process_group(); cut_sub_process_group_add(group, sub_process1); cut_sub_process_group_add(group, sub_process2); cut_sub_process_group_add(group, sub_process3); cut_assert_true(cut_sub_process_group_run(group));
Since 1.0.4
typedef struct _CutSubProcess CutSubProcess;
An object to represent sub cutter process. It contains sub cutter process's parameters and results of sub cutter process.
e.g.:
CutSubProcess *sub_process; sub_process = cut_take_new_sub_process("test-dir"); cut_sub_process_set_multi_thread(sub_process, TRUE); cut_assert_true(cut_sub_process_run(sub_process));
Since 1.0.4