diff options
Diffstat (limited to 'source/lib/netapi/tests')
-rw-r--r-- | source/lib/netapi/tests/Makefile.in | 57 | ||||
-rw-r--r-- | source/lib/netapi/tests/common.c | 86 | ||||
-rw-r--r-- | source/lib/netapi/tests/common.h | 57 | ||||
-rw-r--r-- | source/lib/netapi/tests/netapitest.c | 97 | ||||
-rw-r--r-- | source/lib/netapi/tests/netdisplay.c | 150 | ||||
-rw-r--r-- | source/lib/netapi/tests/netgroup.c | 286 | ||||
-rw-r--r-- | source/lib/netapi/tests/netlocalgroup.c | 226 | ||||
-rw-r--r-- | source/lib/netapi/tests/netshare.c | 232 | ||||
-rw-r--r-- | source/lib/netapi/tests/netuser.c | 458 |
9 files changed, 0 insertions, 1649 deletions
diff --git a/source/lib/netapi/tests/Makefile.in b/source/lib/netapi/tests/Makefile.in deleted file mode 100644 index d3f0663908..0000000000 --- a/source/lib/netapi/tests/Makefile.in +++ /dev/null @@ -1,57 +0,0 @@ -KRB5LIBS=@KRB5_LIBS@ -LDAP_LIBS=@LDAP_LIBS@ -LIBS=@LIBS@ -lnetapi -ltdb -ltalloc -DEVELOPER_CFLAGS=@DEVELOPER_CFLAGS@ -FLAGS=-I../ -L../../../bin @CFLAGS@ $(GTK_FLAGS) -CC=@CC@ -PICFLAG=@PICFLAG@ -LDFLAGS=@PIE_LDFLAGS@ @LDFLAGS@ -DYNEXP=@DYNEXP@ -NETAPI_LIBS=$(LIBS) $(KRB5LIBS) $(LDAP_LIBS) -CMDLINE_LIBS=$(NETAPI_LIBS) @POPTLIBS@ - -# Compile a source file. -COMPILE_CC = $(CC) -I. $(FLAGS) $(PICFLAG) -c $< -o $@ -COMPILE = $(COMPILE_CC) - -PROGS = bin/netapitest@EXEEXT@ - -all: $(PROGS) - -MAKEDIR = || exec false; \ - if test -d "$$dir"; then :; else \ - echo mkdir "$$dir"; \ - mkdir -p "$$dir" >/dev/null 2>&1 || \ - test -d "$$dir" || \ - mkdir "$$dir" || \ - exec false; fi || exec false - -BINARY_PREREQS = bin/.dummy - -bin/.dummy: - @if (: >> $@ || : > $@) >/dev/null 2>&1; then :; else \ - dir=bin $(MAKEDIR); fi - @: >> $@ || : > $@ # what a fancy emoticon! - -.c.o: - @if (: >> $@ || : > $@) >/dev/null 2>&1; then rm -f $@; else \ - dir=`echo $@ | sed 's,/[^/]*$$,,;s,^$$,.,'` $(MAKEDIR); fi - @echo Compiling $*.c - @$(COMPILE) && exit 0;\ - echo "The following command failed:" 1>&2;\ - echo "$(COMPILE_CC)" 1>&2;\ - $(COMPILE_CC) >/dev/null 2>&1 - -CMDLINE_OBJ = common.o -NETAPIBUFFER_OBJ = netapibuffer.o -NETAPITEST_OBJ = netapitest.o netlocalgroup.o netuser.o netgroup.o netdisplay.o netshare.o $(CMDLINE_OBJ) - -bin/netapitest@EXEEXT@: $(BINARY_PREREQS) $(NETAPITEST_OBJ) - @echo Linking $@ - @$(CC) $(FLAGS) -o $@ $(NETAPITEST_OBJ) $(LDFLAGS) $(DYNEXP) $(CMDLINE_LIBS) - -clean: - -rm -f $(PROGS) - -rm -f core */*~ *~ \ - */*.o */*/*.o */*/*/*.o - diff --git a/source/lib/netapi/tests/common.c b/source/lib/netapi/tests/common.c deleted file mode 100644 index 22175afb48..0000000000 --- a/source/lib/netapi/tests/common.c +++ /dev/null @@ -1,86 +0,0 @@ -/* - * Unix SMB/CIFS implementation. - * NetApi testsuite - * Copyright (C) Guenther Deschner 2008 - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, see <http://www.gnu.org/licenses/>. - */ - -#include <stdlib.h> -#include <string.h> -#include <sys/types.h> -#include <inttypes.h> - -#include <popt.h> -#include <netapi.h> - -#include "common.h" - -void popt_common_callback(poptContext con, - enum poptCallbackReason reason, - const struct poptOption *opt, - const char *arg, const void *data) -{ - struct libnetapi_ctx *ctx = NULL; - - libnetapi_getctx(&ctx); - - if (reason == POPT_CALLBACK_REASON_PRE) { - } - - if (reason == POPT_CALLBACK_REASON_POST) { - } - - if (!opt) { - return; - } - switch (opt->val) { - case 'U': { - char *puser = strdup(arg); - char *p = NULL; - - if ((p = strchr(puser,'%'))) { - size_t len; - *p = 0; - libnetapi_set_username(ctx, puser); - libnetapi_set_password(ctx, p+1); - len = strlen(p+1); - memset(strchr(arg,'%')+1,'X',len); - } else { - libnetapi_set_username(ctx, puser); - } - free(puser); - break; - } - case 'd': - libnetapi_set_debuglevel(ctx, arg); - break; - case 'p': - libnetapi_set_password(ctx, arg); - break; - case 'k': - libnetapi_set_use_kerberos(ctx); - break; - } -} - -struct poptOption popt_common_netapi_examples[] = { - { NULL, 0, POPT_ARG_CALLBACK|POPT_CBFLAG_PRE|POPT_CBFLAG_POST, (void *)popt_common_callback }, - { "user", 'U', POPT_ARG_STRING, NULL, 'U', "Username used for connection", "USERNAME" }, - { "password", 'p', POPT_ARG_STRING, NULL, 'p', "Password used for connection", "PASSWORD" }, - { "debuglevel", 'd', POPT_ARG_STRING, NULL, 'd', "Debuglevel", "DEBUGLEVEL" }, - { "kerberos", 'k', POPT_ARG_NONE, NULL, 'k', "Use Kerberos", NULL }, - POPT_TABLEEND -}; - diff --git a/source/lib/netapi/tests/common.h b/source/lib/netapi/tests/common.h deleted file mode 100644 index 5a320321ba..0000000000 --- a/source/lib/netapi/tests/common.h +++ /dev/null @@ -1,57 +0,0 @@ -/* - * Unix SMB/CIFS implementation. - * NetApi testsuite - * Copyright (C) Guenther Deschner 2008 - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, see <http://www.gnu.org/licenses/>. - */ - -#include <popt.h> - -void popt_common_callback(poptContext con, - enum poptCallbackReason reason, - const struct poptOption *opt, - const char *arg, const void *data); - -extern struct poptOption popt_common_netapi_examples[]; - -#define POPT_COMMON_LIBNETAPI_EXAMPLES { NULL, 0, POPT_ARG_INCLUDE_TABLE, popt_common_netapi_examples, 0, "Common samba netapi example options:", NULL }, - -NET_API_STATUS test_netuseradd(const char *hostname, - const char *username); - -NET_API_STATUS netapitest_localgroup(struct libnetapi_ctx *ctx, - const char *hostname); -NET_API_STATUS netapitest_user(struct libnetapi_ctx *ctx, - const char *hostname); -NET_API_STATUS netapitest_group(struct libnetapi_ctx *ctx, - const char *hostname); -NET_API_STATUS netapitest_display(struct libnetapi_ctx *ctx, - const char *hostname); -NET_API_STATUS netapitest_share(struct libnetapi_ctx *ctx, - const char *hostname); - -#ifndef ARRAY_SIZE -#define ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0])) -#endif - -#define NETAPI_STATUS(x,y,fn) \ - printf("FAILURE: line %d: %s failed with status: %s (%d)\n", \ - __LINE__, fn, libnetapi_get_error_string(x,y), y); - -#define NETAPI_STATUS_MSG(x,y,fn,z) \ - printf("FAILURE: line %d: %s failed with status: %s (%d), %s\n", \ - __LINE__, fn, libnetapi_get_error_string(x,y), y, z); - -#define ZERO_STRUCT(x) memset((char *)&(x), 0, sizeof(x)) diff --git a/source/lib/netapi/tests/netapitest.c b/source/lib/netapi/tests/netapitest.c deleted file mode 100644 index 87144020f5..0000000000 --- a/source/lib/netapi/tests/netapitest.c +++ /dev/null @@ -1,97 +0,0 @@ -/* - * Unix SMB/CIFS implementation. - * NetApi testsuite - * Copyright (C) Guenther Deschner 2008 - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, see <http://www.gnu.org/licenses/>. - */ - -#include <sys/types.h> -#include <inttypes.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> - -#include <netapi.h> - -#include "common.h" - -int main(int argc, const char **argv) -{ - NET_API_STATUS status = 0; - struct libnetapi_ctx *ctx = NULL; - const char *hostname = NULL; - - poptContext pc; - int opt; - - struct poptOption long_options[] = { - POPT_AUTOHELP - POPT_COMMON_LIBNETAPI_EXAMPLES - POPT_TABLEEND - }; - - status = libnetapi_init(&ctx); - if (status != 0) { - return status; - } - - pc = poptGetContext("netapitest", argc, argv, long_options, 0); - - poptSetOtherOptionHelp(pc, "hostname"); - while((opt = poptGetNextOpt(pc)) != -1) { - } - - if (!poptPeekArg(pc)) { - poptPrintHelp(pc, stderr, 0); - goto out; - } - hostname = poptGetArg(pc); - - status = netapitest_localgroup(ctx, hostname); - if (status) { - goto out; - } - - status = netapitest_user(ctx, hostname); - if (status) { - goto out; - } - - status = netapitest_group(ctx, hostname); - if (status) { - goto out; - } - - status = netapitest_display(ctx, hostname); - if (status) { - goto out; - } - - status = netapitest_share(ctx, hostname); - if (status) { - goto out; - } - - out: - if (status != 0) { - printf("testsuite failed with: %s\n", - libnetapi_get_error_string(ctx, status)); - } - - libnetapi_free(ctx); - poptFreeContext(pc); - - return status; -} diff --git a/source/lib/netapi/tests/netdisplay.c b/source/lib/netapi/tests/netdisplay.c deleted file mode 100644 index 090792cec2..0000000000 --- a/source/lib/netapi/tests/netdisplay.c +++ /dev/null @@ -1,150 +0,0 @@ -/* - * Unix SMB/CIFS implementation. - * NetGroup testsuite - * Copyright (C) Guenther Deschner 2008 - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, see <http://www.gnu.org/licenses/>. - */ - -#include <sys/types.h> -#include <inttypes.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> - -#include <netapi.h> - -#include "common.h" - -static NET_API_STATUS test_netquerydisplayinformation(const char *hostname, - uint32_t level, - const char *name) -{ - NET_API_STATUS status; - uint32_t entries_read = 0; - int found_name = 0; - const char *current_name; - uint8_t *buffer = NULL; - uint32_t idx = 0; - int i; - - struct NET_DISPLAY_USER *user; - struct NET_DISPLAY_GROUP *group; - struct NET_DISPLAY_MACHINE *machine; - - printf("testing NetQueryDisplayInformation level %d\n", level); - - do { - status = NetQueryDisplayInformation(hostname, - level, - idx, - 1000, - (uint32_t)-1, - &entries_read, - (void **)&buffer); - if (status == 0 || status == ERROR_MORE_DATA) { - switch (level) { - case 1: - user = (struct NET_DISPLAY_USER *)buffer; - break; - case 2: - machine = (struct NET_DISPLAY_MACHINE *)buffer; - break; - case 3: - group = (struct NET_DISPLAY_GROUP *)buffer; - break; - default: - return -1; - } - - for (i=0; i<entries_read; i++) { - - switch (level) { - case 1: - current_name = user->usri1_name; - break; - case 2: - current_name = machine->usri2_name; - break; - case 3: - current_name = group->grpi3_name; - break; - default: - break; - } - - if (name && strcasecmp(current_name, name) == 0) { - found_name = 1; - } - - switch (level) { - case 1: - user++; - break; - case 2: - machine++; - break; - case 3: - group++; - break; - } - } - NetApiBufferFree(buffer); - } - idx += entries_read; - } while (status == ERROR_MORE_DATA); - - if (status) { - return status; - } - - if (name && !found_name) { - printf("failed to get name\n"); - return -1; - } - - return 0; -} - -NET_API_STATUS netapitest_display(struct libnetapi_ctx *ctx, - const char *hostname) -{ - NET_API_STATUS status = 0; - uint32_t levels[] = { 1, 2, 3}; - int i; - - printf("NetDisplay tests\n"); - - /* test enum */ - - for (i=0; i<ARRAY_SIZE(levels); i++) { - - status = test_netquerydisplayinformation(hostname, levels[i], NULL); - if (status) { - NETAPI_STATUS(ctx, status, "NetQueryDisplayInformation"); - goto out; - } - } - - status = 0; - - printf("NetDisplay tests succeeded\n"); - out: - if (status != 0) { - printf("NetDisplay testsuite failed with: %s\n", - libnetapi_get_error_string(ctx, status)); - } - - return status; -} diff --git a/source/lib/netapi/tests/netgroup.c b/source/lib/netapi/tests/netgroup.c deleted file mode 100644 index a89a772ce4..0000000000 --- a/source/lib/netapi/tests/netgroup.c +++ /dev/null @@ -1,286 +0,0 @@ -/* - * Unix SMB/CIFS implementation. - * NetGroup testsuite - * Copyright (C) Guenther Deschner 2008 - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, see <http://www.gnu.org/licenses/>. - */ - -#include <sys/types.h> -#include <inttypes.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> - -#include <netapi.h> - -#include "common.h" - -static NET_API_STATUS test_netgroupenum(const char *hostname, - uint32_t level, - const char *groupname) -{ - NET_API_STATUS status; - uint32_t entries_read = 0; - uint32_t total_entries = 0; - uint32_t resume_handle = 0; - int found_group = 0; - const char *current_name; - uint8_t *buffer = NULL; - int i; - - struct GROUP_INFO_0 *info0; - struct GROUP_INFO_1 *info1; - struct GROUP_INFO_2 *info2; - struct GROUP_INFO_3 *info3; - - printf("testing NetGroupEnum level %d\n", level); - - do { - status = NetGroupEnum(hostname, - level, - &buffer, - 120, //(uint32_t)-1, - &entries_read, - &total_entries, - &resume_handle); - if (status == 0 || status == ERROR_MORE_DATA) { - switch (level) { - case 0: - info0 = (struct GROUP_INFO_0 *)buffer; - break; - case 1: - info1 = (struct GROUP_INFO_1 *)buffer; - break; - case 2: - info2 = (struct GROUP_INFO_2 *)buffer; - break; - case 3: - info3 = (struct GROUP_INFO_3 *)buffer; - break; - default: - return -1; - } - - for (i=0; i<entries_read; i++) { - - switch (level) { - case 0: - current_name = info0->grpi0_name; - break; - case 1: - current_name = info1->grpi1_name; - break; - case 2: - current_name = info2->grpi2_name; - break; - case 3: - current_name = info3->grpi3_name; - break; - default: - break; - } - - if (strcasecmp(current_name, groupname) == 0) { - found_group = 1; - } - - switch (level) { - case 0: - info0++; - break; - case 1: - info1++; - break; - case 2: - info2++; - break; - case 3: - info3++; - break; - } - } - NetApiBufferFree(buffer); - } - } while (status == ERROR_MORE_DATA); - - if (status) { - return status; - } - - if (!found_group) { - printf("failed to get group\n"); - return -1; - } - - return 0; -} - -NET_API_STATUS netapitest_group(struct libnetapi_ctx *ctx, - const char *hostname) -{ - NET_API_STATUS status = 0; - const char *username, *groupname, *groupname2; - uint8_t *buffer = NULL; - struct GROUP_INFO_0 g0; - uint32_t parm_err = 0; - uint32_t levels[] = { 0, 1, 2, 3}; - uint32_t enum_levels[] = { 0, 1, 2, 3}; - int i; - - printf("NetGroup tests\n"); - - username = "torture_test_user"; - groupname = "torture_test_group"; - groupname2 = "torture_test_group2"; - - /* cleanup */ - NetGroupDel(hostname, groupname); - NetGroupDel(hostname, groupname2); - NetUserDel(hostname, username); - - /* add a group */ - - g0.grpi0_name = groupname; - - printf("testing NetGroupAdd\n"); - - status = NetGroupAdd(hostname, 0, (uint8_t *)&g0, &parm_err); - if (status) { - NETAPI_STATUS(ctx, status, "NetGroupAdd"); - goto out; - } - - /* 2nd add must fail */ - - status = NetGroupAdd(hostname, 0, (uint8_t *)&g0, &parm_err); - if (status == 0) { - NETAPI_STATUS(ctx, status, "NetGroupAdd"); - goto out; - } - - /* test enum */ - - for (i=0; i<ARRAY_SIZE(enum_levels); i++) { - - status = test_netgroupenum(hostname, enum_levels[i], groupname); - if (status) { - NETAPI_STATUS(ctx, status, "NetGroupEnum"); - goto out; - } - } - - /* basic queries */ - - for (i=0; i<ARRAY_SIZE(levels); i++) { - - printf("testing NetGroupGetInfo level %d\n", levels[i]); - - status = NetGroupGetInfo(hostname, groupname, levels[i], &buffer); - if (status && status != 124) { - NETAPI_STATUS(ctx, status, "NetGroupGetInfo"); - goto out; - } - } - - /* group rename */ - - g0.grpi0_name = groupname2; - - printf("testing NetGroupSetInfo level 0\n"); - - status = NetGroupSetInfo(hostname, groupname, 0, (uint8_t *)&g0, &parm_err); - if (status) { - NETAPI_STATUS(ctx, status, "NetGroupSetInfo"); - goto out; - } - - /* should not exist anymore */ - - status = NetGroupDel(hostname, groupname); - if (status == 0) { - NETAPI_STATUS(ctx, status, "NetGroupDel"); - goto out; - } - - /* query info */ - - for (i=0; i<ARRAY_SIZE(levels); i++) { - - status = NetGroupGetInfo(hostname, groupname2, levels[i], &buffer); - if (status && status != 124) { - NETAPI_STATUS(ctx, status, "NetGroupGetInfo"); - goto out; - } - } - - /* add user to group */ - - status = test_netuseradd(hostname, username); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserAdd"); - goto out; - } - - printf("testing NetGroupAddUser\n"); - - status = NetGroupAddUser(hostname, groupname2, username); - if (status) { - NETAPI_STATUS(ctx, status, "NetGroupAddUser"); - goto out; - } - - printf("testing NetGroupDelUser\n"); - - status = NetGroupDelUser(hostname, groupname2, username); - if (status) { - NETAPI_STATUS(ctx, status, "NetGroupDelUser"); - goto out; - } - - status = NetUserDel(hostname, username); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserDel"); - goto out; - } - - /* delete */ - - printf("testing NetGroupDel\n"); - - status = NetGroupDel(hostname, groupname2); - if (status) { - NETAPI_STATUS(ctx, status, "NetGroupDel"); - goto out; - }; - - /* should not exist anymore */ - - status = NetGroupGetInfo(hostname, groupname2, 0, &buffer); - if (status == 0) { - NETAPI_STATUS_MSG(ctx, status, "NetGroupGetInfo", "expected failure and error code"); - goto out; - }; - - status = 0; - - printf("NetGroup tests succeeded\n"); - out: - if (status != 0) { - printf("NetGroup testsuite failed with: %s\n", - libnetapi_get_error_string(ctx, status)); - } - - return status; -} diff --git a/source/lib/netapi/tests/netlocalgroup.c b/source/lib/netapi/tests/netlocalgroup.c deleted file mode 100644 index 0d82059356..0000000000 --- a/source/lib/netapi/tests/netlocalgroup.c +++ /dev/null @@ -1,226 +0,0 @@ -/* - * Unix SMB/CIFS implementation. - * NetLocalGroup testsuite - * Copyright (C) Guenther Deschner 2008 - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, see <http://www.gnu.org/licenses/>. - */ - -#include <sys/types.h> -#include <inttypes.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> - -#include <netapi.h> - -#include "common.h" - -static NET_API_STATUS test_netlocalgroupenum(const char *hostname, - uint32_t level, - const char *groupname) -{ - NET_API_STATUS status; - uint32_t entries_read = 0; - uint32_t total_entries = 0; - uint32_t resume_handle = 0; - int found_group = 0; - const char *current_name; - uint8_t *buffer = NULL; - int i; - - struct LOCALGROUP_INFO_0 *info0; - struct LOCALGROUP_INFO_1 *info1; - - printf("testing NetLocalGroupEnum level %d\n", level); - - do { - status = NetLocalGroupEnum(hostname, - level, - &buffer, - (uint32_t)-1, - &entries_read, - &total_entries, - &resume_handle); - if (status == 0 || status == ERROR_MORE_DATA) { - switch (level) { - case 0: - info0 = (struct LOCALGROUP_INFO_0 *)buffer; - break; - case 1: - info1 = (struct LOCALGROUP_INFO_1 *)buffer; - break; - default: - return -1; - } - - for (i=0; i<entries_read; i++) { - - switch (level) { - case 0: - current_name = info0->lgrpi0_name; - break; - case 1: - current_name = info1->lgrpi1_name; - break; - default: - break; - } - - if (strcasecmp(current_name, groupname) == 0) { - found_group = 1; - } - - switch (level) { - case 0: - info0++; - break; - case 1: - info1++; - break; - } - } - NetApiBufferFree(buffer); - } - } while (status == ERROR_MORE_DATA); - - if (status) { - return status; - } - - if (!found_group) { - printf("failed to get group\n"); - return -1; - } - - return 0; -} - -NET_API_STATUS netapitest_localgroup(struct libnetapi_ctx *ctx, - const char *hostname) -{ - NET_API_STATUS status = 0; - const char *groupname, *groupname2; - uint8_t *buffer = NULL; - struct LOCALGROUP_INFO_0 g0; - uint32_t parm_err = 0; - uint32_t levels[] = { 0, 1, 1002 }; - uint32_t enum_levels[] = { 0, 1 }; - int i; - - printf("NetLocalgroup tests\n"); - - groupname = "torture_test_localgroup"; - groupname2 = "torture_test_localgroup2"; - - /* cleanup */ - NetLocalGroupDel(hostname, groupname); - NetLocalGroupDel(hostname, groupname2); - - /* add a localgroup */ - - printf("testing NetLocalGroupAdd\n"); - - g0.lgrpi0_name = groupname; - - status = NetLocalGroupAdd(hostname, 0, (uint8_t *)&g0, &parm_err); - if (status) { - NETAPI_STATUS(ctx, status, "NetLocalGroupAdd"); - goto out; - }; - - /* test enum */ - - for (i=0; i<ARRAY_SIZE(enum_levels); i++) { - - status = test_netlocalgroupenum(hostname, enum_levels[i], groupname); - if (status) { - NETAPI_STATUS(ctx, status, "NetLocalGroupEnum"); - goto out; - } - } - - - /* basic queries */ - - for (i=0; i<ARRAY_SIZE(levels); i++) { - - printf("testing NetLocalGroupGetInfo level %d\n", levels[i]); - - status = NetLocalGroupGetInfo(hostname, groupname, levels[i], &buffer); - if (status && status != 124) { - NETAPI_STATUS(ctx, status, "NetLocalGroupGetInfo"); - goto out; - }; - } - - /* alias rename */ - - printf("testing NetLocalGroupSetInfo level 0\n"); - - g0.lgrpi0_name = groupname2; - - status = NetLocalGroupSetInfo(hostname, groupname, 0, (uint8_t *)&g0, &parm_err); - if (status) { - NETAPI_STATUS(ctx, status, "NetLocalGroupSetInfo"); - goto out; - }; - - /* should not exist anymore */ - - status = NetLocalGroupDel(hostname, groupname); - if (status == 0) { - NETAPI_STATUS(ctx, status, "NetLocalGroupDel"); - goto out; - }; - - /* query info */ - - for (i=0; i<ARRAY_SIZE(levels); i++) { - status = NetLocalGroupGetInfo(hostname, groupname2, levels[i], &buffer); - if (status && status != 124) { - NETAPI_STATUS(ctx, status, "NetLocalGroupGetInfo"); - goto out; - }; - } - - /* delete */ - - printf("testing NetLocalGroupDel\n"); - - status = NetLocalGroupDel(hostname, groupname2); - if (status) { - NETAPI_STATUS(ctx, status, "NetLocalGroupDel"); - goto out; - }; - - /* should not exist anymore */ - - status = NetLocalGroupGetInfo(hostname, groupname2, 0, &buffer); - if (status == 0) { - NETAPI_STATUS(ctx, status, "NetLocalGroupGetInfo"); - goto out; - }; - - status = 0; - - printf("NetLocalgroup tests succeeded\n"); - out: - if (status != 0) { - printf("NetLocalGroup testsuite failed with: %s\n", - libnetapi_get_error_string(ctx, status)); - } - - return status; -} diff --git a/source/lib/netapi/tests/netshare.c b/source/lib/netapi/tests/netshare.c deleted file mode 100644 index 9446c307b3..0000000000 --- a/source/lib/netapi/tests/netshare.c +++ /dev/null @@ -1,232 +0,0 @@ -/* - * Unix SMB/CIFS implementation. - * NetShare testsuite - * Copyright (C) Guenther Deschner 2008 - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, see <http://www.gnu.org/licenses/>. - */ - -#include <sys/types.h> -#include <inttypes.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> - -#include <netapi.h> - -#include "common.h" - -static NET_API_STATUS test_netshareenum(const char *hostname, - uint32_t level, - const char *sharename) -{ - NET_API_STATUS status; - uint32_t entries_read = 0; - uint32_t total_entries = 0; - uint32_t resume_handle = 0; - int found_share = 0; - const char *current_name; - uint8_t *buffer = NULL; - int i; - - struct SHARE_INFO_0 *i0; - struct SHARE_INFO_1 *i1; - struct SHARE_INFO_2 *i2; - - printf("testing NetShareEnum level %d\n", level); - - do { - status = NetShareEnum(hostname, - level, - &buffer, - (uint32_t)-1, - &entries_read, - &total_entries, - &resume_handle); - if (status == 0 || status == ERROR_MORE_DATA) { - switch (level) { - case 0: - i0 = (struct SHARE_INFO_0 *)buffer; - break; - case 1: - i1 = (struct SHARE_INFO_1 *)buffer; - break; - case 2: - i2 = (struct SHARE_INFO_2 *)buffer; - break; - default: - return -1; - } - - for (i=0; i<entries_read; i++) { - - switch (level) { - case 0: - current_name = i0->shi0_netname; - break; - case 1: - current_name = i1->shi1_netname; - break; - case 2: - current_name = i2->shi2_netname; - break; - default: - break; - } - - if (strcasecmp(current_name, sharename) == 0) { - found_share = 1; - } - - switch (level) { - case 0: - i0++; - break; - case 1: - i1++; - break; - case 2: - i2++; - break; - } - } - NetApiBufferFree(buffer); - } - } while (status == ERROR_MORE_DATA); - - if (status) { - return status; - } - - if (!found_share) { - printf("failed to get share\n"); - return -1; - } - - return 0; -} - -NET_API_STATUS netapitest_share(struct libnetapi_ctx *ctx, - const char *hostname) -{ - NET_API_STATUS status = 0; - const char *sharename, *comment; - uint8_t *buffer = NULL; - struct SHARE_INFO_2 i2; - struct SHARE_INFO_1004 i1004; - struct SHARE_INFO_501 *i501 = NULL; - uint32_t parm_err = 0; - uint32_t levels[] = { 0, 1, 2, 501, 1005 }; - uint32_t enum_levels[] = { 0, 1, 2 }; - int i; - - printf("NetShare tests\n"); - - sharename = "torture_test_share"; - - /* cleanup */ - NetShareDel(hostname, sharename, 0); - - /* add a share */ - - printf("testing NetShareAdd\n"); - - ZERO_STRUCT(i2); - - i2.shi2_netname = sharename; - i2.shi2_path = "c:\\"; - - status = NetShareAdd(hostname, 2, (uint8_t *)&i2, &parm_err); - if (status) { - NETAPI_STATUS(ctx, status, "NetShareAdd"); - goto out; - }; - - /* test enum */ - - for (i=0; i<ARRAY_SIZE(enum_levels); i++) { - - status = test_netshareenum(hostname, enum_levels[i], sharename); - if (status) { - NETAPI_STATUS(ctx, status, "NetShareEnum"); - goto out; - } - } - - /* basic queries */ - - for (i=0; i<ARRAY_SIZE(levels); i++) { - - printf("testing NetShareGetInfo level %d\n", levels[i]); - - status = NetShareGetInfo(hostname, sharename, levels[i], &buffer); - if (status && status != 124) { - NETAPI_STATUS(ctx, status, "NetShareGetInfo"); - goto out; - } - } - - - comment = "NetApi generated comment"; - - i1004.shi1004_remark = comment; - - printf("testing NetShareSetInfo level 1004\n"); - - status = NetShareSetInfo(hostname, sharename, 1004, (uint8_t *)&i1004, &parm_err); - if (status) { - NETAPI_STATUS(ctx, status, "NetShareSetInfo"); - goto out; - } - - status = NetShareGetInfo(hostname, sharename, 501, (uint8_t **)&i501); - if (status) { - NETAPI_STATUS(ctx, status, "NetShareGetInfo"); - goto out; - } - - if (strcasecmp(i501->shi501_remark, comment) != 0) { - NETAPI_STATUS(ctx, status, "NetShareGetInfo"); - goto out; - } - - /* delete */ - - printf("testing NetShareDel\n"); - - status = NetShareDel(hostname, sharename, 0); - if (status) { - NETAPI_STATUS(ctx, status, "NetShareDel"); - goto out; - }; - - /* should not exist anymore */ - - status = NetShareGetInfo(hostname, sharename, 0, &buffer); - if (status == 0) { - NETAPI_STATUS(ctx, status, "NetShareGetInfo"); - goto out; - }; - - status = 0; - - printf("NetShare tests succeeded\n"); - out: - if (status != 0) { - printf("NetShare testsuite failed with: %s\n", - libnetapi_get_error_string(ctx, status)); - } - - return status; -} diff --git a/source/lib/netapi/tests/netuser.c b/source/lib/netapi/tests/netuser.c deleted file mode 100644 index f1622e45c4..0000000000 --- a/source/lib/netapi/tests/netuser.c +++ /dev/null @@ -1,458 +0,0 @@ -/* - * Unix SMB/CIFS implementation. - * NetUser testsuite - * Copyright (C) Guenther Deschner 2008 - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, see <http://www.gnu.org/licenses/>. - */ - -#include <sys/types.h> -#include <inttypes.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> - -#include <netapi.h> - -#include "common.h" - -static NET_API_STATUS test_netuserenum(const char *hostname, - uint32_t level, - const char *username) -{ - NET_API_STATUS status; - uint32_t entries_read = 0; - uint32_t total_entries = 0; - uint32_t resume_handle = 0; - const char *current_name; - int found_user = 0; - uint8_t *buffer = NULL; - int i; - - struct USER_INFO_0 *info0; - struct USER_INFO_1 *info1; - struct USER_INFO_2 *info2; - struct USER_INFO_3 *info3; - struct USER_INFO_4 *info4; - struct USER_INFO_10 *info10; - struct USER_INFO_11 *info11; - struct USER_INFO_20 *info20; - struct USER_INFO_23 *info23; - - printf("testing NetUserEnum level %d\n", level); - - do { - status = NetUserEnum(hostname, - level, - FILTER_NORMAL_ACCOUNT, - &buffer, - 120, //(uint32_t)-1, - &entries_read, - &total_entries, - &resume_handle); - if (status == 0 || status == ERROR_MORE_DATA) { - switch (level) { - case 0: - info0 = (struct USER_INFO_0 *)buffer; - break; - case 1: - info1 = (struct USER_INFO_1 *)buffer; - break; - case 2: - info2 = (struct USER_INFO_2 *)buffer; - break; - case 3: - info3 = (struct USER_INFO_3 *)buffer; - break; - case 4: - info4 = (struct USER_INFO_4 *)buffer; - break; - case 10: - info10 = (struct USER_INFO_10 *)buffer; - break; - case 11: - info11 = (struct USER_INFO_11 *)buffer; - break; - case 20: - info20 = (struct USER_INFO_20 *)buffer; - break; - case 23: - info23 = (struct USER_INFO_23 *)buffer; - break; - default: - return -1; - } - - for (i=0; i<entries_read; i++) { - - switch (level) { - case 0: - current_name = info0->usri0_name; - break; - case 1: - current_name = info1->usri1_name; - break; - case 2: - current_name = info2->usri2_name; - break; - case 3: - current_name = info3->usri3_name; - break; - case 4: - current_name = info4->usri4_name; - break; - case 10: - current_name = info10->usri10_name; - break; - case 11: - current_name = info11->usri11_name; - break; - case 20: - current_name = info20->usri20_name; - break; - case 23: - current_name = info23->usri23_name; - break; - default: - return -1; - } - - if (strcasecmp(current_name, username) == 0) { - found_user = 1; - } - - switch (level) { - case 0: - info0++; - break; - case 1: - info1++; - break; - case 2: - info2++; - break; - case 3: - info3++; - break; - case 4: - info4++; - break; - case 10: - info10++; - break; - case 11: - info11++; - break; - case 20: - info20++; - break; - case 23: - info23++; - break; - default: - break; - } - } - NetApiBufferFree(buffer); - } - } while (status == ERROR_MORE_DATA); - - if (status) { - return status; - } - - if (!found_user) { - printf("failed to get user\n"); - return -1; - } - - return 0; -} - -NET_API_STATUS test_netuseradd(const char *hostname, - const char *username) -{ - struct USER_INFO_1 u1; - uint32_t parm_err = 0; - - ZERO_STRUCT(u1); - - printf("testing NetUserAdd\n"); - - u1.usri1_name = username; - u1.usri1_password = "W297!832jD8J"; - u1.usri1_password_age = 0; - u1.usri1_priv = 0; - u1.usri1_home_dir = NULL; - u1.usri1_comment = "User created using Samba NetApi Example code"; - u1.usri1_flags = 0; - u1.usri1_script_path = NULL; - - return NetUserAdd(hostname, 1, (uint8_t *)&u1, &parm_err); -} - -static NET_API_STATUS test_netusermodals(struct libnetapi_ctx *ctx, - const char *hostname) -{ - NET_API_STATUS status; - struct USER_MODALS_INFO_0 *u0 = NULL; - struct USER_MODALS_INFO_0 *_u0 = NULL; - uint8_t *buffer = NULL; - uint32_t parm_err = 0; - uint32_t levels[] = { 0, 1, 2, 3 }; - int i = 0; - - for (i=0; i<ARRAY_SIZE(levels); i++) { - - printf("testing NetUserModalsGet level %d\n", levels[i]); - - status = NetUserModalsGet(hostname, levels[i], &buffer); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserModalsGet"); - return status; - } - } - - status = NetUserModalsGet(hostname, 0, (uint8_t **)&u0); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserModalsGet"); - return status; - } - - printf("testing NetUserModalsSet\n"); - - status = NetUserModalsSet(hostname, 0, (uint8_t *)u0, &parm_err); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserModalsSet"); - return status; - } - - status = NetUserModalsGet(hostname, 0, (uint8_t **)&_u0); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserModalsGet"); - return status; - } - - if (memcmp(u0, _u0, sizeof(u0) != 0)) { - printf("USER_MODALS_INFO_0 struct has changed!!!!\n"); - return -1; - } - - return 0; -} - -static NET_API_STATUS test_netusergetgroups(const char *hostname, - uint32_t level, - const char *username, - const char *groupname) -{ - NET_API_STATUS status; - uint32_t entries_read = 0; - uint32_t total_entries = 0; - const char *current_name; - int found_group = 0; - uint8_t *buffer = NULL; - int i; - - struct GROUP_USERS_INFO_0 *i0; - struct GROUP_USERS_INFO_1 *i1; - - printf("testing NetUserGetGroups level %d\n", level); - - do { - status = NetUserGetGroups(hostname, - username, - level, - &buffer, - 120, //(uint32_t)-1, - &entries_read, - &total_entries); - if (status == 0 || status == ERROR_MORE_DATA) { - switch (level) { - case 0: - i0 = (struct GROUP_USERS_INFO_0 *)buffer; - break; - case 1: - i1 = (struct GROUP_USERS_INFO_1 *)buffer; - break; - default: - return -1; - } - - for (i=0; i<entries_read; i++) { - - switch (level) { - case 0: - current_name = i0->grui0_name; - break; - case 1: - current_name = i1->grui1_name; - break; - default: - return -1; - } - - if (groupname && strcasecmp(current_name, groupname) == 0) { - found_group = 1; - } - - switch (level) { - case 0: - i0++; - break; - case 1: - i1++; - break; - default: - break; - } - } - NetApiBufferFree(buffer); - } - } while (status == ERROR_MORE_DATA); - - if (status) { - return status; - } - - if (groupname && !found_group) { - printf("failed to get membership\n"); - return -1; - } - - return 0; -} - -NET_API_STATUS netapitest_user(struct libnetapi_ctx *ctx, - const char *hostname) -{ - NET_API_STATUS status = 0; - const char *username, *username2; - uint8_t *buffer = NULL; - uint32_t levels[] = { 0, 1, 2, 3, 4, 10, 11, 20, 23 }; - uint32_t enum_levels[] = { 0, 1, 2, 3, 4, 10, 11, 20, 23 }; - uint32_t getgr_levels[] = { 0, 1 }; - int i; - - struct USER_INFO_1007 u1007; - uint32_t parm_err = 0; - - printf("NetUser tests\n"); - - username = "torture_test_user"; - username2 = "torture_test_user2"; - - /* cleanup */ - NetUserDel(hostname, username); - NetUserDel(hostname, username2); - - /* add a user */ - - status = test_netuseradd(hostname, username); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserAdd"); - goto out; - } - - /* enum the new user */ - - for (i=0; i<ARRAY_SIZE(enum_levels); i++) { - - status = test_netuserenum(hostname, enum_levels[i], username); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserEnum"); - goto out; - } - } - - /* basic queries */ - - for (i=0; i<ARRAY_SIZE(levels); i++) { - - printf("testing NetUserGetInfo level %d\n", levels[i]); - - status = NetUserGetInfo(hostname, username, levels[i], &buffer); - if (status && status != 124) { - NETAPI_STATUS(ctx, status, "NetUserGetInfo"); - goto out; - } - } - - /* testing getgroups */ - - for (i=0; i<ARRAY_SIZE(getgr_levels); i++) { - - status = test_netusergetgroups(hostname, getgr_levels[i], username, NULL); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserGetGroups"); - goto out; - } - } - - /* modify description */ - - printf("testing NetUserSetInfo level %d\n", 1007); - - u1007.usri1007_comment = "NetApi modified user"; - - status = NetUserSetInfo(hostname, username, 1007, (uint8_t *)&u1007, &parm_err); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserSetInfo"); - goto out; - } - - /* query info */ - - for (i=0; i<ARRAY_SIZE(levels); i++) { - status = NetUserGetInfo(hostname, username, levels[i], &buffer); - if (status && status != 124) { - NETAPI_STATUS(ctx, status, "NetUserGetInfo"); - goto out; - } - } - - /* delete */ - - printf("testing NetUserDel\n"); - - status = NetUserDel(hostname, username); - if (status) { - NETAPI_STATUS(ctx, status, "NetUserDel"); - goto out; - } - - /* should not exist anymore */ - - status = NetUserGetInfo(hostname, username, 0, &buffer); - if (status == 0) { - NETAPI_STATUS(ctx, status, "NetUserGetInfo"); - goto out; - } - - status = test_netusermodals(ctx, hostname); - if (status) { - goto out; - } - - status = 0; - - printf("NetUser tests succeeded\n"); - out: - if (status != 0) { - printf("NetUser testsuite failed with: %s\n", - libnetapi_get_error_string(ctx, status)); - } - - return status; -} |