2014-03-20 10:30:44 +00:00
|
|
|
/*
|
|
|
|
* networkxml2firewalltest.c: Test iptables rule generation
|
|
|
|
*
|
|
|
|
* 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>
|
|
|
|
|
2014-04-30 10:16:09 +02:00
|
|
|
#include "testutils.h"
|
|
|
|
|
2014-03-20 10:30:44 +00:00
|
|
|
#if defined (__linux__)
|
|
|
|
|
|
|
|
# include "network/bridge_driver_platform.h"
|
|
|
|
# include "virbuffer.h"
|
|
|
|
|
2018-12-13 14:53:50 +00:00
|
|
|
# define LIBVIRT_VIRFIREWALLPRIV_H_ALLOW
|
2014-03-20 10:30:44 +00:00
|
|
|
# include "virfirewallpriv.h"
|
|
|
|
|
2018-12-13 14:53:50 +00:00
|
|
|
# define LIBVIRT_VIRCOMMANDPRIV_H_ALLOW
|
2014-03-20 10:30:44 +00:00
|
|
|
# include "vircommandpriv.h"
|
|
|
|
|
|
|
|
# define VIR_FROM_THIS VIR_FROM_NONE
|
|
|
|
|
|
|
|
static const char *abs_top_srcdir;
|
|
|
|
|
|
|
|
# ifdef __linux__
|
|
|
|
# define RULESTYPE "linux"
|
|
|
|
# else
|
|
|
|
# error "test case not ported to this platform"
|
|
|
|
# endif
|
|
|
|
|
2018-11-01 11:42:56 +00:00
|
|
|
static void
|
|
|
|
testCommandDryRun(const char *const*args ATTRIBUTE_UNUSED,
|
|
|
|
const char *const*env ATTRIBUTE_UNUSED,
|
|
|
|
const char *input ATTRIBUTE_UNUSED,
|
|
|
|
char **output,
|
|
|
|
char **error,
|
|
|
|
int *status,
|
|
|
|
void *opaque ATTRIBUTE_UNUSED)
|
|
|
|
{
|
|
|
|
*status = 0;
|
|
|
|
ignore_value(VIR_STRDUP_QUIET(*output, ""));
|
|
|
|
ignore_value(VIR_STRDUP_QUIET(*error, ""));
|
|
|
|
}
|
|
|
|
|
2014-03-20 10:30:44 +00:00
|
|
|
static int testCompareXMLToArgvFiles(const char *xml,
|
|
|
|
const char *cmdline)
|
|
|
|
{
|
|
|
|
char *expectargv = NULL;
|
|
|
|
char *actualargv = NULL;
|
|
|
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
|
|
|
virNetworkDefPtr def = NULL;
|
|
|
|
int ret = -1;
|
|
|
|
|
2018-11-01 11:42:56 +00:00
|
|
|
virCommandSetDryRun(&buf, testCommandDryRun, NULL);
|
2014-03-20 10:30:44 +00:00
|
|
|
|
|
|
|
if (!(def = virNetworkDefParseFile(xml)))
|
|
|
|
goto cleanup;
|
|
|
|
|
|
|
|
if (networkAddFirewallRules(def) < 0)
|
|
|
|
goto cleanup;
|
|
|
|
|
|
|
|
if (virBufferError(&buf))
|
|
|
|
goto cleanup;
|
|
|
|
|
|
|
|
actualargv = virBufferContentAndReset(&buf);
|
2016-05-26 17:01:55 +02:00
|
|
|
virTestClearCommandPath(actualargv);
|
2014-03-20 10:30:44 +00:00
|
|
|
virCommandSetDryRun(NULL, NULL, NULL);
|
|
|
|
|
2016-05-26 17:01:53 +02:00
|
|
|
if (virTestCompareToFile(actualargv, cmdline) < 0)
|
2014-03-20 10:30:44 +00:00
|
|
|
goto cleanup;
|
|
|
|
|
|
|
|
ret = 0;
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
virBufferFreeAndReset(&buf);
|
|
|
|
VIR_FREE(expectargv);
|
|
|
|
VIR_FREE(actualargv);
|
|
|
|
virNetworkDefFree(def);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct testInfo {
|
|
|
|
const char *name;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
testCompareXMLToIPTablesHelper(const void *data)
|
|
|
|
{
|
|
|
|
int result = -1;
|
|
|
|
const struct testInfo *info = data;
|
|
|
|
char *xml = NULL;
|
|
|
|
char *args = NULL;
|
|
|
|
|
|
|
|
if (virAsprintf(&xml, "%s/networkxml2firewalldata/%s.xml",
|
|
|
|
abs_srcdir, info->name) < 0 ||
|
|
|
|
virAsprintf(&args, "%s/networkxml2firewalldata/%s-%s.args",
|
|
|
|
abs_srcdir, info->name, RULESTYPE) < 0)
|
|
|
|
goto cleanup;
|
|
|
|
|
|
|
|
result = testCompareXMLToArgvFiles(xml, args);
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(xml);
|
|
|
|
VIR_FREE(args);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2017-04-07 15:11:14 +01:00
|
|
|
static bool
|
|
|
|
hasNetfilterTools(void)
|
|
|
|
{
|
|
|
|
return virFileIsExecutable(IPTABLES_PATH) &&
|
|
|
|
virFileIsExecutable(IP6TABLES_PATH) &&
|
|
|
|
virFileIsExecutable(EBTABLES_PATH);
|
|
|
|
}
|
|
|
|
|
2014-03-20 10:30:44 +00:00
|
|
|
|
|
|
|
static int
|
|
|
|
mymain(void)
|
|
|
|
{
|
|
|
|
int ret = 0;
|
|
|
|
|
|
|
|
abs_top_srcdir = getenv("abs_top_srcdir");
|
|
|
|
if (!abs_top_srcdir)
|
|
|
|
abs_top_srcdir = abs_srcdir "/..";
|
|
|
|
|
2017-11-03 13:09:47 +01:00
|
|
|
# define DO_TEST(name) \
|
|
|
|
do { \
|
|
|
|
static struct testInfo info = { \
|
|
|
|
name, \
|
|
|
|
}; \
|
|
|
|
if (virTestRun("Network XML-2-iptables " name, \
|
|
|
|
testCompareXMLToIPTablesHelper, &info) < 0) \
|
|
|
|
ret = -1; \
|
2014-03-20 10:30:44 +00:00
|
|
|
} while (0)
|
|
|
|
|
2014-12-23 06:10:55 +01:00
|
|
|
virFirewallSetLockOverride(true);
|
|
|
|
|
2014-03-20 10:30:44 +00:00
|
|
|
if (virFirewallSetBackend(VIR_FIREWALL_BACKEND_DIRECT) < 0) {
|
2017-04-07 15:11:14 +01:00
|
|
|
if (!hasNetfilterTools()) {
|
|
|
|
fprintf(stderr, "iptables/ip6tables/ebtables tools not present");
|
|
|
|
return EXIT_AM_SKIP;
|
|
|
|
}
|
|
|
|
|
2014-03-20 10:30:44 +00:00
|
|
|
ret = -1;
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
DO_TEST("nat-default");
|
|
|
|
DO_TEST("nat-tftp");
|
|
|
|
DO_TEST("nat-many-ips");
|
|
|
|
DO_TEST("nat-no-dhcp");
|
|
|
|
DO_TEST("nat-ipv6");
|
|
|
|
DO_TEST("route-default");
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
|
2017-03-29 16:45:42 +02:00
|
|
|
VIR_TEST_MAIN(mymain)
|
2014-03-20 10:30:44 +00:00
|
|
|
|
|
|
|
#else /* ! defined (__linux__) */
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
return EXIT_AM_SKIP;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* ! defined (__linux__) */
|