tests: Extend NUMA mocking

While the current amount of mocking works just fine on most of
our target platforms, it somehow causes issues when using Clang
on FreeBSD.

Work around the issue by mocking a couple more functions. It's
not pretty, but it makes qemuxml2argvtest pass on FreeBSD at
long last.

Signed-off-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
Andrea Bolognani 2018-05-02 17:35:21 +02:00
parent b5d4652e07
commit 77ac204d14

View File

@ -55,25 +55,45 @@ time_t time(time_t *t)
return ret; return ret;
} }
bool
virNumaIsAvailable(void)
{
return true;
}
int int
virNumaGetMaxNode(void) virNumaGetMaxNode(void)
{ {
const int maxnodesNum = 7; return 7;
return maxnodesNum;
} }
#if WITH_NUMACTL && HAVE_NUMA_BITMASK_ISBITSET /* We shouldn't need to mock virNumaNodeIsAvailable() and *definitely* not
/* * virNumaNodesetIsAvailable(), but it seems to be the only way to get
* In case libvirt is compiled with full NUMA support, we need to mock * mocking to work with Clang on FreeBSD, so keep these duplicates around
* this function in order to fake what numa nodes are available. * until we figure out a cleaner solution */
*/
bool bool
virNumaNodeIsAvailable(int node) virNumaNodeIsAvailable(int node)
{ {
return node >= 0 && node <= virNumaGetMaxNode(); return node >= 0 && node <= virNumaGetMaxNode();
} }
#endif /* WITH_NUMACTL && HAVE_NUMA_BITMASK_ISBITSET */
bool
virNumaNodesetIsAvailable(virBitmapPtr nodeset)
{
ssize_t bit = -1;
if (!nodeset)
return true;
while ((bit = virBitmapNextSetBit(nodeset, bit)) >= 0) {
if (virNumaNodeIsAvailable(bit))
continue;
return false;
}
return true;
}
char * char *
virTPMCreateCancelPath(const char *devpath) virTPMCreateCancelPath(const char *devpath)