2010-10-03 12:06:47 +02:00
|
|
|
#define LIBSSH_STATIC
|
|
|
|
|
|
|
|
#include "torture.h"
|
2010-10-03 13:31:02 +02:00
|
|
|
#define DEBUG_BUFFER
|
|
|
|
#include "buffer.c"
|
2010-10-03 12:06:47 +02:00
|
|
|
|
|
|
|
#define LIMIT (8*1024*1024)
|
|
|
|
|
2010-12-28 13:44:14 +01:00
|
|
|
static void setup(void **state) {
|
|
|
|
ssh_buffer buffer;
|
|
|
|
buffer = ssh_buffer_new();
|
|
|
|
*state = (void *) buffer;
|
2010-10-03 12:06:47 +02:00
|
|
|
}
|
|
|
|
|
2010-12-28 13:44:14 +01:00
|
|
|
static void teardown(void **state) {
|
|
|
|
ssh_buffer_free(*state);
|
2010-10-03 12:06:47 +02:00
|
|
|
}
|
|
|
|
|
2010-12-28 13:44:14 +01:00
|
|
|
/*
|
|
|
|
* Test if the continuously growing buffer size never exceeds 2 time its
|
2010-10-03 12:06:47 +02:00
|
|
|
* real capacity
|
|
|
|
*/
|
2010-12-28 13:44:14 +01:00
|
|
|
static void torture_growing_buffer(void **state) {
|
|
|
|
ssh_buffer buffer = *state;
|
2010-10-03 12:06:47 +02:00
|
|
|
int i;
|
2010-12-28 13:44:14 +01:00
|
|
|
|
2010-10-03 12:06:47 +02:00
|
|
|
for(i=0;i<LIMIT;++i){
|
|
|
|
buffer_add_data(buffer,"A",1);
|
|
|
|
if(buffer->used >= 128){
|
|
|
|
if(buffer_get_rest_len(buffer) * 2 < buffer->allocated){
|
2010-12-28 13:44:14 +01:00
|
|
|
assert_true(buffer_get_rest_len(buffer) * 2 >= buffer->allocated);
|
2010-10-03 12:06:47 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-12-28 13:44:14 +01:00
|
|
|
/*
|
|
|
|
* Test if the continuously growing buffer size never exceeds 2 time its
|
2010-10-03 12:06:47 +02:00
|
|
|
* real capacity, when we remove 1 byte after each call (sliding window)
|
|
|
|
*/
|
2010-12-28 13:44:14 +01:00
|
|
|
static void torture_growing_buffer_shifting(void **state) {
|
|
|
|
ssh_buffer buffer = *state;
|
2010-10-03 12:06:47 +02:00
|
|
|
int i;
|
|
|
|
unsigned char c;
|
|
|
|
for(i=0; i<1024;++i){
|
|
|
|
buffer_add_data(buffer,"S",1);
|
|
|
|
}
|
|
|
|
for(i=0;i<LIMIT;++i){
|
|
|
|
buffer_get_u8(buffer,&c);
|
|
|
|
buffer_add_data(buffer,"A",1);
|
|
|
|
if(buffer->used >= 128){
|
|
|
|
if(buffer_get_rest_len(buffer) * 4 < buffer->allocated){
|
2010-12-28 13:44:14 +01:00
|
|
|
assert_true(buffer_get_rest_len(buffer) * 4 >= buffer->allocated);
|
2010-10-03 12:06:47 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-12-28 13:44:14 +01:00
|
|
|
/*
|
|
|
|
* Test the behavior of buffer_prepend_data
|
2010-10-03 12:25:33 +02:00
|
|
|
*/
|
2010-12-28 13:44:14 +01:00
|
|
|
static void torture_buffer_prepend(void **state) {
|
|
|
|
ssh_buffer buffer = *state;
|
2010-10-03 12:25:33 +02:00
|
|
|
uint32_t v;
|
|
|
|
buffer_add_data(buffer,"abcdef",6);
|
|
|
|
buffer_prepend_data(buffer,"xyz",3);
|
2010-12-28 13:44:14 +01:00
|
|
|
assert_int_equal(buffer_get_rest_len(buffer),9);
|
|
|
|
assert_int_equal(memcmp(buffer_get_rest(buffer), "xyzabcdef", 9), 0);
|
2010-10-03 12:25:33 +02:00
|
|
|
// Now remove 4 bytes and see if we can replace them
|
|
|
|
buffer_get_u32(buffer,&v);
|
2010-12-28 13:44:14 +01:00
|
|
|
assert_int_equal(buffer_get_rest_len(buffer),5);
|
|
|
|
assert_int_equal(memcmp(buffer_get_rest(buffer), "bcdef", 5), 0);
|
2010-10-03 12:25:33 +02:00
|
|
|
buffer_prepend_data(buffer,"aris",4);
|
2010-12-28 13:44:14 +01:00
|
|
|
assert_int_equal(buffer_get_rest_len(buffer),9);
|
|
|
|
assert_int_equal(memcmp(buffer_get_rest(buffer), "arisbcdef", 9), 0);
|
2010-10-03 13:01:21 +02:00
|
|
|
/* same thing but we add 5 bytes now */
|
|
|
|
buffer_get_u32(buffer,&v);
|
2010-12-28 13:44:14 +01:00
|
|
|
assert_int_equal(buffer_get_rest_len(buffer),5);
|
|
|
|
assert_int_equal(memcmp(buffer_get_rest(buffer), "bcdef", 5), 0);
|
2010-10-03 13:01:21 +02:00
|
|
|
buffer_prepend_data(buffer,"12345",5);
|
2010-12-28 13:44:14 +01:00
|
|
|
assert_int_equal(buffer_get_rest_len(buffer),10);
|
|
|
|
assert_int_equal(memcmp(buffer_get_rest(buffer), "12345bcdef", 10), 0);
|
2010-10-03 13:01:21 +02:00
|
|
|
|
2010-10-03 12:25:33 +02:00
|
|
|
}
|
|
|
|
|
2012-10-22 20:45:59 +02:00
|
|
|
/*
|
|
|
|
* Test the behavior of buffer_get_ssh_string with invalid data
|
|
|
|
*/
|
|
|
|
static void torture_buffer_get_ssh_string(void **state) {
|
|
|
|
ssh_buffer buffer;
|
|
|
|
int i,j,k,l;
|
|
|
|
/* some values that can go wrong */
|
|
|
|
uint32_t values[] = {0xffffffff, 0xfffffffe, 0xfffffffc, 0xffffff00,
|
|
|
|
0x80000000, 0x80000004, 0x7fffffff};
|
|
|
|
char data[128];
|
|
|
|
(void)state;
|
|
|
|
memset(data,'X',sizeof(data));
|
|
|
|
for(i=0; i < (int)(sizeof(values)/sizeof(values[0]));++i){
|
|
|
|
for(j=0; j< (int)sizeof(data);++j){
|
|
|
|
for(k=1;k<5;++k){
|
|
|
|
buffer=buffer_new();
|
|
|
|
for(l=0;l<k;++l){
|
|
|
|
buffer_add_u32(buffer,htonl(values[i]));
|
|
|
|
}
|
|
|
|
buffer_add_data(buffer,data,j);
|
|
|
|
for(l=0;l<k;++l){
|
|
|
|
ssh_string str = buffer_get_ssh_string(buffer);
|
|
|
|
assert_true(str==NULL);
|
|
|
|
}
|
|
|
|
buffer_free(buffer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2010-12-28 13:44:14 +01:00
|
|
|
int torture_run_tests(void) {
|
2011-01-02 17:25:51 +01:00
|
|
|
int rc;
|
2010-12-28 13:44:14 +01:00
|
|
|
const UnitTest tests[] = {
|
|
|
|
unit_test_setup_teardown(torture_growing_buffer, setup, teardown),
|
|
|
|
unit_test_setup_teardown(torture_growing_buffer_shifting, setup, teardown),
|
|
|
|
unit_test_setup_teardown(torture_buffer_prepend, setup, teardown),
|
2012-10-22 20:45:59 +02:00
|
|
|
unit_test(torture_buffer_get_ssh_string),
|
2010-12-28 13:44:14 +01:00
|
|
|
};
|
2010-10-03 12:06:47 +02:00
|
|
|
|
2011-01-02 17:25:51 +01:00
|
|
|
ssh_init();
|
|
|
|
rc=run_tests(tests);
|
|
|
|
ssh_finalize();
|
|
|
|
return rc;
|
2010-10-03 12:06:47 +02:00
|
|
|
}
|