1 # Unix SMB/CIFS implementation.
2 # Copyright (C) Jelmer Vernooij <jelmer@samba.org> 2007-2012
4 # This program is free software; you can redistribute it and/or modify
5 # it under the terms of the GNU General Public License as published by
6 # the Free Software Foundation; either version 3 of the License, or
7 # (at your option) any later version.
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
14 # You should have received a copy of the GNU General Public License
15 # along with this program. If not, see <http://www.gnu.org/licenses/>.
18 """Tests for samba.provision."""
21 from samba
.provision
import (
25 determine_netbios_name
,
31 from samba
.tests
import env_loadparm
, TestCase
33 def create_dummy_secretsdb(path
, lp
=None):
34 """Create a dummy secrets database for use in tests.
36 :param path: Path to store the secrets db
37 :param lp: Optional loadparm context. A simple one will
38 be generated if not specified.
42 paths
= ProvisionPaths()
44 paths
.private_dir
= os
.path
.dirname(path
)
45 paths
.keytab
= "no.keytab"
46 paths
.dns_keytab
= "no.dns.keytab"
47 secrets_ldb
= setup_secretsdb(paths
, None, None, lp
=lp
)
48 secrets_ldb
.transaction_commit()
52 class ProvisionTestCase(samba
.tests
.TestCaseInTempDir
):
53 """Some simple tests for individual functions in the provisioning code.
56 def test_setup_secretsdb(self
):
57 path
= os
.path
.join(self
.tempdir
, "secrets.ldb")
58 paths
= ProvisionPaths()
60 paths
.private_dir
= os
.path
.dirname(path
)
61 paths
.keytab
= "no.keytab"
62 paths
.dns_keytab
= "no.dns.keytab"
63 ldb
= setup_secretsdb(paths
, None, None, lp
=env_loadparm())
65 self
.assertEquals("LSA Secrets",
66 ldb
.searchone(basedn
="CN=LSA Secrets", attribute
="CN"))
72 class FindNssTests(TestCase
):
73 """Test findnss() function."""
75 def test_nothing(self
):
78 self
.assertRaises(KeyError, findnss
, x
, [])
81 self
.assertEquals("bla", findnss(lambda x
: "bla", ["bla"]))
83 def test_skip_first(self
):
88 self
.assertEquals("ha", findnss(x
, ["bloe", "bla"]))
91 class Disabled(object):
93 def test_setup_templatesdb(self
):
94 raise NotImplementedError(self
.test_setup_templatesdb
)
96 def test_setup_registry(self
):
97 raise NotImplementedError(self
.test_setup_registry
)
99 def test_setup_samdb_rootdse(self
):
100 raise NotImplementedError(self
.test_setup_samdb_rootdse
)
102 def test_setup_samdb_partitions(self
):
103 raise NotImplementedError(self
.test_setup_samdb_partitions
)
105 def test_create_phpldapadmin_config(self
):
106 raise NotImplementedError(self
.test_create_phpldapadmin_config
)
108 def test_provision_dns(self
):
109 raise NotImplementedError(self
.test_provision_dns
)
111 def test_provision_ldapbase(self
):
112 raise NotImplementedError(self
.test_provision_ldapbase
)
114 def test_provision_guess(self
):
115 raise NotImplementedError(self
.test_provision_guess
)
117 def test_join_domain(self
):
118 raise NotImplementedError(self
.test_join_domain
)
120 def test_vampire(self
):
121 raise NotImplementedError(self
.test_vampire
)
124 class SanitizeServerRoleTests(TestCase
):
127 self
.assertEquals("standalone server",
128 sanitize_server_role("standalone server"))
129 self
.assertEquals("member server",
130 sanitize_server_role("member server"))
132 def test_invalid(self
):
133 self
.assertRaises(ValueError, sanitize_server_role
, "foo")
135 def test_valid(self
):
136 self
.assertEquals("standalone server", sanitize_server_role("ROLE_STANDALONE"))
137 self
.assertEquals("standalone server", sanitize_server_role("standalone"))
138 self
.assertEquals("active directory domain controller", sanitize_server_role("domain controller"))
141 class DummyLogger(object):
146 def info(self
, text
, *args
):
147 self
.entries
.append(("INFO", text
% args
))
150 class ProvisionResultTests(TestCase
):
152 def report_logger(self
, result
):
153 logger
= DummyLogger()
154 result
.report_logger(logger
)
155 return logger
.entries
157 def base_result(self
):
158 result
= ProvisionResult()
159 result
.server_role
= "domain controller"
160 result
.names
= ProvisionNames()
161 result
.names
.hostname
= "hostnaam"
162 result
.names
.domain
= "DOMEIN"
163 result
.names
.dnsdomain
= "dnsdomein"
164 result
.domainsid
= "S1-1-1"
165 result
.paths
= ProvisionPaths()
168 def test_basic_report_logger(self
):
169 result
= self
.base_result()
170 entries
= self
.report_logger(result
)
171 self
.assertEquals(entries
, [
172 ('INFO', 'Once the above files are installed, your Samba4 server '
173 'will be ready to use'),
174 ('INFO', 'Server Role: domain controller'),
175 ('INFO', 'Hostname: hostnaam'),
176 ('INFO', 'NetBIOS Domain: DOMEIN'),
177 ('INFO', 'DNS Domain: dnsdomein'),
178 ('INFO', 'DOMAIN SID: S1-1-1')])
180 def test_report_logger_phpldapadmin(self
):
181 result
= self
.base_result()
182 result
.paths
.phpldapadminconfig
= "/some/ldapconfig"
183 entries
= self
.report_logger(result
)
184 self
.assertEquals(entries
[-1],
185 ("INFO", "A phpLDAPadmin configuration file suitable for administering the Samba 4 LDAP server has been created in /some/ldapconfig."))
187 def test_report_logger_adminpass(self
):
188 result
= self
.base_result()
189 result
.adminpass_generated
= True
190 result
.adminpass
= "geheim"
191 entries
= self
.report_logger(result
)
192 self
.assertEquals(entries
[1],
193 ("INFO", 'Admin password: geheim'))
196 class DetermineNetbiosNameTests(TestCase
):
198 def test_limits_to_15(self
):
199 self
.assertEquals("A" * 15, determine_netbios_name("a" * 30))
201 def test_strips_invalid(self
):
202 self
.assertEquals("BLABLA", determine_netbios_name("bla/bla"))