X-Git-Url: http://git.samba.org/samba.git/?a=blobdiff_plain;f=testsuite%2Flibsmbclient%2Fsrc%2Flseek%2Flseek_7.c;fp=testsuite%2Flibsmbclient%2Fsrc%2Flseek%2Flseek_7.c;h=e3ef6cdd54495d48c23c33781e81333463e8d7e5;hb=53a331cfb271bd64bb26d0d433439e249adbbe71;hp=0000000000000000000000000000000000000000;hpb=e8fcbc5df1d51b2b3683254288f204f42b75e7e9;p=ira%2Fwip.git diff --git a/testsuite/libsmbclient/src/lseek/lseek_7.c b/testsuite/libsmbclient/src/lseek/lseek_7.c new file mode 100644 index 00000000000..e3ef6cdd544 --- /dev/null +++ b/testsuite/libsmbclient/src/lseek/lseek_7.c @@ -0,0 +1,80 @@ +#include +#include +#include +#include +#include + +#define MAX_BUFF_SIZE 255 +char g_workgroup[MAX_BUFF_SIZE]; +char g_username[MAX_BUFF_SIZE]; +char g_password[MAX_BUFF_SIZE]; +char g_server[MAX_BUFF_SIZE]; +char g_share[MAX_BUFF_SIZE]; + + +void auth_fn(const char *server, const char *share, char *workgroup, int wgmaxlen, + char *username, int unmaxlen, char *password, int pwmaxlen) +{ + + strncpy(workgroup, g_workgroup, wgmaxlen - 1); + + strncpy(username, g_username, unmaxlen - 1); + + strncpy(password, g_password, pwmaxlen - 1); + + strcpy(g_server, server); + strcpy(g_share, share); + +} + +int main(int argc, char** argv) +{ + int err = -1; + int fd = 0; + int msg_len = 0; + char url[MAX_BUFF_SIZE]; + char* message; + + bzero(g_workgroup,MAX_BUFF_SIZE); + bzero(url,MAX_BUFF_SIZE); + + if ( argc == 6 ) + { + + strncpy(g_workgroup,argv[1],strlen(argv[1])); + strncpy(g_username,argv[2],strlen(argv[2])); + strncpy(g_password,argv[3],strlen(argv[3])); + strncpy(url,argv[4],strlen(argv[4])); + + msg_len = strlen(argv[5])+1; + message = malloc(msg_len); + message[msg_len - 1] = 0; + strncpy(message,argv[5],msg_len); + + smbc_init(auth_fn, 0); + smbc_unlink(url); + fd = smbc_open(url,O_RDWR | O_CREAT, 0666); + smbc_close(fd); + + fd = smbc_open(url, O_RDWR, 0666); + smbc_write(fd, message, msg_len); + smbc_close(fd); + + fd = smbc_open(url, O_RDWR, 0666); + err = smbc_lseek(fd,0,SEEK_END); + smbc_close(fd); + + if ( err != msg_len ) + err = 1; + + else + err = 0; + + free(message); + + } + + return err; + +} +