Fix building domain def in securityselinuxtest

The virDomainDef created by testBuildDomainDef in securityselinuxtest
adds a seclabel but does not increment nseclabels. Also, it should
populate seclabel->model with 'selinux'.

While at it, use the secdef itself to populate values instead of
the indirection through def->seclabels[0].
This commit is contained in:
Jim Fehlig 2017-08-16 15:45:54 -06:00
parent 6134dc2a6b
commit ff7e0a1a40

View File

@ -73,24 +73,27 @@ testBuildDomainDef(bool dynamic,
if (!(def = virDomainDefNew())) if (!(def = virDomainDefNew()))
goto error; goto error;
def->virtType = VIR_DOMAIN_VIRT_KVM;
if (VIR_ALLOC_N(def->seclabels, 1) < 0) if (VIR_ALLOC_N(def->seclabels, 1) < 0)
goto error; goto error;
if (VIR_ALLOC(secdef) < 0) if (VIR_ALLOC(secdef) < 0)
goto error; goto error;
def->virtType = VIR_DOMAIN_VIRT_KVM; if (VIR_STRDUP(secdef->model, "selinux") < 0)
def->seclabels[0] = secdef; goto error;
def->seclabels[0]->type = dynamic ? VIR_DOMAIN_SECLABEL_DYNAMIC : VIR_DOMAIN_SECLABEL_STATIC;
secdef->type = dynamic ? VIR_DOMAIN_SECLABEL_DYNAMIC : VIR_DOMAIN_SECLABEL_STATIC;
if (label && if (label &&
VIR_STRDUP(def->seclabels[0]->label, label) < 0) VIR_STRDUP(secdef->label, label) < 0)
goto error; goto error;
if (baselabel && if (baselabel &&
VIR_STRDUP(def->seclabels[0]->baselabel, baselabel) < 0) VIR_STRDUP(secdef->baselabel, baselabel) < 0)
goto error; goto error;
def->seclabels[0] = secdef;
def->nseclabels++;
return def; return def;
error: error: