s4:torture/netlogon: add/use test_SetupCredentialsPipe() helper function
[samba.git] / source4 / torture / rpc / join.c
index 8ea94279be6e3b97fe0f065ab25b87f1b4dc10aa..6e0afcac28187ed2436288867f68a2729388e580 100644 (file)
@@ -1,41 +1,86 @@
 #include "includes.h"
-#include "libnet/libnet.h"
+#include "libcli/libcli.h"
+
+#include "torture/rpc/torture_rpc.h"
+
+#include "libcli/resolve/resolve.h"
+#include "param/param.h"
 
 #define TORTURE_NETBIOS_NAME "smbtorturejoin"
 
 
-BOOL torture_rpc_join(void)
-{  
+bool torture_rpc_join(struct torture_context *torture)
+{
+       NTSTATUS status;
        struct test_join *tj;
        struct cli_credentials *machine_account;
+       struct smbcli_state *cli;
+       const char *host = torture_setting_string(torture, "host", NULL);
+       struct smbcli_options options;
+       struct smbcli_session_options session_options;
 
        /* Join domain as a member server. */
-       tj = torture_join_domain(TORTURE_NETBIOS_NAME,
+       tj = torture_join_domain(torture,
+                                TORTURE_NETBIOS_NAME,
                                 ACB_WSTRUST,
                                 &machine_account);
 
        if (!tj) {
-               DEBUG(0, ("%s failed to join domain\n",
+               DEBUG(0, ("%s failed to join domain as workstation\n",
+                         TORTURE_NETBIOS_NAME));
+               return false;
+       }
+
+       lpcfg_smbcli_options(torture->lp_ctx, &options);
+       lpcfg_smbcli_session_options(torture->lp_ctx, &session_options);
+
+       status = smbcli_full_connection(tj, &cli, host,
+                                       lpcfg_smb_ports(torture->lp_ctx),
+                                       "IPC$", NULL,
+                                       lpcfg_socket_options(torture->lp_ctx),
+                                       machine_account,
+                                       lpcfg_resolve_context(torture->lp_ctx),
+                                       torture->ev, &options, &session_options,
+                                       lpcfg_gensec_settings(torture, torture->lp_ctx));
+       if (!NT_STATUS_IS_OK(status)) {
+               DEBUG(0, ("%s failed to connect to IPC$ with workstation credentials\n",
                          TORTURE_NETBIOS_NAME));
-               return False;
+               return false;   
        }
+       smbcli_tdis(cli);
         
        /* Leave domain. */                          
-       torture_leave_domain(tj);
+       torture_leave_domain(torture, tj);
         
        /* Join domain as a domain controller. */
-       tj = torture_join_domain(TORTURE_NETBIOS_NAME,
+       tj = torture_join_domain(torture, TORTURE_NETBIOS_NAME,
                                 ACB_SVRTRUST,
                                 &machine_account);
        if (!tj) {
-               DEBUG(0, ("%s failed to join domain\n",
+               DEBUG(0, ("%s failed to join domain as domain controller\n",
                          TORTURE_NETBIOS_NAME));
-               return False;
+               return false;
        }
 
+       status = smbcli_full_connection(tj, &cli, host,
+                                       lpcfg_smb_ports(torture->lp_ctx),
+                                       "IPC$", NULL,
+                                       lpcfg_socket_options(torture->lp_ctx),
+                                       machine_account,
+                                       lpcfg_resolve_context(torture->lp_ctx),
+                                       torture->ev, &options, &session_options,
+                                       lpcfg_gensec_settings(torture, torture->lp_ctx));
+       if (!NT_STATUS_IS_OK(status)) {
+               DEBUG(0, ("%s failed to connect to IPC$ with workstation credentials\n",
+                         TORTURE_NETBIOS_NAME));
+               return false;   
+       }
+
+       smbcli_tdis(cli);
+
        /* Leave domain. */
-       torture_leave_domain(tj);
+       torture_leave_domain(torture, tj);
 
-       return True;
+       return true;
 }