summaryrefslogtreecommitdiffstats
path: root/source4
diff options
context:
space:
mode:
authorStefan Metzmacher <metze@samba.org>2010-03-11 13:30:19 +0100
committerStefan Metzmacher <metze@samba.org>2010-03-11 13:31:40 +0100
commitdd934472e8e456abc01a99637f91528128bec369 (patch)
treea720bb84f92559c2a22435ba4dc345e144c5b629 /source4
parentb71bbbab8b491140e3de7374b4c9232d387157e3 (diff)
downloadsamba-dd934472e8e456abc01a99637f91528128bec369.tar.gz
samba-dd934472e8e456abc01a99637f91528128bec369.tar.xz
samba-dd934472e8e456abc01a99637f91528128bec369.zip
NET-API-BECOME-DC: convert to torture api
metze
Diffstat (limited to 'source4')
-rw-r--r--source4/torture/libnet/libnet_BecomeDC.c82
1 files changed, 28 insertions, 54 deletions
diff --git a/source4/torture/libnet/libnet_BecomeDC.c b/source4/torture/libnet/libnet_BecomeDC.c
index 104a5a2f2dd..1271d2c8d3c 100644
--- a/source4/torture/libnet/libnet_BecomeDC.c
+++ b/source4/torture/libnet/libnet_BecomeDC.c
@@ -590,7 +590,7 @@ bool torture_net_become_dc(struct torture_context *torture)
"torture_temp_dir should return NT_STATUS_OK" );
s = talloc_zero(torture, struct test_become_dc_state);
- if (!s) return false;
+ torture_assert(torture, s, "talloc_zero");
s->tctx = torture;
s->lp_ctx = torture->lp_ctx;
@@ -600,11 +600,9 @@ bool torture_net_become_dc(struct torture_context *torture)
/* do an initial name resolution to find its IP */
status = resolve_name(lp_resolve_context(torture->lp_ctx),
&name, torture, &address, torture->ev);
- if (!NT_STATUS_IS_OK(status)) {
- printf("Failed to resolve %s - %s\n",
- name.name, nt_errstr(status));
- return false;
- }
+ torture_assert_ntstatus_ok(torture, status, talloc_asprintf(torture,
+ "Failed to resolve %s - %s\n",
+ name.name, nt_errstr(status)));
s->netbios_name = lp_parm_string(torture->lp_ctx, NULL, "become dc", "smbtorture dc");
if (!s->netbios_name || !s->netbios_name[0]) {
@@ -617,11 +615,9 @@ bool torture_net_become_dc(struct torture_context *torture)
s->tj = torture_join_domain(torture, s->netbios_name,
ACB_WSTRUST,
&s->machine_account);
- if (!s->tj) {
- DEBUG(0, ("%s failed to join domain as workstation\n",
- s->netbios_name));
- return false;
- }
+ torture_assert(torture, s->tj, talloc_asprintf(torture,
+ "%s failed to join domain as workstation\n",
+ s->netbios_name));
s->ctx = libnet_context_init(torture->ev, torture->lp_ctx);
s->ctx->cred = cmdline_credentials;
@@ -643,66 +639,45 @@ bool torture_net_become_dc(struct torture_context *torture)
b.in.callbacks.domain_chunk = test_become_dc_store_chunk;
status = libnet_BecomeDC(s->ctx, s, &b);
- if (!NT_STATUS_IS_OK(status)) {
- printf("libnet_BecomeDC() failed - %s %s\n", nt_errstr(status), b.out.error_string);
- ret = false;
- goto cleanup;
- }
-
+ torture_assert_ntstatus_ok_goto(torture, status, ret, cleanup, talloc_asprintf(torture,
+ "libnet_BecomeDC() failed - %s %s\n",
+ nt_errstr(status), b.out.error_string));
msg = ldb_msg_new(s);
- if (!msg) {
- printf("ldb_msg_new() failed\n");
- ret = false;
- goto cleanup;
- }
+ torture_assert_int_equal_goto(torture, (msg?1:0), 1, ret, cleanup,
+ "ldb_msg_new() failed\n");
msg->dn = ldb_dn_new(msg, s->ldb, "@ROOTDSE");
- if (!msg->dn) {
- printf("ldb_msg_new(@ROOTDSE) failed\n");
- ret = false;
- goto cleanup;
- }
+ torture_assert_int_equal_goto(torture, (msg->dn?1:0), 1, ret, cleanup,
+ "ldb_msg_new(@ROOTDSE) failed\n");
ldb_ret = ldb_msg_add_string(msg, "isSynchronized", "TRUE");
- if (ldb_ret != LDB_SUCCESS) {
- printf("ldb_msg_add_string(msg, isSynchronized, TRUE) failed: %d\n", ldb_ret);
- ret = false;
- goto cleanup;
- }
+ torture_assert_int_equal_goto(torture, ldb_ret, LDB_SUCCESS, ret, cleanup,
+ "ldb_msg_add_string(msg, isSynchronized, TRUE) failed\n");
for (i=0; i < msg->num_elements; i++) {
msg->elements[i].flags = LDB_FLAG_MOD_REPLACE;
}
- printf("mark ROOTDSE with isSynchronized=TRUE\n");
+ torture_comment(torture, "mark ROOTDSE with isSynchronized=TRUE\n");
ldb_ret = ldb_modify(s->ldb, msg);
- if (ldb_ret != LDB_SUCCESS) {
- printf("ldb_modify() failed: %d\n", ldb_ret);
- ret = false;
- goto cleanup;
- }
+ torture_assert_int_equal_goto(torture, ldb_ret, LDB_SUCCESS, ret, cleanup,
+ "ldb_modify() failed\n");
/* reopen the ldb */
talloc_free(s->ldb); /* this also free's the s->schema, because dsdb_set_schema() steals it */
s->schema = NULL;
sam_ldb_path = talloc_asprintf(s, "%s/%s", s->targetdir, "private/sam.ldb");
- DEBUG(0,("Reopen the SAM LDB with system credentials and all replicated data: %s\n", sam_ldb_path));
+ torture_comment(torture, "Reopen the SAM LDB with system credentials and all replicated data: %s\n", sam_ldb_path);
s->ldb = ldb_wrap_connect(s, s->tctx->ev, s->lp_ctx, sam_ldb_path,
system_session(s->lp_ctx),
NULL, 0);
- if (!s->ldb) {
- DEBUG(0,("Failed to open '%s'\n",
- sam_ldb_path));
- ret = false;
- goto cleanup;
- }
+ torture_assert_int_equal_goto(torture, (s->ldb?1:0), 1, ret, cleanup,
+ talloc_asprintf(torture,
+ "Failed to open '%s'\n", sam_ldb_path));
s->schema = dsdb_get_schema(s->ldb);
- if (!s->schema) {
- DEBUG(0,("Failed to get loaded dsdb_schema\n"));
- ret = false;
- goto cleanup;
- }
+ torture_assert_int_equal_goto(torture, (s->schema?1:0), 1, ret, cleanup,
+ "Failed to get loaded dsdb_schema\n");
/* Make sure we get this from the command line */
if (lp_parm_bool(torture->lp_ctx, NULL, "become dc", "do not unjoin", false)) {
@@ -718,10 +693,9 @@ cleanup:
u.in.dest_dsa_netbios_name = s->netbios_name;
status = libnet_UnbecomeDC(s->ctx, s, &u);
- if (!NT_STATUS_IS_OK(status)) {
- printf("libnet_UnbecomeDC() failed - %s %s\n", nt_errstr(status), u.out.error_string);
- ret = false;
- }
+ torture_assert_ntstatus_ok(torture, status, talloc_asprintf(torture,
+ "libnet_UnbecomeDC() failed - %s %s\n",
+ nt_errstr(status), u.out.error_string));
/* Leave domain. */
torture_leave_domain(torture, s->tj);