2012-06-22 10:05:41 +01:00
|
|
|
#include "status.h"
|
|
|
|
#include "serve.h"
|
|
|
|
#include "ioutil.h"
|
|
|
|
#include "util.h"
|
|
|
|
|
|
|
|
#include <check.h>
|
|
|
|
|
2013-07-08 13:32:14 +01:00
|
|
|
struct server* mock_server(void)
|
2013-07-08 10:11:18 +01:00
|
|
|
{
|
2013-07-08 13:32:14 +01:00
|
|
|
struct server* out = xmalloc( sizeof( struct server ) );
|
|
|
|
out->l_start_mirror = flexthread_mutex_create();
|
2013-09-23 13:38:19 +01:00
|
|
|
out->nbd_client = xmalloc( sizeof( struct client_tbl_entry ) * 4 );
|
|
|
|
out->max_nbd_clients = 4;
|
2013-07-08 13:32:14 +01:00
|
|
|
return out;
|
2013-07-08 10:11:18 +01:00
|
|
|
}
|
|
|
|
|
2013-07-08 13:32:14 +01:00
|
|
|
struct server* mock_mirroring_server(void)
|
2012-06-22 10:05:41 +01:00
|
|
|
{
|
2013-07-08 13:32:14 +01:00
|
|
|
struct server *out = mock_server();
|
|
|
|
out->mirror = xmalloc( sizeof( struct mirror ) );
|
|
|
|
|
|
|
|
return out;
|
|
|
|
}
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-07-08 13:32:14 +01:00
|
|
|
void destroy_mock_server( struct server* serve )
|
|
|
|
{
|
|
|
|
if ( NULL != serve->mirror ) {
|
|
|
|
free( serve->mirror );
|
|
|
|
}
|
|
|
|
|
|
|
|
flexthread_mutex_destroy( serve->l_start_mirror );
|
2013-09-23 13:38:19 +01:00
|
|
|
free( serve->nbd_client );
|
2013-07-08 13:32:14 +01:00
|
|
|
free( serve );
|
|
|
|
}
|
|
|
|
|
|
|
|
START_TEST( test_status_create )
|
|
|
|
{
|
|
|
|
struct server * server = mock_server();
|
|
|
|
struct status * status = status_create( server );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
|
|
|
fail_if( NULL == status, "Status wasn't allocated" );
|
|
|
|
status_destroy( status );
|
2013-07-08 13:32:14 +01:00
|
|
|
destroy_mock_server( server );
|
2012-06-22 10:05:41 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
START_TEST( test_gets_has_control )
|
|
|
|
{
|
2013-07-08 13:32:14 +01:00
|
|
|
struct server * server = mock_server();
|
|
|
|
server->success = 1;
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-07-08 13:32:14 +01:00
|
|
|
struct status * status = status_create( server );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
|
|
|
fail_unless( status->has_control == 1, "has_control wasn't copied" );
|
|
|
|
status_destroy( status );
|
2013-07-08 13:32:14 +01:00
|
|
|
destroy_mock_server( server );
|
2012-06-22 10:05:41 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
|
|
|
|
START_TEST( test_gets_is_mirroring )
|
|
|
|
{
|
2013-07-08 13:32:14 +01:00
|
|
|
struct server * server = mock_server();
|
|
|
|
struct status * status = status_create( server );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
|
|
|
fail_if( status->is_mirroring, "is_mirroring was set" );
|
|
|
|
status_destroy( status );
|
2013-07-08 13:32:14 +01:00
|
|
|
destroy_mock_server( server );
|
|
|
|
|
|
|
|
server = mock_mirroring_server();
|
|
|
|
status = status_create( server );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
|
|
|
fail_unless( status->is_mirroring, "is_mirroring wasn't set" );
|
|
|
|
status_destroy( status );
|
2013-07-08 13:32:14 +01:00
|
|
|
destroy_mock_server( server );
|
2012-06-22 10:05:41 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
START_TEST( test_gets_clients_allowed )
|
|
|
|
{
|
|
|
|
struct server * server = mock_server();
|
|
|
|
struct status * status = status_create( server );
|
|
|
|
|
|
|
|
fail_if( status->clients_allowed, "clients_allowed was set" );
|
|
|
|
status_destroy( status );
|
|
|
|
|
|
|
|
server->allow_new_clients = 1;
|
|
|
|
status = status_create( server );
|
|
|
|
|
|
|
|
fail_unless( status->clients_allowed, "clients_allowed was not set" );
|
|
|
|
status_destroy( status );
|
|
|
|
destroy_mock_server( server );
|
|
|
|
|
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
START_TEST( test_gets_num_clients )
|
|
|
|
{
|
|
|
|
struct server * server = mock_server();
|
|
|
|
struct status * status = status_create( server );
|
|
|
|
|
|
|
|
fail_if( status->num_clients != 0, "num_clients was wrong" );
|
|
|
|
status_destroy( status );
|
|
|
|
|
|
|
|
server->nbd_client[0].thread = 1;
|
|
|
|
server->nbd_client[1].thread = 1;
|
|
|
|
status = status_create( server );
|
|
|
|
|
|
|
|
fail_unless( status->num_clients == 2, "num_clients was wrong" );
|
|
|
|
status_destroy( status );
|
|
|
|
destroy_mock_server( server );
|
|
|
|
|
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2013-07-08 09:58:31 +01:00
|
|
|
START_TEST( test_gets_migration_pass )
|
|
|
|
{
|
2013-07-08 13:32:14 +01:00
|
|
|
struct server * server = mock_server();
|
|
|
|
struct status * status = status_create( server );
|
2013-07-08 09:58:31 +01:00
|
|
|
|
|
|
|
fail_if( status->migration_pass != 0, "migration_pass was set" );
|
|
|
|
status_destroy( status );
|
2013-07-08 13:32:14 +01:00
|
|
|
destroy_mock_server( server );
|
|
|
|
|
|
|
|
server = mock_mirroring_server();
|
|
|
|
server->mirror->pass = 1;
|
|
|
|
status = status_create( server );
|
2013-07-08 09:58:31 +01:00
|
|
|
|
|
|
|
fail_unless( status->migration_pass == 1, "migration_pass wasn't set" );
|
|
|
|
status_destroy( status );
|
2013-07-08 13:32:14 +01:00
|
|
|
destroy_mock_server( server );
|
2013-07-08 09:58:31 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2012-07-16 11:50:59 +01:00
|
|
|
START_TEST( test_gets_pid )
|
|
|
|
{
|
2013-07-08 13:32:14 +01:00
|
|
|
struct server * server = mock_server();
|
|
|
|
struct status * status = status_create( server );
|
2012-07-16 11:50:59 +01:00
|
|
|
|
|
|
|
fail_unless( getpid() == status->pid, "Pid wasn't gathered" );
|
|
|
|
|
|
|
|
status_destroy( status );
|
2013-07-08 13:32:14 +01:00
|
|
|
destroy_mock_server( server );
|
2012-07-16 11:50:59 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2013-07-08 10:11:18 +01:00
|
|
|
START_TEST( test_gets_size )
|
|
|
|
{
|
2013-07-08 13:32:14 +01:00
|
|
|
struct server * server = mock_server();
|
|
|
|
server->size = 1024;
|
2013-07-08 10:11:18 +01:00
|
|
|
|
2013-07-08 13:32:14 +01:00
|
|
|
struct status * status = status_create( server );
|
2013-07-08 10:11:18 +01:00
|
|
|
|
|
|
|
fail_unless( 1024 == status->size, "Size wasn't gathered" );
|
|
|
|
|
|
|
|
status_destroy( status );
|
2013-07-08 13:32:14 +01:00
|
|
|
destroy_mock_server( server );
|
2013-07-08 10:11:18 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2013-07-26 11:50:01 +01:00
|
|
|
START_TEST( test_gets_migration_statistics )
|
2013-07-08 13:51:15 +01:00
|
|
|
{
|
|
|
|
struct server * server = mock_mirroring_server();
|
|
|
|
server->mirror->this_pass_clean = 2048;
|
|
|
|
server->mirror->this_pass_dirty = 4096;
|
2013-07-26 11:50:01 +01:00
|
|
|
server->mirror->all_dirty = 16384;
|
2013-08-14 13:30:25 +01:00
|
|
|
server->mirror->max_bytes_per_second = 32768;
|
2013-07-26 11:50:01 +01:00
|
|
|
|
|
|
|
/* we have a bit of a time dependency here */
|
|
|
|
server->mirror->migration_started = monotonic_time_ms();
|
2013-07-08 13:51:15 +01:00
|
|
|
|
|
|
|
struct status * status = status_create( server );
|
|
|
|
|
|
|
|
fail_unless( 2048 == status->pass_clean_bytes, "pass_clean_bytes wasn't gathered" );
|
|
|
|
fail_unless( 4096 == status->pass_dirty_bytes, "pass_dirty_bytes wasn't gathered" );
|
|
|
|
|
2013-07-26 11:50:01 +01:00
|
|
|
fail_unless (
|
|
|
|
0 == status->migration_duration ||
|
|
|
|
1 == status->migration_duration ||
|
|
|
|
2 == status->migration_duration,
|
|
|
|
"migration_duration is unreasonable!"
|
|
|
|
);
|
|
|
|
|
|
|
|
fail_unless(
|
|
|
|
16384 / ( status->migration_duration + 1 ) == status->migration_speed,
|
|
|
|
"migration_speed not calculated correctly"
|
|
|
|
);
|
|
|
|
|
2013-08-14 13:30:25 +01:00
|
|
|
fail_unless( 32768 == status->migration_speed_limit, "migration_speed_limit not read" );
|
|
|
|
|
2013-07-26 11:50:01 +01:00
|
|
|
|
2013-07-08 13:51:15 +01:00
|
|
|
status_destroy( status );
|
|
|
|
destroy_mock_server( server );
|
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2012-07-16 11:50:59 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
#define RENDER_TEST_SETUP \
|
|
|
|
struct status status; \
|
|
|
|
int fds[2]; \
|
|
|
|
pipe( fds );
|
|
|
|
|
|
|
|
void fail_unless_rendered( int fd, char *fragment )
|
2012-06-22 10:05:41 +01:00
|
|
|
{
|
|
|
|
char buf[1024] = {0};
|
2013-09-23 13:38:19 +01:00
|
|
|
char emsg[1024] = {0};
|
|
|
|
char *found = NULL;
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
sprintf(emsg, "Fragment: %s not found", fragment );
|
|
|
|
|
|
|
|
fail_unless( read_until_newline( fd, buf, 1024 ) > 0, "Couldn't read" );
|
|
|
|
found = strstr( buf, fragment );
|
|
|
|
fail_if( NULL == found, emsg );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
return;
|
|
|
|
}
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
void fail_if_rendered( int fd, char *fragment )
|
|
|
|
{
|
|
|
|
char buf[1024] = {0};
|
|
|
|
char emsg[1024] = {0};
|
|
|
|
char *found = NULL;
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
sprintf(emsg, "Fragment: %s found", fragment );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_unless( read_until_newline( fd, buf, 1024 ) > 0, "Couldn't read" );
|
|
|
|
found = strstr( buf, fragment );
|
|
|
|
fail_unless( NULL == found, emsg );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
START_TEST( test_renders_has_control )
|
|
|
|
{
|
|
|
|
RENDER_TEST_SETUP
|
|
|
|
|
|
|
|
status.has_control = 1;
|
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_unless_rendered( fds[0], "has_control=true" );
|
|
|
|
|
|
|
|
status.has_control = 0;
|
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_unless_rendered( fds[0], "has_control=false" );
|
2012-06-22 10:05:41 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
|
|
|
|
START_TEST( test_renders_is_mirroring )
|
|
|
|
{
|
2013-09-23 13:38:19 +01:00
|
|
|
RENDER_TEST_SETUP
|
2012-06-22 10:05:41 +01:00
|
|
|
|
|
|
|
status.is_mirroring = 1;
|
|
|
|
status_write( &status, fds[1] );
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_unless_rendered( fds[0], "is_mirroring=true" );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status.is_mirroring = 0;
|
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_unless_rendered( fds[0], "is_mirroring=false" );
|
|
|
|
}
|
|
|
|
END_TEST
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
START_TEST( test_renders_clients_allowed )
|
|
|
|
{
|
|
|
|
RENDER_TEST_SETUP
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status.clients_allowed = 1;
|
2012-06-22 10:05:41 +01:00
|
|
|
status_write( &status, fds[1] );
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_unless_rendered( fds[0], "clients_allowed=true" );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status.clients_allowed = 0;
|
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_unless_rendered( fds[0], "clients_allowed=false" );
|
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
START_TEST( test_renders_num_clients )
|
|
|
|
{
|
|
|
|
RENDER_TEST_SETUP
|
|
|
|
|
|
|
|
status.num_clients = 0;
|
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_unless_rendered( fds[0], "num_clients=0" );
|
|
|
|
|
|
|
|
status.num_clients = 4000;
|
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_unless_rendered( fds[0], "num_clients=4000" );
|
2012-06-22 10:05:41 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
|
2012-07-16 11:50:59 +01:00
|
|
|
START_TEST( test_renders_pid )
|
|
|
|
{
|
2013-09-23 13:38:19 +01:00
|
|
|
RENDER_TEST_SETUP
|
2012-07-16 11:50:59 +01:00
|
|
|
|
|
|
|
status.pid = 42;
|
|
|
|
status_write( &status, fds[1] );
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_unless_rendered( fds[0], "pid=42" );
|
2012-07-16 11:50:59 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2013-07-08 10:11:18 +01:00
|
|
|
START_TEST( test_renders_size )
|
|
|
|
{
|
2013-09-23 13:38:19 +01:00
|
|
|
RENDER_TEST_SETUP
|
2013-07-08 10:11:18 +01:00
|
|
|
|
|
|
|
status.size = ( (uint64_t)1 << 33 );
|
|
|
|
status_write( &status, fds[1] );
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_unless_rendered( fds[0], "size=8589934592" );
|
2013-07-08 10:11:18 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2013-07-08 09:58:31 +01:00
|
|
|
START_TEST( test_renders_migration_pass )
|
|
|
|
{
|
2013-09-23 13:38:19 +01:00
|
|
|
RENDER_TEST_SETUP
|
2013-07-08 09:58:31 +01:00
|
|
|
|
|
|
|
status.is_mirroring = 0;
|
|
|
|
status.migration_pass = 1;
|
|
|
|
status_write( &status, fds[1] );
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_if_rendered( fds[0], "migration_pass" );
|
2013-07-08 09:58:31 +01:00
|
|
|
|
|
|
|
status.is_mirroring = 1;
|
|
|
|
status_write( &status, fds[1] );
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_unless_rendered( fds[0], "migration_pass=1" );
|
2013-07-08 09:58:31 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2013-07-26 11:50:01 +01:00
|
|
|
START_TEST( test_renders_migration_statistics )
|
2013-07-08 14:27:04 +01:00
|
|
|
{
|
2013-09-23 13:38:19 +01:00
|
|
|
RENDER_TEST_SETUP
|
2013-07-08 14:27:04 +01:00
|
|
|
|
|
|
|
status.is_mirroring = 0;
|
|
|
|
status.pass_dirty_bytes = 2048;
|
|
|
|
status.pass_clean_bytes = 4096;
|
2013-07-26 11:50:01 +01:00
|
|
|
status.migration_duration = 8;
|
|
|
|
status.migration_speed = 40000000;
|
2013-08-14 13:30:25 +01:00
|
|
|
status.migration_speed_limit = 40000001;
|
2013-07-26 11:50:01 +01:00
|
|
|
|
2013-07-08 14:27:04 +01:00
|
|
|
status_write( &status, fds[1] );
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_if_rendered( fds[0], "pass_dirty_bytes" );
|
2013-07-08 14:27:04 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_if_rendered( fds[0], "pass_clean_bytes" );
|
2013-07-08 14:27:04 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_if_rendered( fds[0], "migration_duration" );
|
2013-07-26 11:50:01 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_if_rendered( fds[0], "migration_speed" );
|
|
|
|
|
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_if_rendered( fds[0], "migration_speed_limit" );
|
2013-07-08 14:27:04 +01:00
|
|
|
|
|
|
|
status.is_mirroring = 1;
|
2013-09-23 13:38:19 +01:00
|
|
|
|
2013-07-08 14:27:04 +01:00
|
|
|
status_write( &status, fds[1] );
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_unless_rendered( fds[0], "pass_dirty_bytes=2048" );
|
2013-07-08 14:27:04 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_unless_rendered( fds[0], "pass_clean_bytes=4096" );
|
2013-08-14 13:30:25 +01:00
|
|
|
|
|
|
|
status_write( &status, fds[1] );
|
2013-09-23 13:38:19 +01:00
|
|
|
fail_unless_rendered( fds[0], "migration_duration=8" );
|
2013-08-14 13:30:25 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_unless_rendered( fds[0], "migration_speed=40000000" );
|
2013-08-14 13:30:25 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_unless_rendered( fds[0], "migration_speed_limit=40000001" );
|
2013-08-14 13:30:25 +01:00
|
|
|
|
2013-09-23 13:38:19 +01:00
|
|
|
status.migration_speed_limit = UINT64_MAX;
|
|
|
|
|
|
|
|
status_write( &status, fds[1] );
|
|
|
|
fail_if_rendered( fds[0], "migration_speed_limit" );
|
2013-07-08 14:27:04 +01:00
|
|
|
}
|
|
|
|
END_TEST
|
2013-07-08 09:58:31 +01:00
|
|
|
|
2012-07-16 11:50:59 +01:00
|
|
|
|
2012-06-22 10:05:41 +01:00
|
|
|
Suite *status_suite(void)
|
|
|
|
{
|
|
|
|
Suite *s = suite_create("status");
|
|
|
|
TCase *tc_create = tcase_create("create");
|
|
|
|
TCase *tc_render = tcase_create("render");
|
|
|
|
|
|
|
|
tcase_add_test(tc_create, test_status_create);
|
|
|
|
tcase_add_test(tc_create, test_gets_has_control);
|
|
|
|
tcase_add_test(tc_create, test_gets_is_mirroring);
|
2013-09-23 13:38:19 +01:00
|
|
|
tcase_add_test(tc_create, test_gets_clients_allowed);
|
|
|
|
tcase_add_test(tc_create, test_gets_num_clients);
|
2012-07-16 11:50:59 +01:00
|
|
|
tcase_add_test(tc_create, test_gets_pid);
|
2013-07-08 10:11:18 +01:00
|
|
|
tcase_add_test(tc_create, test_gets_size);
|
2013-07-08 09:58:31 +01:00
|
|
|
tcase_add_test(tc_create, test_gets_migration_pass);
|
2013-07-26 11:50:01 +01:00
|
|
|
tcase_add_test(tc_create, test_gets_migration_statistics);
|
2013-07-08 13:32:14 +01:00
|
|
|
|
2012-06-22 10:05:41 +01:00
|
|
|
|
|
|
|
tcase_add_test(tc_render, test_renders_has_control);
|
|
|
|
tcase_add_test(tc_render, test_renders_is_mirroring);
|
2013-09-23 13:38:19 +01:00
|
|
|
tcase_add_test(tc_render, test_renders_clients_allowed);
|
|
|
|
tcase_add_test(tc_render, test_renders_num_clients);
|
2012-07-16 11:50:59 +01:00
|
|
|
tcase_add_test(tc_render, test_renders_pid);
|
2013-07-08 10:11:18 +01:00
|
|
|
tcase_add_test(tc_render, test_renders_size);
|
2013-07-08 09:58:31 +01:00
|
|
|
tcase_add_test(tc_render, test_renders_migration_pass);
|
2013-07-26 11:50:01 +01:00
|
|
|
tcase_add_test(tc_render, test_renders_migration_statistics);
|
2012-06-22 10:05:41 +01:00
|
|
|
|
|
|
|
suite_add_tcase(s, tc_create);
|
|
|
|
suite_add_tcase(s, tc_render);
|
|
|
|
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
int number_failed;
|
2012-10-09 17:35:20 +01:00
|
|
|
|
2012-06-22 10:05:41 +01:00
|
|
|
Suite *s = status_suite();
|
|
|
|
SRunner *sr = srunner_create(s);
|
|
|
|
srunner_run_all(sr, CK_NORMAL);
|
|
|
|
number_failed = srunner_ntests_failed(sr);
|
|
|
|
srunner_free(sr);
|
|
|
|
return (number_failed == 0) ? 0 : 1;
|
|
|
|
}
|
|
|
|
|