virkmodtest.c 3.4 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
/*
 * Copyright (C) 2014 Red Hat, Inc.
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library.  If not, see
 * <http://www.gnu.org/licenses/>.
 */

#include <config.h>

#include "testutils.h"

#ifdef __linux__

25
# define LIBVIRT_VIRCOMMANDPRIV_H_ALLOW
26
# include "vircommandpriv.h"
27 28 29
# include "virkmod.h"
# include "virstring.h"

30
# define MODNAME "vfio-pci"
31 32 33 34

# define VIR_FROM_THIS VIR_FROM_NONE

static int
J
Ján Tomko 已提交
35
testKModConfig(const void *args G_GNUC_UNUSED)
36 37 38 39 40 41 42 43 44
{
    int ret = -1;
    char *outbuf = NULL;

    /* This will return the contents of a 'modprobe -c' which can differ
     * from machine to machine - be happy that we get something.
     */
    outbuf = virKModConfig();
    if (!outbuf) {
45 46 47 48 49 50
        if (virFileIsExecutable(MODPROBE)) {
            fprintf(stderr, "Failed to get config\n");
        } else {
            /* modprobe doesn't exist, do not claim error. */
            ret = 0;
        }
51 52 53 54
        goto cleanup;
    }
    ret = 0;

55
 cleanup:
56 57 58 59 60 61 62 63 64 65 66 67
    VIR_FREE(outbuf);
    return ret;
}


static int
checkOutput(virBufferPtr buf, const char *exp_cmd)
{
    int ret = -1;
    char *actual_cmd = NULL;

    if (!(actual_cmd = virBufferContentAndReset(buf))) {
P
Peter Krempa 已提交
68
        fprintf(stderr, "cannot compare buffer to exp: %s", exp_cmd);
69 70 71 72
        goto cleanup;
    }

    if (STRNEQ(exp_cmd, actual_cmd)) {
73
        virTestDifference(stderr, exp_cmd, actual_cmd);
74 75 76 77 78
        goto cleanup;
    }

    ret = 0;

79
 cleanup:
80 81 82 83 84 85
    VIR_FREE(actual_cmd);
    return ret;
}


static int
86
testKModLoad(const void *args G_GNUC_UNUSED)
87 88 89 90 91
{
    int ret = -1;
    char *errbuf = NULL;
    virBuffer buf = VIR_BUFFER_INITIALIZER;

92
    virCommandSetDryRun(&buf, NULL, NULL);
93

94
    errbuf = virKModLoad(MODNAME);
95 96 97 98 99
    if (errbuf) {
        fprintf(stderr, "Failed to load, error: %s\n", errbuf);
        goto cleanup;
    }

100
    if (checkOutput(&buf, MODPROBE " -b " MODNAME "\n") < 0)
101 102 103 104
        goto cleanup;

    ret = 0;

105
 cleanup:
106
    virCommandSetDryRun(NULL, NULL, NULL);
107 108 109 110 111 112
    VIR_FREE(errbuf);
    return ret;
}


static int
113
testKModUnload(const void *args G_GNUC_UNUSED)
114 115 116 117 118
{
    int ret = -1;
    char *errbuf = NULL;
    virBuffer buf = VIR_BUFFER_INITIALIZER;

119
    virCommandSetDryRun(&buf, NULL, NULL);
120

121
    errbuf = virKModUnload(MODNAME);
122 123 124 125 126
    if (errbuf) {
        fprintf(stderr, "Failed to unload, error: %s\n", errbuf);
        goto cleanup;
    }

127
    if (checkOutput(&buf, RMMOD " " MODNAME "\n") < 0)
128 129 130 131
        goto cleanup;

    ret = 0;

132
 cleanup:
133
    virCommandSetDryRun(NULL, NULL, NULL);
134 135 136 137 138 139 140 141 142 143
    VIR_FREE(errbuf);
    return ret;
}


static int
mymain(void)
{
    int ret = 0;

144
    if (virTestRun("config", testKModConfig, NULL) < 0)
145
        ret = -1;
146 147 148 149
    if (virTestRun("load", testKModLoad, NULL) < 0)
        ret = -1;
    if (virTestRun("unload", testKModUnload, NULL) < 0)
        ret = -1;
150

151
    return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
152 153 154

}

155
VIR_TEST_MAIN(mymain);
156 157 158 159 160 161 162
#else
int
main(void)
{
    return EXIT_AM_SKIP;
}
#endif