ntdb: switch between secrets.tdb and secrets.ntdb depending on 'use ntdb'
[obnox/samba/samba-obnox.git] / source4 / scripting / python / samba / tests / provision.py
index 76c10145f0a39b277c1f92940e2ee691927b3f5b..929e7074f75a59d3f001bbddd1eeb741c308cd03 100644 (file)
@@ -1,76 +1,82 @@
-#!/usr/bin/python
-
 # Unix SMB/CIFS implementation.
-# Copyright (C) Jelmer Vernooij <jelmer@samba.org> 2007-2008
-#   
+# Copyright (C) Jelmer Vernooij <jelmer@samba.org> 2007-2012
+#
 # This program is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
 # the Free Software Foundation; either version 3 of the License, or
 # (at your option) any later version.
-#   
+#
 # This program 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 General Public License for more details.
-#   
+#
 # You should have received a copy of the GNU General Public License
 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
 #
 
+"""Tests for samba.provision."""
+
 import os
-from samba.provision import setup_secretsdb, secretsdb_become_dc, findnss
+from samba.provision import (
+    ProvisionNames,
+    ProvisionPaths,
+    ProvisionResult,
+    determine_netbios_name,
+    sanitize_server_role,
+    setup_secretsdb,
+    findnss,
+    )
 import samba.tests
-from ldb import Dn
-from samba import param
-import unittest
+from samba.tests import env_loadparm, TestCase
 
-lp = samba.tests.cmdline_loadparm
+def create_dummy_secretsdb(path, lp=None):
+    """Create a dummy secrets database for use in tests.
 
-setup_dir = "setup"
-def setup_path(file):
-    return os.path.join(setup_dir, file)
+    :param path: Path to store the secrets db
+    :param lp: Optional loadparm context. A simple one will
+        be generated if not specified.
+    """
+    if lp is None:
+        lp = env_loadparm()
+    paths = ProvisionPaths()
+    paths.secrets = path
+    paths.private_dir = os.path.dirname(path)
+    paths.keytab = "no.keytab"
+    paths.dns_keytab = "no.dns.keytab"
+    secrets_ldb = setup_secretsdb(paths, None, None, lp=lp)
+    secrets_ldb.transaction_commit()
+    return secrets_ldb
 
 
 class ProvisionTestCase(samba.tests.TestCaseInTempDir):
     """Some simple tests for individual functions in the provisioning code.
     """
+
     def test_setup_secretsdb(self):
         path = os.path.join(self.tempdir, "secrets.ldb")
-        ldb = setup_secretsdb(path, setup_path, None, None, lp=lp)
+        paths = ProvisionPaths()
+        secrets_tdb_path = os.path.join(self.tempdir, "secrets.tdb")
+        secrets_ntdb_path = os.path.join(self.tempdir, "secrets.ntdb")
+        paths.secrets = path
+        paths.private_dir = os.path.dirname(path)
+        paths.keytab = "no.keytab"
+        paths.dns_keytab = "no.dns.keytab"
+        ldb = setup_secretsdb(paths, None, None, lp=env_loadparm())
         try:
             self.assertEquals("LSA Secrets",
                  ldb.searchone(basedn="CN=LSA Secrets", attribute="CN"))
         finally:
             del ldb
             os.unlink(path)
-            
-    def test_become_dc(self):
-        path = os.path.join(self.tempdir, "secrets.ldb")
-        secrets_ldb = setup_secretsdb(path, setup_path, None, None, lp=lp)
-        try:
-            secretsdb_become_dc(secrets_ldb, setup_path, domain="EXAMPLE", 
-                   realm="example", netbiosname="myhost", 
-                   domainsid="S-5-22", keytab_path="keytab.path", 
-                   samdb_url="ldap://url/", 
-                   dns_keytab_path="dns.keytab", dnspass="bla", 
-                           machinepass="machinepass", dnsdomain="example.com")
-            self.assertEquals(1, 
-                    len(secrets_ldb.search("samAccountName=krbtgt,flatname=EXAMPLE,CN=Principals")))
-           self.assertEquals("keytab.path",
-                    secrets_ldb.searchone(basedn="flatname=EXAMPLE,CN=primary domains", 
-                                          expression="(privateKeytab=*)", 
-                                          attribute="privateKeytab"))
-            self.assertEquals("S-5-22",
-                    secrets_ldb.searchone(basedn="flatname=EXAMPLE,CN=primary domains",
-                                          expression="objectSid=*", attribute="objectSid"))
+            if os.path.exists(secrets_tdb_path):
+                os.unlink(secrets_tdb_path)
+            if os.path.exists(secrets_ntdb_path):
+                os.unlink(secrets_ntdb_path)
 
-        finally:
-            del secrets_ldb
-            os.unlink(path)
-
-
-class FindNssTests(unittest.TestCase):
+class FindNssTests(TestCase):
     """Test findnss() function."""
+
     def test_nothing(self):
         def x(y):
             raise KeyError
@@ -87,7 +93,8 @@ class FindNssTests(unittest.TestCase):
         self.assertEquals("ha", findnss(x, ["bloe", "bla"]))
 
 
-class Disabled:
+class Disabled(object):
+
     def test_setup_templatesdb(self):
         raise NotImplementedError(self.test_setup_templatesdb)
 
@@ -100,9 +107,6 @@ class Disabled:
     def test_setup_samdb_partitions(self):
         raise NotImplementedError(self.test_setup_samdb_partitions)
 
-    def test_create_phpldapadmin_config(self):
-        raise NotImplementedError(self.test_create_phpldapadmin_config)
-
     def test_provision_dns(self):
         raise NotImplementedError(self.test_provision_dns)
 
@@ -118,7 +122,82 @@ class Disabled:
     def test_vampire(self):
         raise NotImplementedError(self.test_vampire)
 
-    def test_erase_partitions(self):
-        raise NotImplementedError(self.test_erase_partitions)
-
 
+class SanitizeServerRoleTests(TestCase):
+
+    def test_same(self):
+        self.assertEquals("standalone server",
+            sanitize_server_role("standalone server"))
+        self.assertEquals("member server",
+            sanitize_server_role("member server"))
+
+    def test_invalid(self):
+        self.assertRaises(ValueError, sanitize_server_role, "foo")
+
+    def test_valid(self):
+        self.assertEquals(
+            "standalone server",
+            sanitize_server_role("ROLE_STANDALONE"))
+        self.assertEquals(
+            "standalone server",
+            sanitize_server_role("standalone"))
+        self.assertEquals(
+            "active directory domain controller",
+            sanitize_server_role("domain controller"))
+
+
+class DummyLogger(object):
+
+    def __init__(self):
+        self.entries = []
+
+    def info(self, text, *args):
+        self.entries.append(("INFO", text % args))
+
+
+class ProvisionResultTests(TestCase):
+
+    def report_logger(self, result):
+        logger = DummyLogger()
+        result.report_logger(logger)
+        return logger.entries
+
+    def base_result(self):
+        result = ProvisionResult()
+        result.server_role = "domain controller"
+        result.names = ProvisionNames()
+        result.names.hostname = "hostnaam"
+        result.names.domain = "DOMEIN"
+        result.names.dnsdomain = "dnsdomein"
+        result.domainsid = "S1-1-1"
+        result.paths = ProvisionPaths()
+        return result
+
+    def test_basic_report_logger(self):
+        result = self.base_result()
+        entries = self.report_logger(result)
+        self.assertEquals(entries, [
+            ('INFO', 'Once the above files are installed, your Samba4 server '
+                'will be ready to use'),
+            ('INFO', 'Server Role:           domain controller'),
+            ('INFO', 'Hostname:              hostnaam'),
+            ('INFO', 'NetBIOS Domain:        DOMEIN'),
+            ('INFO', 'DNS Domain:            dnsdomein'),
+            ('INFO', 'DOMAIN SID:            S1-1-1')])
+
+    def test_report_logger_adminpass(self):
+        result = self.base_result()
+        result.adminpass_generated = True
+        result.adminpass = "geheim"
+        entries = self.report_logger(result)
+        self.assertEquals(entries[1],
+                ("INFO", 'Admin password:        geheim'))
+
+
+class DetermineNetbiosNameTests(TestCase):
+
+    def test_limits_to_15(self):
+        self.assertEquals("A" * 15, determine_netbios_name("a" * 30))
+
+    def test_strips_invalid(self):
+        self.assertEquals("BLABLA", determine_netbios_name("bla/bla"))