mirror of
https://gitea.osmocom.org/cellular-infrastructure/osmo-mgw.git
synced 2025-10-25 09:03:47 +00:00
sgsn: Add VTY configuration for the CDR module
Make it possible to set a filename to use for the CDR. By default no CDR will be generated. Forbid to set the interval of 0 seconds as this will cause a lot of work. Add a very basic VTY test.
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* (C) 2010-2013 by Harald Welte <laforge@gnumonks.org>
|
* (C) 2010-2013 by Harald Welte <laforge@gnumonks.org>
|
||||||
* (C) 2010 by On-Waves
|
* (C) 2010 by On-Waves
|
||||||
|
* (C) 2015 by Holger Hans Peter Freyther
|
||||||
* All Rights Reserved
|
* All Rights Reserved
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
@@ -164,6 +165,12 @@ static int config_write_sgsn(struct vty *vty)
|
|||||||
actx->ggsn->id, VTY_NEWLINE);
|
actx->ggsn->id, VTY_NEWLINE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (g_cfg->cdr.filename)
|
||||||
|
vty_out(vty, " cdr filename %s%s", g_cfg->cdr.filename, VTY_NEWLINE);
|
||||||
|
else
|
||||||
|
vty_out(vty, " no cdr filename%s", VTY_NEWLINE);
|
||||||
|
vty_out(vty, " cdr interval %d%s", g_cfg->cdr.interval, VTY_NEWLINE);
|
||||||
|
|
||||||
return CMD_SUCCESS;
|
return CMD_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -811,6 +818,32 @@ DEFUN(cfg_no_apn_name, cfg_no_apn_name_cmd,
|
|||||||
return CMD_SUCCESS;
|
return CMD_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DEFUN(cfg_cdr_filename, cfg_cdr_filename_cmd,
|
||||||
|
"cdr filename NAME",
|
||||||
|
"CDR\nSet filename\nname\n")
|
||||||
|
{
|
||||||
|
talloc_free(g_cfg->cdr.filename);
|
||||||
|
g_cfg->cdr.filename = talloc_strdup(tall_vty_ctx, argv[0]);
|
||||||
|
return CMD_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
DEFUN(cfg_no_cdr_filename, cfg_no_cdr_filename_cmd,
|
||||||
|
"no cdr filename",
|
||||||
|
NO_STR "CDR\nDisable CDR generation\n")
|
||||||
|
{
|
||||||
|
talloc_free(g_cfg->cdr.filename);
|
||||||
|
g_cfg->cdr.filename = NULL;
|
||||||
|
return CMD_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
DEFUN(cfg_cdr_interval, cfg_cdr_interval_cmd,
|
||||||
|
"cdr interval <1-2147483647>",
|
||||||
|
"CDR\nPDP periodic log interval\nSeconds\n")
|
||||||
|
{
|
||||||
|
g_cfg->cdr.interval = atoi(argv[0]);
|
||||||
|
return CMD_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
int sgsn_vty_init(void)
|
int sgsn_vty_init(void)
|
||||||
{
|
{
|
||||||
install_element_ve(&show_sgsn_cmd);
|
install_element_ve(&show_sgsn_cmd);
|
||||||
@@ -842,6 +875,9 @@ int sgsn_vty_init(void)
|
|||||||
install_element(SGSN_NODE, &cfg_apn_imsi_ggsn_cmd);
|
install_element(SGSN_NODE, &cfg_apn_imsi_ggsn_cmd);
|
||||||
install_element(SGSN_NODE, &cfg_apn_name_cmd);
|
install_element(SGSN_NODE, &cfg_apn_name_cmd);
|
||||||
install_element(SGSN_NODE, &cfg_no_apn_name_cmd);
|
install_element(SGSN_NODE, &cfg_no_apn_name_cmd);
|
||||||
|
install_element(SGSN_NODE, &cfg_cdr_filename_cmd);
|
||||||
|
install_element(SGSN_NODE, &cfg_no_cdr_filename_cmd);
|
||||||
|
install_element(SGSN_NODE, &cfg_cdr_interval_cmd);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -891,6 +891,34 @@ class TestVTYSGSN(TestVTYGenericBSC):
|
|||||||
res = self.vty.command("show running-config")
|
res = self.vty.command("show running-config")
|
||||||
self.assertEquals(res.find("apn internet"), -1)
|
self.assertEquals(res.find("apn internet"), -1)
|
||||||
|
|
||||||
|
def testVtyCDR(self):
|
||||||
|
self.vty.enable()
|
||||||
|
self.assertTrue(self.vty.verify('configure terminal', ['']))
|
||||||
|
self.assertEquals(self.vty.node(), 'config')
|
||||||
|
self.assertTrue(self.vty.verify('sgsn', ['']))
|
||||||
|
self.assertEquals(self.vty.node(), 'config-sgsn')
|
||||||
|
|
||||||
|
res = self.vty.command("show running-config")
|
||||||
|
self.assert_(res.find("no cdr filename") > 0)
|
||||||
|
|
||||||
|
self.vty.command("cdr filename bla.cdr")
|
||||||
|
res = self.vty.command("show running-config")
|
||||||
|
self.assertEquals(res.find("no cdr filename"), -1)
|
||||||
|
self.assert_(res.find(" cdr filename bla.cdr") > 0)
|
||||||
|
|
||||||
|
self.vty.command("no cdr filename")
|
||||||
|
res = self.vty.command("show running-config")
|
||||||
|
self.assert_(res.find("no cdr filename") > 0)
|
||||||
|
self.assertEquals(res.find(" cdr filename bla.cdr"), -1)
|
||||||
|
|
||||||
|
res = self.vty.command("show running-config")
|
||||||
|
self.assert_(res.find(" cdr interval 600") > 0)
|
||||||
|
|
||||||
|
self.vty.command("cdr interval 900")
|
||||||
|
res = self.vty.command("show running-config")
|
||||||
|
self.assert_(res.find(" cdr interval 900") > 0)
|
||||||
|
self.assertEquals(res.find(" cdr interval 600"), -1)
|
||||||
|
|
||||||
def add_nat_test(suite, workdir):
|
def add_nat_test(suite, workdir):
|
||||||
if not os.path.isfile(os.path.join(workdir, "src/osmo-bsc_nat/osmo-bsc_nat")):
|
if not os.path.isfile(os.path.join(workdir, "src/osmo-bsc_nat/osmo-bsc_nat")):
|
||||||
print("Skipping the NAT test")
|
print("Skipping the NAT test")
|
||||||
|
|||||||
Reference in New Issue
Block a user