1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-25 06:04:04 +03:00

s4:torture Remove _drs_util_verify_attids() from RPC-DSSYNC

I'm satisfied that the task this test does is already done by the time
we map the incoming schema, and process the objects.  If we have the
OID mapping wrong or incomplete, we will get any errors this test
found errors there.

(And this dramaticly reduces the test time, so we can now add
RPC-DSSYNC to 'make test').

Andrew Bartlett
This commit is contained in:
Andrew Bartlett 2009-11-12 08:08:26 +11:00
parent 6d1e60987b
commit 06b234e811
2 changed files with 0 additions and 87 deletions

View File

@ -41,7 +41,6 @@ ntvfs.cifs.raw.notify
ntvfs.cifs.raw.scan-eamax ntvfs.cifs.raw.scan-eamax
ntvfs.cifs.raw.context ntvfs.cifs.raw.context
ntvfs.cifs.raw.qfileinfo.ipc ntvfs.cifs.raw.qfileinfo.ipc
rpc.dssync
rpc.samsync rpc.samsync
rpc.remact # Not provided by Samba 4 rpc.remact # Not provided by Samba 4
rpc.oxidresolve # Not provided by Samba 4 rpc.oxidresolve # Not provided by Samba 4

View File

@ -79,11 +79,6 @@ struct DsSyncTest {
} old_dc; } old_dc;
}; };
static bool _drs_util_verify_attids(struct torture_context *tctx,
struct DsSyncTest *ctx,
const struct drsuapi_DsReplicaOIDMapping_Ctr *prefix_map,
const struct drsuapi_DsReplicaObjectListItemEx *cur);
static struct DsSyncTest *test_create_context(struct torture_context *tctx) static struct DsSyncTest *test_create_context(struct torture_context *tctx)
{ {
NTSTATUS status; NTSTATUS status;
@ -382,7 +377,6 @@ static bool test_analyse_objects(struct torture_context *tctx,
int i, j, ret; int i, j, ret;
struct dsdb_extended_replicated_objects *objs; struct dsdb_extended_replicated_objects *objs;
struct ldb_extended_dn_control *extended_dn_ctrl; struct ldb_extended_dn_control *extended_dn_ctrl;
_drs_util_verify_attids(tctx, ctx, mapping_ctr, first_object);
if (!dsdb_get_schema(ldb)) { if (!dsdb_get_schema(ldb)) {
struct dsdb_schema *ldap_schema; struct dsdb_schema *ldap_schema;
@ -714,86 +708,6 @@ static bool test_analyse_objects(struct torture_context *tctx,
return true; return true;
} }
/**
* Fetch LDAP attribute name and DN by supplied OID
*/
static bool _drs_ldap_attr_by_oid(struct torture_context *tctx,
struct DsSyncTest *ctx,
const char *oid,
char **attr_name)
{
struct ldb_dn *config_dn;
struct ldb_result *res;
TALLOC_CTX *tmp_ctx = NULL;
const char *search_attrs[] = {"lDAPDisplayName", NULL};
int ret;
tmp_ctx = talloc_new(ctx);
config_dn = ldb_dn_new_fmt(tmp_ctx, ctx->admin.ldap.ldb,
"CN=Schema,CN=Configuration,%s", ctx->domain_dn);
ret = ldb_search(ctx->admin.ldap.ldb, tmp_ctx, &res, config_dn,
LDB_SCOPE_ONELEVEL, search_attrs, "(attributeID=%s)", oid);
torture_assert_int_equal(tctx,
ret, LDB_SUCCESS,
"Failed to search for attribute");
torture_assert_int_equal(tctx,
res->count, 1, "Failed to find attribute for OID");
if (attr_name) {
*attr_name = talloc_strdup(ctx, ldb_msg_find_attr_as_string(res->msgs[0], "lDAPDisplayName", NULL));
}
talloc_free(tmp_ctx);
return true;
}
/**
* Make Attribute OID and verify such Attribute exists in schema
*/
static bool _drs_util_verify_attids(struct torture_context *tctx,
struct DsSyncTest *ctx,
const struct drsuapi_DsReplicaOIDMapping_Ctr *prefix_map,
const struct drsuapi_DsReplicaObjectListItemEx *cur)
{
uint32_t i;
DEBUG(1,("drs_test_verify_attids:\n"));
for (; cur; cur = cur->next_object) {
char *attr_name = NULL;
const struct drsuapi_DsReplicaObject *obj = &cur->object;
DEBUG(1,("%3s %-10s: %s\n", "", "object_dn", obj->identifier->dn));
for (i = 0; i < obj->attribute_ctr.num_attributes; i++) {
int map_idx;
const char *oid = NULL;
struct drsuapi_DsReplicaAttribute *attr;
attr = &obj->attribute_ctr.attributes[i];
if (!drs_util_oid_from_attid(tctx, prefix_map, attr->attid, &oid, &map_idx)) {
return false;
}
if (!_drs_ldap_attr_by_oid(tctx, ctx, oid, &attr_name)) {
return false;
}
DEBUG(10,("%7s attr[%2d]: %-22s {map_idx=%2d; attid=0x%06x; ldap_name=%-26s; idl_name=%s}\n", "",
i, oid, map_idx, attr->attid, attr_name,
drs_util_DsAttributeId_to_string(attr->attid)));
talloc_free(attr_name);
}
}
return true;
}
static bool test_FetchData(struct torture_context *tctx, struct DsSyncTest *ctx) static bool test_FetchData(struct torture_context *tctx, struct DsSyncTest *ctx)
{ {
NTSTATUS status; NTSTATUS status;