Markus Mäkelä 943662d2b5 Rewrite temporary table test
Use stack allocated test class and use const char pointers for const
functions. Simplify the test and improve error messages.
2017-06-06 22:45:19 +03:00

78 lines
2.2 KiB
C

#ifndef SQL_T1_H
#define SQL_T1_H
#include "mariadb_func.h"
#include "testconnections.h"
/**
* @brief execute_select_query_and_check Execute query and check that result contains expected number of rows
* @param conn MYSQL handler
* @param sql Query
* @param rows Expected number of rows
* @return 0 in case of success
*/
int execute_select_query_and_check(MYSQL *conn, const char *sql, unsigned long long int rows);
/**
* @brief create_t1 Create t1 table, fileds: (x1 int, fl int)
* @param conn MYSQL handler
* @return 0 in case of success
*/
int create_t1(MYSQL * conn);
/**
* @brief create_t1 Create t2 table, fileds: (x1 int, fl int)
* @param conn MYSQL handler
* @return 0 in case of success
*/
int create_t2(MYSQL * conn);
/**
* @brief create_insert_string Create SQL query string to insert N rows into t1
* fl is equal to given value and x1 is incrementing value (row index)
* @param sql pointer to buffer to put result
* @param N Number of rows to insert
* @param fl value to fill 'fl' field
* @return 0
*/
int create_insert_string(char *sql, int N, int fl);
/**
* @brief create_insert_string Create SQL query string to insert N rows into t1
* fl is equal to given value and x1 is incrementing value (row index)
* (same as create_insert_string(), but allocates buffer for SQL string by itself)
* @param sql pointer to buffer to put result
* @param N Number of rows to insert
* @param fl value to fill 'fl' field
* @return pointer to insert SQL string
*/
char* allocate_insert_string(int fl, int N);
/**
* @brief insert_into_t1 Insert N blocks of 16^i rows into t1
* first block has fl=0, second - fl=1, ..., N-block fl=N-1
* first block has 16 row, second - 256, ..., N-block 16^N rows
* @param conn MYSQL handler
* @param N Number of blocks to insert
* @return 0 in case of success
*/
int insert_into_t1(MYSQL *conn, int N);
/**
* @brief select_from_t1 Check that t1 contains data as inserted by insert_into_t1()
* @param conn MYSQL handler
* @param N Number of blocks to insert
* @return 0 in case of success
*/
int select_from_t1(MYSQL *conn, int N);
/**
* @brief check_if_t1_exists
* @param conn MYSQL handler
* @return 0 if content of t1 is ok
*/
int check_if_t1_exists(MYSQL *conn);
#endif // SQL_T1_H