[A] Added test style
This commit is contained in:
parent
423ddb3ab8
commit
23191ec05d
19
src/fort.c
19
src/fort.c
@ -379,19 +379,30 @@ int ft_set_table_options(FTABLE * FORT_RESTRICT table, const fort_table_options_
|
|||||||
{
|
{
|
||||||
assert(table);
|
assert(table);
|
||||||
if (options == NULL) {
|
if (options == NULL) {
|
||||||
F_FREE(table->options);
|
destroy_table_options(table->options);
|
||||||
table->options = NULL;
|
table->options = NULL;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
fort_table_options_t *new_options = F_CALLOC(sizeof(fort_table_options_t), 1);
|
|
||||||
|
|
||||||
|
fort_table_options_t *new_options = copy_table_options(options);
|
||||||
if (new_options == NULL) {
|
if (new_options == NULL) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
memcpy(new_options, options, sizeof(fort_table_options_t));
|
destroy_table_options(table->options);
|
||||||
F_FREE(table->options);
|
|
||||||
table->options = new_options;
|
table->options = new_options;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
|
||||||
|
// fort_table_options_t *new_options = F_CALLOC(sizeof(fort_table_options_t), 1);
|
||||||
|
// if (new_options == NULL) {
|
||||||
|
// return -1;
|
||||||
|
// }
|
||||||
|
// memcpy(new_options, options, sizeof(fort_table_options_t));
|
||||||
|
// F_FREE(table->options);
|
||||||
|
// table->options = new_options;
|
||||||
|
// return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -64,6 +64,19 @@ fort_table_options_t* create_table_options()
|
|||||||
return options;
|
return options;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fort_table_options_t* copy_table_options(const fort_table_options_t *option)
|
||||||
|
{
|
||||||
|
/* todo: normal implementation, do deep copy of col options */
|
||||||
|
|
||||||
|
fort_table_options_t* new_opt = create_table_options();
|
||||||
|
if (new_opt == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
memcpy(new_opt, option, sizeof(fort_table_options_t));
|
||||||
|
return new_opt;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void destroy_table_options(fort_table_options_t* options)
|
void destroy_table_options(fort_table_options_t* options)
|
||||||
{
|
{
|
||||||
if (options == NULL)
|
if (options == NULL)
|
||||||
|
@ -96,6 +96,7 @@ extern fort_table_options_t g_table_options;
|
|||||||
|
|
||||||
|
|
||||||
fort_table_options_t* create_table_options();
|
fort_table_options_t* create_table_options();
|
||||||
|
fort_table_options_t* copy_table_options(const fort_table_options_t *option);
|
||||||
void destroy_table_options(fort_table_options_t* options);
|
void destroy_table_options(fort_table_options_t* options);
|
||||||
fort_status_t fort_options_set_column_min_width(fort_table_options_t *options, size_t column, size_t width);
|
fort_status_t fort_options_set_column_min_width(fort_table_options_t *options, size_t column, size_t width);
|
||||||
fort_status_t fort_options_set_column_alignment(fort_table_options_t *options, size_t column, enum TextAlignment al);
|
fort_status_t fort_options_set_column_alignment(fort_table_options_t *options, size_t column, enum TextAlignment al);
|
||||||
|
@ -6,11 +6,43 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
//#include "fort.c"
|
//#include "fort.c"
|
||||||
#include "table.h"
|
#include "table.h"
|
||||||
|
#include "options.h"
|
||||||
|
#include "vector.h"
|
||||||
|
|
||||||
|
|
||||||
|
fort_table_options_t test_table_opts = {
|
||||||
|
1, /* cell_padding_top */
|
||||||
|
1, /* cell_padding_bottom */
|
||||||
|
1, /* cell_padding_left */
|
||||||
|
1, /* cell_padding_right */
|
||||||
|
1, /* cell_empty_string_height */
|
||||||
|
|
||||||
|
/* border_chars */
|
||||||
|
{
|
||||||
|
'+', '-', '+', '+',
|
||||||
|
'|', '|', '|',
|
||||||
|
'+', '-', '+', '+',
|
||||||
|
'+', '-', '+', '+'
|
||||||
|
},
|
||||||
|
|
||||||
|
/* header_border_chars */
|
||||||
|
{
|
||||||
|
'+', '-', '+', '+',
|
||||||
|
'|', '|', '|',
|
||||||
|
'+', '-', '+', '+',
|
||||||
|
'+', '-', '+', '+'
|
||||||
|
},
|
||||||
|
|
||||||
|
NULL, /* col_options */
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
void test_table_sizes(void **state)
|
void test_table_sizes(void **state)
|
||||||
{
|
{
|
||||||
(void)state;
|
(void)state;
|
||||||
FTABLE *table = ft_create_table();
|
FTABLE *table = ft_create_table();
|
||||||
|
assert_true( table != NULL );
|
||||||
|
ft_set_table_options(table, &test_table_opts);
|
||||||
|
|
||||||
size_t rows = 0;
|
size_t rows = 0;
|
||||||
size_t cols = 0;
|
size_t cols = 0;
|
||||||
@ -58,6 +90,8 @@ void test_table_geometry(void **state)
|
|||||||
{
|
{
|
||||||
(void)state;
|
(void)state;
|
||||||
FTABLE *table = ft_create_table();
|
FTABLE *table = ft_create_table();
|
||||||
|
assert_true( table != NULL );
|
||||||
|
ft_set_table_options(table, &test_table_opts);
|
||||||
|
|
||||||
size_t height = 0;
|
size_t height = 0;
|
||||||
size_t width = 0;
|
size_t width = 0;
|
||||||
@ -99,6 +133,8 @@ void test_table_basic(void **state)
|
|||||||
|
|
||||||
WHEN("All columns are equal and not empty") {
|
WHEN("All columns are equal and not empty") {
|
||||||
table = ft_create_table();
|
table = ft_create_table();
|
||||||
|
assert_true( table != NULL );
|
||||||
|
ft_set_table_options(table, &test_table_opts);
|
||||||
|
|
||||||
int n = FT_HDR_PRINTF_LN(table, "%d|%c|%s|%f", 3, 'c', "234", 3.14);
|
int n = FT_HDR_PRINTF_LN(table, "%d|%c|%s|%f", 3, 'c', "234", 3.14);
|
||||||
assert_true( n == 4 );
|
assert_true( n == 4 );
|
||||||
@ -134,6 +170,8 @@ void test_table_basic(void **state)
|
|||||||
|
|
||||||
WHEN("All columns are not equal and not empty") {
|
WHEN("All columns are not equal and not empty") {
|
||||||
table = ft_create_table();
|
table = ft_create_table();
|
||||||
|
assert_true( table != NULL );
|
||||||
|
ft_set_table_options(table, &test_table_opts);
|
||||||
|
|
||||||
int n = FT_HDR_PRINTF_LN(table, "%d|%c|%s|%f", 3, 'c', "234", 3.14);
|
int n = FT_HDR_PRINTF_LN(table, "%d|%c|%s|%f", 3, 'c', "234", 3.14);
|
||||||
assert_true( n == 4 );
|
assert_true( n == 4 );
|
||||||
@ -167,6 +205,8 @@ void test_table_basic(void **state)
|
|||||||
|
|
||||||
WHEN("All columns are not equal and some cells are empty") {
|
WHEN("All columns are not equal and some cells are empty") {
|
||||||
table = ft_create_table();
|
table = ft_create_table();
|
||||||
|
assert_true( table != NULL );
|
||||||
|
ft_set_table_options(table, &test_table_opts);
|
||||||
|
|
||||||
int n = FT_HDR_PRINTF_LN(table, "||%s|%f", "234", 3.14);
|
int n = FT_HDR_PRINTF_LN(table, "||%s|%f", "234", 3.14);
|
||||||
assert_true( n == 4 );
|
assert_true( n == 4 );
|
||||||
@ -200,6 +240,8 @@ void test_table_basic(void **state)
|
|||||||
|
|
||||||
WHEN("All cells are empty") {
|
WHEN("All cells are empty") {
|
||||||
table = ft_create_table();
|
table = ft_create_table();
|
||||||
|
assert_true( table != NULL );
|
||||||
|
ft_set_table_options(table, &test_table_opts);
|
||||||
|
|
||||||
int n = FT_HDR_PRINTF_LN(table, "|||");
|
int n = FT_HDR_PRINTF_LN(table, "|||");
|
||||||
assert_true( n == 4 );
|
assert_true( n == 4 );
|
||||||
@ -235,11 +277,14 @@ void test_table_basic(void **state)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
FTABLE *create_test_int_table()
|
FTABLE *create_test_int_table(int set_test_opts)
|
||||||
{
|
{
|
||||||
FTABLE *table = NULL;
|
FTABLE *table = NULL;
|
||||||
|
|
||||||
table = ft_create_table();
|
table = ft_create_table();
|
||||||
|
assert_true( table != NULL );
|
||||||
|
if (set_test_opts)
|
||||||
|
ft_set_table_options(table, &test_table_opts);
|
||||||
|
|
||||||
assert_true (table != NULL);
|
assert_true (table != NULL);
|
||||||
|
|
||||||
@ -264,20 +309,20 @@ void test_table_options(void **state)
|
|||||||
(void)state;
|
(void)state;
|
||||||
FTABLE *table = NULL;
|
FTABLE *table = NULL;
|
||||||
|
|
||||||
fort_table_options_t def_options;
|
// fort_table_options_t def_options =;
|
||||||
ft_get_default_options(&def_options);
|
// ft_get_default_options(&def_options);
|
||||||
|
|
||||||
|
|
||||||
WHEN("All paddings = 1") {
|
WHEN("All paddings = 1") {
|
||||||
fort_table_options_t table_options;
|
fort_table_options_t table_options;
|
||||||
memcpy(&table_options, &def_options, sizeof(fort_table_options_t));
|
memcpy(&table_options, &test_table_opts, sizeof(fort_table_options_t));
|
||||||
table_options.cell_padding_bottom = 1;
|
table_options.cell_padding_bottom = 1;
|
||||||
table_options.cell_padding_top = 1;
|
table_options.cell_padding_top = 1;
|
||||||
table_options.cell_padding_left = 1;
|
table_options.cell_padding_left = 1;
|
||||||
table_options.cell_padding_right = 1;
|
table_options.cell_padding_right = 1;
|
||||||
ft_set_default_options(&table_options);
|
ft_set_default_options(&table_options);
|
||||||
|
|
||||||
table = create_test_int_table();
|
table = create_test_int_table(0);
|
||||||
|
|
||||||
const char *table_str = ft_to_string(table);
|
const char *table_str = ft_to_string(table);
|
||||||
assert_true( table_str != NULL );
|
assert_true( table_str != NULL );
|
||||||
@ -304,14 +349,14 @@ void test_table_options(void **state)
|
|||||||
|
|
||||||
WHEN("Top and bottom padding = 0") {
|
WHEN("Top and bottom padding = 0") {
|
||||||
fort_table_options_t table_options;
|
fort_table_options_t table_options;
|
||||||
memcpy(&table_options, &def_options, sizeof(fort_table_options_t));
|
memcpy(&table_options, &test_table_opts, sizeof(fort_table_options_t));
|
||||||
table_options.cell_padding_bottom = 0;
|
table_options.cell_padding_bottom = 0;
|
||||||
table_options.cell_padding_top = 0;
|
table_options.cell_padding_top = 0;
|
||||||
table_options.cell_padding_left = 1;
|
table_options.cell_padding_left = 1;
|
||||||
table_options.cell_padding_right = 1;
|
table_options.cell_padding_right = 1;
|
||||||
ft_set_default_options(&table_options);
|
ft_set_default_options(&table_options);
|
||||||
|
|
||||||
table = create_test_int_table();
|
table = create_test_int_table(0);
|
||||||
|
|
||||||
const char *table_str = ft_to_string(table);
|
const char *table_str = ft_to_string(table);
|
||||||
assert_true( table_str != NULL );
|
assert_true( table_str != NULL );
|
||||||
@ -332,14 +377,14 @@ void test_table_options(void **state)
|
|||||||
|
|
||||||
WHEN("Left and right padding = 0") {
|
WHEN("Left and right padding = 0") {
|
||||||
fort_table_options_t table_options;
|
fort_table_options_t table_options;
|
||||||
memcpy(&table_options, &def_options, sizeof(fort_table_options_t));
|
memcpy(&table_options, &test_table_opts, sizeof(fort_table_options_t));
|
||||||
table_options.cell_padding_bottom = 1;
|
table_options.cell_padding_bottom = 1;
|
||||||
table_options.cell_padding_top = 1;
|
table_options.cell_padding_top = 1;
|
||||||
table_options.cell_padding_left = 0;
|
table_options.cell_padding_left = 0;
|
||||||
table_options.cell_padding_right = 0;
|
table_options.cell_padding_right = 0;
|
||||||
ft_set_default_options(&table_options);
|
ft_set_default_options(&table_options);
|
||||||
|
|
||||||
table = create_test_int_table();
|
table = create_test_int_table(0);
|
||||||
|
|
||||||
const char *table_str = ft_to_string(table);
|
const char *table_str = ft_to_string(table);
|
||||||
assert_true( table_str != NULL );
|
assert_true( table_str != NULL );
|
||||||
@ -366,14 +411,14 @@ void test_table_options(void **state)
|
|||||||
|
|
||||||
WHEN("All paddings = 0") {
|
WHEN("All paddings = 0") {
|
||||||
fort_table_options_t table_options;
|
fort_table_options_t table_options;
|
||||||
memcpy(&table_options, &def_options, sizeof(fort_table_options_t));
|
memcpy(&table_options, &test_table_opts, sizeof(fort_table_options_t));
|
||||||
table_options.cell_padding_bottom = 0;
|
table_options.cell_padding_bottom = 0;
|
||||||
table_options.cell_padding_top = 0;
|
table_options.cell_padding_top = 0;
|
||||||
table_options.cell_padding_left = 0;
|
table_options.cell_padding_left = 0;
|
||||||
table_options.cell_padding_right = 0;
|
table_options.cell_padding_right = 0;
|
||||||
ft_set_default_options(&table_options);
|
ft_set_default_options(&table_options);
|
||||||
|
|
||||||
table = create_test_int_table();
|
table = create_test_int_table(0);
|
||||||
|
|
||||||
const char *table_str = ft_to_string(table);
|
const char *table_str = ft_to_string(table);
|
||||||
assert_true( table_str != NULL );
|
assert_true( table_str != NULL );
|
||||||
@ -394,7 +439,7 @@ void test_table_options(void **state)
|
|||||||
|
|
||||||
WHEN("Empty string has 0 heigt") {
|
WHEN("Empty string has 0 heigt") {
|
||||||
fort_table_options_t table_options;
|
fort_table_options_t table_options;
|
||||||
memcpy(&table_options, &def_options, sizeof(fort_table_options_t));
|
memcpy(&table_options, &test_table_opts, sizeof(fort_table_options_t));
|
||||||
table_options.cell_padding_bottom = 1;
|
table_options.cell_padding_bottom = 1;
|
||||||
table_options.cell_padding_top = 1;
|
table_options.cell_padding_top = 1;
|
||||||
table_options.cell_padding_left = 1;
|
table_options.cell_padding_left = 1;
|
||||||
@ -402,7 +447,7 @@ void test_table_options(void **state)
|
|||||||
table_options.cell_empty_string_height = 0;
|
table_options.cell_empty_string_height = 0;
|
||||||
ft_set_default_options(&table_options);
|
ft_set_default_options(&table_options);
|
||||||
|
|
||||||
table = create_test_int_table();
|
table = create_test_int_table(0);
|
||||||
int n = ft_printf_ln(table, "|||");
|
int n = ft_printf_ln(table, "|||");
|
||||||
assert_true( n == 4 );
|
assert_true( n == 4 );
|
||||||
|
|
||||||
@ -434,7 +479,7 @@ void test_table_options(void **state)
|
|||||||
|
|
||||||
WHEN("Changing cell separators") {
|
WHEN("Changing cell separators") {
|
||||||
fort_table_options_t table_options;
|
fort_table_options_t table_options;
|
||||||
memcpy(&table_options, &def_options, sizeof(fort_table_options_t));
|
memcpy(&table_options, &test_table_opts, sizeof(fort_table_options_t));
|
||||||
|
|
||||||
#define BOR_CHARS table_options.border_chars
|
#define BOR_CHARS table_options.border_chars
|
||||||
#define H_BOR_CHARS table_options.header_border_chars
|
#define H_BOR_CHARS table_options.header_border_chars
|
||||||
@ -455,7 +500,7 @@ void test_table_options(void **state)
|
|||||||
|
|
||||||
ft_set_default_options(&table_options);
|
ft_set_default_options(&table_options);
|
||||||
|
|
||||||
table = create_test_int_table();
|
table = create_test_int_table(0);
|
||||||
const char *table_str = ft_to_string(table);
|
const char *table_str = ft_to_string(table);
|
||||||
assert_true( table_str != NULL );
|
assert_true( table_str != NULL );
|
||||||
const char *table_str_etalon =
|
const char *table_str_etalon =
|
||||||
@ -504,7 +549,7 @@ void test_table_options(void **state)
|
|||||||
table_options.cell_empty_string_height = 0;
|
table_options.cell_empty_string_height = 0;
|
||||||
ft_set_default_options(&table_options);
|
ft_set_default_options(&table_options);
|
||||||
|
|
||||||
table = create_test_int_table();
|
table = create_test_int_table(0);
|
||||||
table_str = ft_to_string(table);
|
table_str = ft_to_string(table);
|
||||||
assert_true( table_str != NULL );
|
assert_true( table_str != NULL );
|
||||||
table_str_etalon =
|
table_str_etalon =
|
||||||
@ -523,14 +568,14 @@ void test_table_options(void **state)
|
|||||||
|
|
||||||
WHEN("Setting options for a particular table") {
|
WHEN("Setting options for a particular table") {
|
||||||
fort_table_options_t table_options;
|
fort_table_options_t table_options;
|
||||||
memcpy(&table_options, &def_options, sizeof(fort_table_options_t));
|
memcpy(&table_options, &test_table_opts, sizeof(fort_table_options_t));
|
||||||
table_options.cell_padding_bottom = 0;
|
table_options.cell_padding_bottom = 0;
|
||||||
table_options.cell_padding_top = 0;
|
table_options.cell_padding_top = 0;
|
||||||
table_options.cell_padding_left = 0;
|
table_options.cell_padding_left = 0;
|
||||||
table_options.cell_padding_right = 0;
|
table_options.cell_padding_right = 0;
|
||||||
ft_set_default_options(&table_options);
|
ft_set_default_options(&table_options);
|
||||||
|
|
||||||
table = create_test_int_table();
|
table = create_test_int_table(0);
|
||||||
|
|
||||||
const char *table_str = ft_to_string(table);
|
const char *table_str = ft_to_string(table);
|
||||||
assert_true( table_str != NULL );
|
assert_true( table_str != NULL );
|
||||||
@ -577,7 +622,7 @@ void test_table_options(void **state)
|
|||||||
|
|
||||||
WHEN("Set table width and column alignment") {
|
WHEN("Set table width and column alignment") {
|
||||||
fort_table_options_t table_options;
|
fort_table_options_t table_options;
|
||||||
memcpy(&table_options, &def_options, sizeof(fort_table_options_t));
|
memcpy(&table_options, &test_table_opts, sizeof(fort_table_options_t));
|
||||||
table_options.cell_padding_bottom = 1;
|
table_options.cell_padding_bottom = 1;
|
||||||
table_options.cell_padding_top = 1;
|
table_options.cell_padding_top = 1;
|
||||||
table_options.cell_padding_left = 1;
|
table_options.cell_padding_left = 1;
|
||||||
@ -585,7 +630,7 @@ void test_table_options(void **state)
|
|||||||
ft_set_default_options(&table_options);
|
ft_set_default_options(&table_options);
|
||||||
|
|
||||||
|
|
||||||
table = create_test_int_table();
|
table = create_test_int_table(0);
|
||||||
ft_set_column_min_width(table, 1, 7);
|
ft_set_column_min_width(table, 1, 7);
|
||||||
ft_set_column_alignment(table, 1, LeftAligned);
|
ft_set_column_alignment(table, 1, LeftAligned);
|
||||||
ft_set_column_min_width(table, 2, 8);
|
ft_set_column_min_width(table, 2, 8);
|
||||||
|
Loading…
Reference in New Issue
Block a user