Bulk add of the test suite for libsmbclient ...
[sfrench/samba-autobuild/.git] / testsuite / libsmbclient / src / readdir / readdir_1.c
diff --git a/testsuite/libsmbclient/src/readdir/readdir_1.c b/testsuite/libsmbclient/src/readdir/readdir_1.c
new file mode 100644 (file)
index 0000000..5ca7e38
--- /dev/null
@@ -0,0 +1,107 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <errno.h>
+#include <libsmbclient.h>
+
+#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 dh = 0; 
+       int entry_num = 0;
+       int i = 0;
+       char *file_name;
+       char *tmp_file_ptr;
+
+       struct smbc_dirent *dirptr;
+
+
+       char buff[MAX_BUFF_SIZE];
+       char url[MAX_BUFF_SIZE];
+       char file_url[MAX_BUFF_SIZE];
+       char dir_url[MAX_BUFF_SIZE];
+       char dirbuff[MAX_BUFF_SIZE];
+
+       bzero(g_workgroup,MAX_BUFF_SIZE);
+       bzero(url,MAX_BUFF_SIZE);
+       bzero(file_url,MAX_BUFF_SIZE);
+       bzero(dir_url,MAX_BUFF_SIZE);
+       bzero(buff,MAX_BUFF_SIZE);
+
+       if ( argc == 6 )
+       {
+
+               dirptr = (struct smbc_dirent *) dirbuff;
+
+               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]));
+               smbc_init(auth_fn, 0);
+
+               strncpy(file_url,"tempfile-",9);
+               tmp_file_ptr = file_url;
+               tmp_file_ptr += 9;
+
+               smbc_rmdir(url);
+               smbc_mkdir(url,0666);
+
+               entry_num = atoi(argv[5]);
+               strcat(dir_url,url);
+               strcat(dir_url,"/");
+
+               file_name = dir_url;
+               file_name += strlen(dir_url);
+
+               for ( i = 0; i < entry_num; i++ )
+               {
+                       sprintf(buff,"%d",i);
+                       memcpy(tmp_file_ptr,buff,strlen(buff)+4);
+                       strncat(tmp_file_ptr,".txt",4);
+                       strcpy(file_name,file_url);
+                       fd = smbc_open(dir_url,O_RDWR | O_CREAT, 0666);
+                       smbc_close(fd);
+
+               }
+
+               dh = smbc_opendir(url);
+               dirptr = smbc_readdir( dh );
+
+               if ( dirptr == NULL )
+                       
+                       err = 1;
+
+               else
+                       err = 0;
+                       
+
+       }
+
+       return err;
+
+}
+