3 '''automated testing of Samba3 against windows'''
10 t.putenv("LD_LIBRARY_PATH", "${PREFIX}/lib")
15 t.chdir('${SOURCETREE}/source3')
16 t.putenv('CC', 'ccache gcc')
17 t.run_cmd("./autogen.sh")
18 t.run_cmd("./configure -C --prefix=${PREFIX} --enable-developer")
19 t.run_cmd('make basics')
21 t.run_cmd('rm -rf ${PREFIX}')
22 t.run_cmd('make install')
25 t.info('Starting Samba3')
27 t.run_cmd('killall -9 -q samba smbd nmbd winbindd', checkfail=False)
28 t.run_cmd("rm -f var/locks/*.pid")
29 t.run_cmd(['sbin/nmbd', "-D"])
30 t.run_cmd(['sbin/winbindd', "-D"])
31 t.run_cmd(['sbin/smbd', "-D"])
32 t.port_wait("${INTERFACE_IP}", 139)
36 t.info('Testing wbinfo')
38 t.cmd_contains("bin/wbinfo --version", ["Version 3."])
39 t.cmd_contains("bin/wbinfo -p", ["Ping to winbindd succeeded"])
40 t.retry_cmd("bin/wbinfo --online-status",
42 "${HOSTNAME} : online",
43 "${WIN_DOMAIN} : online"],
45 t.cmd_contains("bin/wbinfo -u",
46 ["${WIN_DOMAIN}/administrator",
47 "${WIN_DOMAIN}/krbtgt" ],
49 t.cmd_contains("bin/wbinfo -g",
50 ["${WIN_DOMAIN}/domain users",
51 "${WIN_DOMAIN}/domain guests",
52 "${WIN_DOMAIN}/domain admins"],
54 t.cmd_contains("bin/wbinfo --name-to-sid administrator",
55 "S-1-5-.*-500 SID_USER .1",
57 t.cmd_contains("bin/wbinfo --name-to-sid 'domain users'",
58 "S-1-5-.*-513 SID_DOM_GROUP .2",
61 t.retry_cmd("bin/wbinfo --authenticate=${WIN_DOMAIN}/administrator%${WIN_PASS}",
62 ["plaintext password authentication succeeded",
63 "challenge/response password authentication succeeded"])
66 def test_smbclient(t):
67 t.info('Testing smbclient')
69 t.cmd_contains("bin/smbclient --version", ["Version 3."])
70 t.cmd_contains('bin/smbclient -L ${INTERFACE_IP} -U%', ["Domain=[${WIN_DOMAIN}]", "test", "IPC$", "Samba 3."],
72 child = t.pexpect_spawn('bin/smbclient //${HOSTNAME}.${WIN_REALM}/test -Uroot%${PASSWORD2}')
75 child.expect("blocks available")
76 child.sendline("mkdir testdir")
78 child.sendline("cd testdir")
79 child.expect('testdir')
80 child.sendline("cd ..")
81 child.sendline("rmdir testdir")
85 t.info("Adding test shares")
87 t.write_file("lib/smb.conf", '''
93 t.run_cmd("mkdir -p test")
96 def prep_join_as_member(t, vm):
97 '''prepare to join a windows domain as a member server'''
99 t.info("Starting VMs for joining ${WIN_VM} as a member using net ads join")
101 t.run_cmd('killall -9 -q samba smbd nmbd winbindd', checkfail=False)
102 t.vm_poweroff("${WIN_VM}", checkfail=False)
103 t.vm_restore("${WIN_VM}", "${WIN_SNAPSHOT}")
104 child = t.open_telnet("${WIN_HOSTNAME}", "administrator", "${WIN_PASS}", set_time=True)
105 t.get_ipconfig(child)
106 t.del_files(["var", "private"])
107 t.write_file("lib/smb.conf", '''
109 netbios name = ${HOSTNAME}
110 log level = ${DEBUGLEVEL}
112 workgroup = ${WIN_DOMAIN}
114 bind interfaces only = yes
115 interfaces = ${INTERFACE}
116 winbind separator = /
117 idmap uid = 1000000-2000000
118 idmap gid = 1000000-2000000
119 winbind enum users = yes
120 winbind enum groups = yes
125 panic action = xterm -e gdb --pid %d
128 def join_as_member(t, vm):
129 '''join a windows domain as a member server'''
131 t.info("Joining ${WIN_VM} as a member using net ads join")
132 t.port_wait("${WIN_IP}", 389)
133 t.retry_cmd("host -t SRV _ldap._tcp.${WIN_REALM} ${WIN_IP}", ['has SRV record'] )
134 t.cmd_contains("bin/net ads join -Uadministrator%${WIN_PASS}", ["Joined"])
135 t.cmd_contains("bin/net ads testjoin", ["Join is OK"])
136 t.cmd_contains("bin/net ads dns register ${HOSTNAME}.${WIN_REALM} -P", ["Successfully registered hostname with DNS"])
137 t.cmd_contains("host -t A ${HOSTNAME}.${WIN_REALM}",
138 ['${HOSTNAME}.${WIN_REALM} has address'])
141 def test_join_as_member(t, vm):
142 '''test the domain join'''
144 t.info('Testing join as member')
146 t.run_cmd('bin/net ads user add root -Uadministrator%${WIN_PASS}')
147 child = t.pexpect_spawn('bin/net ads password root -Uadministrator%${WIN_PASS}')
148 child.expect("Enter new password for root")
149 child.sendline("${PASSWORD2}")
150 child.expect("Password change for ");
151 child.expect(" completed")
152 child = t.pexpect_spawn('bin/net rpc shell -S ${WIN_HOSTNAME}.${WIN_REALM} -Uadministrator%${WIN_PASS}')
153 child.expect("net rpc>")
154 child.sendline("user edit disabled root no")
155 child.expect("Set root's disabled flag")
161 '''basic s3 testing'''
163 t.check_prerequesites()
166 if not t.skip("configure_bind"):
168 if not t.skip("stop_bind"):
170 if not t.skip("stop_vms"):
173 if not t.skip("build"):
176 if not t.skip("configure_bind2"):
178 if not t.skip("start_bind"):
181 if t.have_var('W2K8R2A_VM') and not t.skip("join_w2k8r2"):
182 prep_join_as_member(t, "W2K8R2A")
183 t.run_dcpromo_as_first_dc("W2K8R2A", func_level='2008r2')
184 join_as_member(t, "W2K8R2A")
187 test_join_as_member(t, "W2K8R2A")
189 t.info("S3 test: All OK")
193 '''cleanup after tests'''
194 t.info("Cleaning up ...")
195 t.restore_resolv_conf()
196 if getattr(t, 'bind_child', False):
200 if __name__ == '__main__':
201 t = wintest.wintest()
203 t.setup("test-s3.py", "source3")
208 if not t.opts.nocleanup:
212 if not t.opts.nocleanup:
214 t.info("S3 test: All OK")