summaryrefslogtreecommitdiff
path: root/source4/torture/libnet/libnet_lookup.c
diff options
context:
space:
mode:
authorRafal Szczesniak <mimir@samba.org>2005-06-21 20:22:38 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 13:18:40 -0500
commitcc98a92bb0396845ec1dcb75ac412df9db9652d9 (patch)
tree0f11a92a8139db40f5f14dcf0c3387b5b107a26e /source4/torture/libnet/libnet_lookup.c
parent49417aaed7a9e2cc841cad2f418f7f84765cce36 (diff)
downloadsamba-cc98a92bb0396845ec1dcb75ac412df9db9652d9.tar.gz
samba-cc98a92bb0396845ec1dcb75ac412df9db9652d9.tar.bz2
samba-cc98a92bb0396845ec1dcb75ac412df9db9652d9.zip
r7816: Implementation of "shortcut" function for those (probably many) who
don't like to bother with netbios type names when looking for common types: hosts (servers) and domain controllers. Also, apropriate tests rafal (This used to be commit 50cd94be0f876a3463aa58b7e0898e6b3340c4c2)
Diffstat (limited to 'source4/torture/libnet/libnet_lookup.c')
-rw-r--r--source4/torture/libnet/libnet_lookup.c58
1 files changed, 54 insertions, 4 deletions
diff --git a/source4/torture/libnet/libnet_lookup.c b/source4/torture/libnet/libnet_lookup.c
index 058d43574c..b101f62960 100644
--- a/source4/torture/libnet/libnet_lookup.c
+++ b/source4/torture/libnet/libnet_lookup.c
@@ -32,21 +32,71 @@ BOOL torture_lookup(void)
TALLOC_CTX *mem_ctx;
struct libnet_Lookup lookup;
const char address[16];
- const char* methods[] = { "wins", "bcast", NULL };
+ const char** methods = lp_name_resolve_order();
- mem_ctx = talloc_init("test_userinfo");
+ mem_ctx = talloc_init("test_lookup");
lookup.in.hostname = lp_netbios_name();
- lookup.in.methods = NULL;
- lookup.in.type = NBT_NAME_SERVER;
+ lookup.in.methods = lp_name_resolve_order();
+ lookup.in.type = NBT_NAME_CLIENT;
lookup.out.address = (const char**)&address;
status = libnet_Lookup(mem_ctx, &lookup);
if (!NT_STATUS_IS_OK(status)) {
+ printf("Couldn't lookup name %s: %s\n", lookup.in.hostname, nt_errstr(status));
+ return False;
+ }
+
+ return True;
+}
+
+
+BOOL torture_lookup_host(void)
+{
+ NTSTATUS status;
+ TALLOC_CTX *mem_ctx;
+ struct libnet_Lookup lookup;
+ const char address[16];
+ const char** methods = lp_name_resolve_order();
+
+ mem_ctx = talloc_init("test_lookup_host");
+
+ lookup.in.hostname = lp_netbios_name();
+ lookup.in.methods = lp_name_resolve_order();
+ lookup.out.address = (const char**)&address;
+
+ status = libnet_LookupHost(mem_ctx, &lookup);
+
+ if (!NT_STATUS_IS_OK(status)) {
printf("Couldn't lookup host %s: %s\n", lookup.in.hostname, nt_errstr(status));
return False;
}
return True;
}
+
+
+BOOL torture_lookup_pdc(void)
+{
+ NTSTATUS status;
+ TALLOC_CTX *mem_ctx;
+ struct libnet_Lookup lookup;
+ const char address[16];
+ const char** methods = lp_name_resolve_order();
+
+ mem_ctx = talloc_init("test_lookup_pdc");
+
+ lookup.in.hostname = lp_workgroup();
+ lookup.in.methods = lp_name_resolve_order();
+ lookup.out.address = (const char**)&address;
+
+ status = libnet_LookupPdc(mem_ctx, &lookup);
+
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("Couldn't lookup pdc %s: %s\n", lookup.in.hostname, nt_errstr(status));
+ return False;
+ }
+
+ return True;
+}