TT#81207 [caller|callee]_prefs from usr and peer loads

Change-Id: I2f25147100297cb99a98b1f6186daaf7da16ef44
changes/57/39957/2
Victor Seva 5 years ago
parent 3cf6970d3a
commit 68ee236da4

@ -19,6 +19,7 @@
-- --
local utils = require 'ngcp.utils' local utils = require 'ngcp.utils'
local utable = utils.table local utable = utils.table
local NGCPXAvp = require 'ngcp.xavp'
local NGCPPrefs = require 'ngcp.pref' local NGCPPrefs = require 'ngcp.pref'
local NGCPDomainPrefs = require 'ngcp.dp' local NGCPDomainPrefs = require 'ngcp.dp'
local NGCPPeerPrefs = require 'ngcp.pp' local NGCPPeerPrefs = require 'ngcp.pp'
@ -39,11 +40,11 @@ function NGCPRealPrefs:new(config)
return instance return instance
end end
function NGCPRealPrefs:caller_load(uuid) function NGCPRealPrefs:caller_load(_)
error("Not implemented") error("Not implemented")
end end
function NGCPRealPrefs:callee_load(uuid) function NGCPRealPrefs:callee_load(_)
error("Not implemented") error("Not implemented")
end end
@ -90,12 +91,14 @@ function NGCPRealPrefs:_peer_load(level, keys)
local xavp = { local xavp = {
peer = NGCPPeerPrefs:xavp(level), peer = NGCPPeerPrefs:xavp(level),
} }
xavp[level] = NGCPXAvp:new(level, 'prefs')
local peer_keys = {} local peer_keys = {}
local values = KSR.pvx.xavp_getd_p1(xavp.peer.name, 0) local values = KSR.pvx.xavp_getd_p1(xavp.peer.name, 0)
for _,v in pairs(keys) do for _,v in pairs(keys) do
local value = values[v] local value = values[v]
if value then if value then
utable.add(peer_keys, v) utable.add(peer_keys, v)
xavp[level](v, value)
end end
end end
return peer_keys return peer_keys
@ -108,6 +111,7 @@ function NGCPRealPrefs:_usr_load(level, keys)
prof = NGCPProfilePrefs:xavp(level), prof = NGCPProfilePrefs:xavp(level),
usr = NGCPUserPrefs:xavp(level) usr = NGCPUserPrefs:xavp(level)
} }
xavp[level] = NGCPXAvp:new(level, 'prefs')
local real_values = {} local real_values = {}
local dom_values = KSR.pvx.xavp_getd_p1(xavp.dom.name, 0) local dom_values = KSR.pvx.xavp_getd_p1(xavp.dom.name, 0)
local prof_values = KSR.pvx.xavp_getd_p1(xavp.prof.name, 0) local prof_values = KSR.pvx.xavp_getd_p1(xavp.prof.name, 0)
@ -122,6 +126,7 @@ function NGCPRealPrefs:_usr_load(level, keys)
end end
if value then if value then
real_values[v] = value real_values[v] = value
xavp[level](v, value)
else else
KSR.err(string.format("key:%s not in user, profile or domain\n", v)) KSR.err(string.format("key:%s not in user, profile or domain\n", v))
end end
@ -134,5 +139,18 @@ function NGCPRealPrefs:_usr_load(level, keys)
return real_keys return real_keys
end end
function NGCPRealPrefs:clean(vtype)
NGCPPrefs.clean(self, vtype)
if not vtype then
self:xavp('callee'):clean()
self:xavp('caller'):clean()
NGCPXAvp:new('callee', 'prefs'):clean()
NGCPXAvp:new('caller', 'prefs'):clean()
else
self:xavp(vtype):clean()
NGCPXAvp:new(vtype, 'prefs'):clean()
end
end
-- class -- class
return NGCPRealPrefs return NGCPRealPrefs

@ -45,6 +45,26 @@ TestNGCPRealPrefs = {} --class
lu.assertError(self.real.callee_load, nil) lu.assertError(self.real.callee_load, nil)
end end
function TestNGCPRealPrefs:test_caller_mix_load()
local keys = {"uno"}
local xavp = {
domain = NGCPDomainPrefs:xavp("caller"),
user = NGCPUserPrefs:xavp("caller"),
peer = NGCPPeerPrefs:xavp("caller"),
real = NGCPRealPrefs:xavp("caller")
}
xavp.user("uno",1)
local real_keys = self.real:caller_usr_load(keys)
lu.assertEquals(KSR.pv.get("$xavp(caller_usr_prefs=>uno)"),1)
lu.assertEquals(KSR.pv.get("$xavp(caller_prefs=>uno)"),1)
xavp.peer("uno",3)
real_keys = self.real:caller_peer_load(keys)
lu.assertEquals(KSR.pv.get("$xavp(caller_usr_prefs=>uno)"),1)
lu.assertEquals(KSR.pv.get("$xavp(caller_peer_prefs=>uno)"),3)
lu.assertEquals(KSR.pv.get("$xavp(caller_prefs=>uno)"),3)
end
function TestNGCPRealPrefs:test_caller_peer_load() function TestNGCPRealPrefs:test_caller_peer_load()
local keys = {"uno"} local keys = {"uno"}
local xavp = { local xavp = {
@ -58,10 +78,15 @@ TestNGCPRealPrefs = {} --class
xavp.user("uno",2) xavp.user("uno",2)
lu.assertEquals(KSR.pv.get("$xavp(caller_usr_prefs=>uno)"),2) lu.assertEquals(KSR.pv.get("$xavp(caller_usr_prefs=>uno)"),2)
xavp.peer("uno",3) xavp.peer("uno",3)
lu.assertIsNil(KSR.pv.get("$xavp(caller_prefs=>dummy)"))
local real_keys = self.real:caller_peer_load(keys) local real_keys = self.real:caller_peer_load(keys)
lu.assertEquals(real_keys, keys) lu.assertEquals(real_keys, keys)
lu.assertEquals(xavp.real("uno"),nil) lu.assertEquals(xavp.real("uno"),nil)
lu.assertEquals(xavp.peer("uno"),3) lu.assertEquals(xavp.peer("uno"),3)
lu.assertEquals(KSR.pv.get("$xavp(caller_prefs=>uno)"),3)
end end
function TestNGCPRealPrefs:test_caller_usr_load() function TestNGCPRealPrefs:test_caller_usr_load()
@ -75,9 +100,13 @@ TestNGCPRealPrefs = {} --class
lu.assertEquals(KSR.pv.get("$xavp(caller_dom_prefs=>uno)"),1) lu.assertEquals(KSR.pv.get("$xavp(caller_dom_prefs=>uno)"),1)
xavp.user("uno",2) xavp.user("uno",2)
lu.assertEquals(KSR.pv.get("$xavp(caller_usr_prefs=>uno)"),2) lu.assertEquals(KSR.pv.get("$xavp(caller_usr_prefs=>uno)"),2)
lu.assertIsNil(KSR.pv.get("$xavp(caller_prefs=>dummy)"))
local real_keys = self.real:caller_usr_load(keys) local real_keys = self.real:caller_usr_load(keys)
lu.assertEquals(real_keys, keys) lu.assertEquals(real_keys, keys)
lu.assertEquals(xavp.real("uno"),2) lu.assertEquals(xavp.real("uno"),2)
lu.assertEquals(KSR.pv.get("$xavp(caller_prefs=>uno)"),2)
end end
function TestNGCPRealPrefs:test_caller_usr_load1() function TestNGCPRealPrefs:test_caller_usr_load1()
@ -91,10 +120,15 @@ TestNGCPRealPrefs = {} --class
lu.assertEquals(KSR.pv.get("$xavp(caller_dom_prefs=>uno)"),1) lu.assertEquals(KSR.pv.get("$xavp(caller_dom_prefs=>uno)"),1)
xavp.user("dos",2) xavp.user("dos",2)
lu.assertEquals(KSR.pv.get("$xavp(caller_usr_prefs=>dos)"),2) lu.assertEquals(KSR.pv.get("$xavp(caller_usr_prefs=>dos)"),2)
lu.assertIsNil(KSR.pv.get("$xavp(caller_prefs=>dummy)"))
local real_keys = self.real:caller_usr_load(keys) local real_keys = self.real:caller_usr_load(keys)
lu.assertItemsEquals(real_keys, keys) lu.assertItemsEquals(real_keys, keys)
lu.assertEquals(xavp.real("uno"),1) lu.assertEquals(xavp.real("uno"),1)
lu.assertEquals(xavp.real("dos"),2) lu.assertEquals(xavp.real("dos"),2)
lu.assertEquals(KSR.pv.get("$xavp(caller_prefs=>uno)"),1)
lu.assertEquals(KSR.pv.get("$xavp(caller_prefs=>dos)"),2)
end end
function TestNGCPRealPrefs:test_callee_usr_load() function TestNGCPRealPrefs:test_callee_usr_load()
@ -108,9 +142,13 @@ TestNGCPRealPrefs = {} --class
lu.assertEquals(KSR.pv.get("$xavp(callee_dom_prefs=>uno)"),1) lu.assertEquals(KSR.pv.get("$xavp(callee_dom_prefs=>uno)"),1)
xavp.user("uno",2) xavp.user("uno",2)
lu.assertEquals(KSR.pv.get("$xavp(callee_usr_prefs=>uno)"),2) lu.assertEquals(KSR.pv.get("$xavp(callee_usr_prefs=>uno)"),2)
lu.assertIsNil(KSR.pv.get("$xavp(callee_prefs=>dummy)"))
local real_keys = self.real:callee_usr_load(keys) local real_keys = self.real:callee_usr_load(keys)
lu.assertEquals(real_keys, keys) lu.assertEquals(real_keys, keys)
lu.assertEquals(xavp.real("uno"),2) lu.assertEquals(xavp.real("uno"),2)
lu.assertEquals(KSR.pv.get("$xavp(callee_prefs=>uno)"),2)
end end
function TestNGCPRealPrefs:test_callee_usr_load1() function TestNGCPRealPrefs:test_callee_usr_load1()
@ -124,10 +162,15 @@ TestNGCPRealPrefs = {} --class
lu.assertEquals(KSR.pv.get("$xavp(callee_dom_prefs=>uno)"),1) lu.assertEquals(KSR.pv.get("$xavp(callee_dom_prefs=>uno)"),1)
xavp.user("dos",2) xavp.user("dos",2)
lu.assertEquals(KSR.pv.get("$xavp(callee_usr_prefs=>dos)"),2) lu.assertEquals(KSR.pv.get("$xavp(callee_usr_prefs=>dos)"),2)
lu.assertIsNil(KSR.pv.get("$xavp(callee_prefs=>dummy)"))
local real_keys = self.real:callee_usr_load(keys) local real_keys = self.real:callee_usr_load(keys)
lu.assertItemsEquals(real_keys, keys) lu.assertItemsEquals(real_keys, keys)
lu.assertEquals(xavp.real("uno"),1) lu.assertEquals(xavp.real("uno"),1)
lu.assertEquals(xavp.real("dos"),2) lu.assertEquals(xavp.real("dos"),2)
lu.assertEquals(KSR.pv.get("$xavp(callee_prefs=>uno)"),1)
lu.assertEquals(KSR.pv.get("$xavp(callee_prefs=>dos)"),2)
end end
function TestNGCPRealPrefs:test_set() function TestNGCPRealPrefs:test_set()

Loading…
Cancel
Save