Skip to content

Commit

Permalink
tests/kcc_util: Add unit tests for automatic site coverage
Browse files Browse the repository at this point in the history
Signed-off-by: Garming Sam <[email protected]>
Reviewed-by: Douglas Bagnall <[email protected]>
  • Loading branch information
GSam authored and douglasbagnall committed Mar 21, 2018
1 parent ecf503c commit b71f897
Show file tree
Hide file tree
Showing 3 changed files with 354 additions and 1 deletion.
352 changes: 352 additions & 0 deletions python/samba/tests/kcc/kcc_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,10 @@
import samba
import samba.tests
from samba.kcc.kcc_utils import *
from samba.credentials import Credentials
from samba.auth import system_session
from samba.samdb import SamDB
from samba.tests import delete_force


class ScheduleTests(samba.tests.TestCase):
Expand All @@ -35,3 +39,351 @@ def test_new_connection_schedule(self):
# OK, this is pathetic, but the rest of it looks really hard, with the
# classes all intertwingled with each other and the samdb. That is to say:
# XXX later.

class SiteCoverageTests(samba.tests.TestCase):

def setUp(self):
self.prefix = "kcc_"
self.lp = samba.tests.env_loadparm()

self.sites = {}
self.site_links = {}

self.creds = Credentials()
self.creds.guess(self.lp)
self.session = system_session()

self.samdb = SamDB(session_info=self.session,
credentials=self.creds,
lp=self.lp)

def tearDown(self):
self.samdb.transaction_start()

for site in self.sites:
delete_force(self.samdb, site, controls=['tree_delete:1'])

for site_link in self.site_links:
delete_force(self.samdb, site_link)

self.samdb.transaction_commit()

def _add_server(self, name, site):
dn = "CN={},CN=Servers,{}".format(name, site)
self.samdb.add({
"dn": dn,
"objectClass": "server",
"serverReference": self.samdb.domain_dn()
})
return dn

def _add_site(self, name):
dn = "CN={},CN=Sites,{}".format(
name, self.samdb.get_config_basedn()
)
self.samdb.add({
"dn": dn,
"objectClass": "site"
})
self.samdb.add({
"dn": "CN=Servers," + dn,
"objectClass": ["serversContainer"]
})

self.sites[dn] = name
return dn, name.lower()

def _add_site_link(self, name, links=[], cost=100):
dn = "CN={},CN=IP,CN=Inter-Site Transports,CN=Sites,{}".format(
name, self.samdb.get_config_basedn()
)
self.samdb.add({
"dn": dn,
"objectClass": "siteLink",
"cost": str(cost),
"siteList": links
})
self.site_links[dn] = name
return dn

def test_single_site_link_same_dc_count(self):
self.samdb.transaction_start()
site1, name1 = self._add_site(self.prefix + "ABCD")
site2, name2 = self._add_site(self.prefix + "BCDE")

uncovered_dn, uncovered = self._add_site(self.prefix + "uncovered")

self._add_server(self.prefix + "ABCD" + '1', site1)
self._add_server(self.prefix + "BCDE" + '1', site2)

self._add_site_link(self.prefix + "link",
[site1, site2, uncovered_dn])
self.samdb.transaction_commit()

to_cover = uncovered_sites_to_cover(self.samdb, name1)
to_cover.sort()

self.assertEqual([uncovered], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name2)
to_cover.sort()

self.assertEqual([], to_cover)

def test_single_site_link_different_dc_count(self):
self.samdb.transaction_start()
site1, name1 = self._add_site(self.prefix + "ABCD")
site2, name2 = self._add_site(self.prefix + "BCDE")

uncovered_dn, uncovered = self._add_site(self.prefix + "uncovered")

self._add_server(self.prefix + "ABCD" + '1', site1)
self._add_server(self.prefix + "ABCD" + '2', site1)
self._add_server(self.prefix + "BCDE" + '1', site2)
self._add_server(self.prefix + "BCDE" + '2', site2)
self._add_server(self.prefix + "BCDE" + '3', site2)

self._add_site_link(self.prefix + "link",
[site1, site2, uncovered_dn])
self.samdb.transaction_commit()

to_cover = uncovered_sites_to_cover(self.samdb, name1)
to_cover.sort()

self.assertEqual([], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name2)
to_cover.sort()

self.assertEqual([uncovered], to_cover)

def test_two_site_links_same_cost(self):
self.samdb.transaction_start()
site1, name1 = self._add_site(self.prefix + "ABCD")
site2, name2 = self._add_site(self.prefix + "BCDE")

uncovered_dn, uncovered = self._add_site(self.prefix + "uncovered")

self._add_server(self.prefix + "ABCD" + '1', site1)
self._add_server(self.prefix + "ABCD" + '2', site1)
self._add_server(self.prefix + "BCDE" + '1', site2)
self._add_server(self.prefix + "BCDE" + '2', site2)
self._add_server(self.prefix + "BCDE" + '3', site2)

self._add_site_link(self.prefix + "link1",
[site1, uncovered_dn])
self._add_site_link(self.prefix + "link2",
[site2, uncovered_dn])
self.samdb.transaction_commit()

to_cover = uncovered_sites_to_cover(self.samdb, name1)
to_cover.sort()

self.assertEqual([uncovered], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name2)
to_cover.sort()

self.assertEqual([uncovered], to_cover)

def test_two_site_links_different_costs(self):
self.samdb.transaction_start()
site1, name1 = self._add_site(self.prefix + "ABCD")
site2, name2 = self._add_site(self.prefix + "BCDE")

uncovered_dn, uncovered = self._add_site(self.prefix + "uncovered")

self._add_server(self.prefix + "ABCD" + '1', site1)
self._add_server(self.prefix + "BCDE" + '1', site2)
self._add_server(self.prefix + "BCDE" + '2', site2)

self._add_site_link(self.prefix + "link1",
[site1, uncovered_dn],
cost=50)
self._add_site_link(self.prefix + "link2",
[site2, uncovered_dn],
cost=75)
self.samdb.transaction_commit()

to_cover = uncovered_sites_to_cover(self.samdb, name1)
to_cover.sort()

self.assertEqual([uncovered], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name2)
to_cover.sort()

self.assertEqual([], to_cover)

def test_three_site_links_different_costs(self):
self.samdb.transaction_start()
site1, name1 = self._add_site(self.prefix + "ABCD")
site2, name2 = self._add_site(self.prefix + "BCDE")
site3, name3 = self._add_site(self.prefix + "CDEF")

uncovered_dn, uncovered = self._add_site(self.prefix + "uncovered")

self._add_server(self.prefix + "ABCD" + '1', site1)
self._add_server(self.prefix + "BCDE" + '1', site2)
self._add_server(self.prefix + "CDEF" + '1', site3)
self._add_server(self.prefix + "CDEF" + '2', site3)

self._add_site_link(self.prefix + "link1",
[site1, uncovered_dn],
cost=50)
self._add_site_link(self.prefix + "link2",
[site2, uncovered_dn],
cost=75)
self._add_site_link(self.prefix + "link3",
[site3, uncovered_dn],
cost=60)
self.samdb.transaction_commit()

to_cover = uncovered_sites_to_cover(self.samdb, name1)
to_cover.sort()

self.assertEqual([uncovered], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name2)
to_cover.sort()

self.assertEqual([], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name3)
to_cover.sort()

self.assertEqual([], to_cover)

def test_three_site_links_different_costs(self):
self.samdb.transaction_start()
site1, name1 = self._add_site(self.prefix + "ABCD")
site2, name2 = self._add_site(self.prefix + "BCDE")
site3, name3 = self._add_site(self.prefix + "CDEF")

uncovered_dn, uncovered = self._add_site(self.prefix + "uncovered")

self._add_server(self.prefix + "ABCD" + '1', site1)
self._add_server(self.prefix + "BCDE" + '1', site2)
self._add_server(self.prefix + "CDEF" + '1', site3)
self._add_server(self.prefix + "CDEF" + '2', site3)

self._add_site_link(self.prefix + "link1",
[site1, uncovered_dn],
cost=50)
self._add_site_link(self.prefix + "link2",
[site2, uncovered_dn],
cost=75)
self._add_site_link(self.prefix + "link3",
[site3, uncovered_dn],
cost=50)
self.samdb.transaction_commit()

to_cover = uncovered_sites_to_cover(self.samdb, name1)
to_cover.sort()

self.assertEqual([uncovered], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name2)
to_cover.sort()

self.assertEqual([], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name3)
to_cover.sort()

self.assertEqual([uncovered], to_cover)

def test_complex_setup_with_multiple_uncovered_sites(self):
self.samdb.transaction_start()
site1, name1 = self._add_site(self.prefix + "ABCD")
site2, name2 = self._add_site(self.prefix + "BCDE")
site3, name3 = self._add_site(self.prefix + "CDEF")

site4, name4 = self._add_site(self.prefix + "1234")
site5, name5 = self._add_site(self.prefix + "2345")
site6, name6 = self._add_site(self.prefix + "3456")

uncovered_dn1, uncovered1 = self._add_site(self.prefix + "uncovered1")
uncovered_dn2, uncovered2 = self._add_site(self.prefix + "uncovered2")
uncovered_dn3, uncovered3 = self._add_site(self.prefix + "uncovered3")

# Site Link Cluster 1 - Server List
self._add_server(self.prefix + "ABCD" + '1', site1)

self._add_server(self.prefix + "BCDE" + '1', site2)
self._add_server(self.prefix + "BCDE" + '2', site2)

self._add_server(self.prefix + "CDEF" + '1', site3)
self._add_server(self.prefix + "CDEF" + '2', site3)
self._add_server(self.prefix + "CDEF" + '3', site3)

# Site Link Cluster 2 - Server List
self._add_server(self.prefix + "1234" + '1', site4)
self._add_server(self.prefix + "1234" + '2', site4)

self._add_server(self.prefix + "2345" + '1', site5)
self._add_server(self.prefix + "2345" + '2', site5)

self._add_server(self.prefix + "3456" + '1', site6)

# Join to Uncovered1 (preference to site link cluster 1)
self._add_site_link(self.prefix + "link1A",
[site1, site2, site3, uncovered_dn1],
cost=49)
self._add_site_link(self.prefix + "link2A",
[site4, site5, site6, uncovered_dn1],
cost=50)

# Join to Uncovered2 (no preferene on site links)
self._add_site_link(self.prefix + "link1B",
[site1, site2, site3, uncovered_dn2],
cost=50)
self._add_site_link(self.prefix + "link2B",
[site4, site5, site6, uncovered_dn2],
cost=50)

# Join to Uncovered3 (preference to site link cluster 2)
self._add_site_link(self.prefix + "link1C",
[site1, site2, site3, uncovered_dn3],
cost=50)
self._add_site_link(self.prefix + "link2C",
[site4, site5, site6, uncovered_dn3],
cost=49)

self.samdb.transaction_commit()

to_cover = uncovered_sites_to_cover(self.samdb, name1)
to_cover.sort()

self.assertEqual([], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name2)
to_cover.sort()

self.assertEqual([], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name3)
to_cover.sort()

self.assertEqual([uncovered1, uncovered2], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name4)
to_cover.sort()

self.assertEqual([uncovered2, uncovered3], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name5)
to_cover.sort()

self.assertEqual([], to_cover)

to_cover = uncovered_sites_to_cover(self.samdb, name6)
to_cover.sort()

self.assertEqual([], to_cover)

for to_check in [uncovered1, uncovered2, uncovered3]:
to_cover = uncovered_sites_to_cover(self.samdb, to_check)
to_cover.sort()

self.assertEqual([], to_cover)
1 change: 0 additions & 1 deletion selftest/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,6 @@
planpythontestsuite("none", "samba.tests.policy")
planpythontestsuite("none", "samba.tests.kcc.graph")
planpythontestsuite("none", "samba.tests.kcc.graph_utils")
planpythontestsuite("none", "samba.tests.kcc.kcc_utils")
planpythontestsuite("none", "samba.tests.kcc.ldif_import_export")
planpythontestsuite("none", "samba.tests.graph")
plantestsuite("wafsamba.duplicate_symbols", "none", [os.path.join(srcdir(), "buildtools/wafsamba/test_duplicate_symbol.sh")])
Expand Down
2 changes: 2 additions & 0 deletions source4/selftest/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -999,6 +999,8 @@ def planoldpythontestsuite(env, module, name=None, extra_path=[], environ={}, ex
)
planpythontestsuite(env, "samba.tests.samba_tool.visualize_drs")

planpythontestsuite("ad_dc_ntvfs:local", "samba.tests.kcc.kcc_utils")

for env in [ "simpleserver", "fileserver", "nt4_dc", "ad_dc", "ad_dc_ntvfs", "ad_member"]:
planoldpythontestsuite(env, "netlogonsvc",
extra_path=[os.path.join(srcdir(), 'python/samba/tests')],
Expand Down

0 comments on commit b71f897

Please sign in to comment.