2010-11-19 06:08:56 +03:00
#!/usr/bin/env python
''' automated testing of Samba3 against windows '''
import sys , os
import optparse
import wintest
2010-12-10 04:13:58 +03:00
def set_libpath ( t ) :
2010-11-19 06:08:56 +03:00
t . putenv ( " LD_LIBRARY_PATH " , " $ {PREFIX} /lib " )
2010-12-14 02:53:34 +03:00
def set_krb5_conf ( t ) :
t . run_cmd ( " mkdir -p $ {PREFIX} /etc " )
t . write_file ( " $ {PREFIX} /etc/krb5.conf " ,
''' [libdefaults]
dns_lookup_realm = false
dns_lookup_kdc = true ''' )
t . putenv ( " KRB5_CONFIG " , ' $ {PREFIX} /etc/krb5.conf ' )
2010-11-19 06:08:56 +03:00
def build_s3 ( t ) :
''' build samba3 '''
t . info ( ' Building s3 ' )
t . chdir ( ' $ {SOURCETREE} /source3 ' )
t . putenv ( ' CC ' , ' ccache gcc ' )
t . run_cmd ( " ./autogen.sh " )
t . run_cmd ( " ./configure -C --prefix=$ {PREFIX} --enable-developer " )
t . run_cmd ( ' make basics ' )
t . run_cmd ( ' make -j4 ' )
t . run_cmd ( ' rm -rf $ {PREFIX} ' )
t . run_cmd ( ' make install ' )
2010-12-03 07:31:39 +03:00
def start_s3 ( t ) :
2010-11-19 06:08:56 +03:00
t . info ( ' Starting Samba3 ' )
t . chdir ( " $ {PREFIX} " )
t . run_cmd ( ' killall -9 -q samba smbd nmbd winbindd ' , checkfail = False )
t . run_cmd ( " rm -f var/locks/*.pid " )
t . run_cmd ( [ ' sbin/nmbd ' , " -D " ] )
t . run_cmd ( [ ' sbin/winbindd ' , " -D " ] )
t . run_cmd ( [ ' sbin/smbd ' , " -D " ] )
2010-12-10 07:09:54 +03:00
t . port_wait ( " $ {INTERFACE_IP} " , 139 )
2010-11-19 06:08:56 +03:00
def test_wbinfo ( t ) :
t . info ( ' Testing wbinfo ' )
t . chdir ( ' $ {PREFIX} ' )
t . cmd_contains ( " bin/wbinfo --version " , [ " Version 3. " ] )
t . cmd_contains ( " bin/wbinfo -p " , [ " Ping to winbindd succeeded " ] )
t . retry_cmd ( " bin/wbinfo --online-status " ,
[ " BUILTIN : online " ,
" $ {HOSTNAME} : online " ,
" $ {WIN_DOMAIN} : online " ] ,
casefold = True )
t . cmd_contains ( " bin/wbinfo -u " ,
[ " $ {WIN_DOMAIN} /administrator " ,
" $ {WIN_DOMAIN} /krbtgt " ] ,
casefold = True )
t . cmd_contains ( " bin/wbinfo -g " ,
[ " $ {WIN_DOMAIN} /domain users " ,
" $ {WIN_DOMAIN} /domain guests " ,
" $ {WIN_DOMAIN} /domain admins " ] ,
casefold = True )
t . cmd_contains ( " bin/wbinfo --name-to-sid administrator " ,
" S-1-5-.*-500 SID_USER .1 " ,
regex = True )
t . cmd_contains ( " bin/wbinfo --name-to-sid ' domain users ' " ,
" S-1-5-.*-513 SID_DOM_GROUP .2 " ,
regex = True )
2010-12-10 07:09:54 +03:00
t . retry_cmd ( " bin/wbinfo --authenticate=$ {WIN_DOMAIN} /administrator % $ {WIN_PASS} " ,
2010-11-19 06:08:56 +03:00
[ " plaintext password authentication succeeded " ,
" challenge/response password authentication succeeded " ] )
def test_smbclient ( t ) :
t . info ( ' Testing smbclient ' )
t . chdir ( ' $ {PREFIX} ' )
t . cmd_contains ( " bin/smbclient --version " , [ " Version 3. " ] )
2010-12-10 07:09:54 +03:00
t . cmd_contains ( ' bin/smbclient -L $ {INTERFACE_IP} -U % ' , [ " Domain=[$ {WIN_DOMAIN} ] " , " test " , " IPC$ " , " Samba 3. " ] ,
2010-11-19 06:08:56 +03:00
casefold = True )
2010-12-14 02:53:34 +03:00
child = t . pexpect_spawn ( ' bin/smbclient //$ {HOSTNAME} .$ {WIN_REALM} /test -Uroot@$ {WIN_REALM} % $ {PASSWORD2} ' )
child . expect ( " smb: " )
child . sendline ( " dir " )
child . expect ( " blocks available " )
child . sendline ( " mkdir testdir " )
child . expect ( " smb: " )
child . sendline ( " cd testdir " )
child . expect ( ' testdir ' )
child . sendline ( " cd .. " )
child . sendline ( " rmdir testdir " )
child = t . pexpect_spawn ( ' bin/smbclient //$ {HOSTNAME} .$ {WIN_REALM} /test -Uroot@$ {WIN_REALM} % $ {PASSWORD2} -k ' )
2010-11-19 06:08:56 +03:00
child . expect ( " smb: " )
child . sendline ( " dir " )
child . expect ( " blocks available " )
child . sendline ( " mkdir testdir " )
child . expect ( " smb: " )
child . sendline ( " cd testdir " )
child . expect ( ' testdir ' )
child . sendline ( " cd .. " )
child . sendline ( " rmdir testdir " )
def create_shares ( t ) :
t . info ( " Adding test shares " )
t . chdir ( ' $ {PREFIX} ' )
t . write_file ( " lib/smb.conf " , '''
[ test ]
path = $ { PREFIX } / test
read only = no
''' ,
mode = ' a ' )
t . run_cmd ( " mkdir -p test " )
2010-12-10 04:13:58 +03:00
def prep_join_as_member ( t , vm ) :
''' prepare to join a windows domain as a member server '''
2010-11-19 06:08:56 +03:00
t . setwinvars ( vm )
2010-12-10 04:13:58 +03:00
t . info ( " Starting VMs for joining $ {WIN_VM} as a member using net ads join " )
2010-11-19 06:08:56 +03:00
t . chdir ( ' $ {PREFIX} ' )
t . run_cmd ( ' killall -9 -q samba smbd nmbd winbindd ' , checkfail = False )
t . vm_poweroff ( " $ {WIN_VM} " , checkfail = False )
t . vm_restore ( " $ {WIN_VM} " , " $ {WIN_SNAPSHOT} " )
child = t . open_telnet ( " $ {WIN_HOSTNAME} " , " administrator " , " $ {WIN_PASS} " , set_time = True )
2010-12-10 04:13:58 +03:00
t . get_ipconfig ( child )
2010-11-19 06:08:56 +03:00
t . del_files ( [ " var " , " private " ] )
t . write_file ( " lib/smb.conf " , '''
[ global ]
netbios name = $ { HOSTNAME }
log level = $ { DEBUGLEVEL }
realm = $ { WIN_REALM }
workgroup = $ { WIN_DOMAIN }
security = ADS
2010-12-10 07:09:54 +03:00
bind interfaces only = yes
2010-12-03 07:31:39 +03:00
interfaces = $ { INTERFACE }
2010-11-19 06:08:56 +03:00
winbind separator = /
idmap uid = 1000000 - 2000000
idmap gid = 1000000 - 2000000
winbind enum users = yes
winbind enum groups = yes
max protocol = SMB2
map hidden = no
map system = no
ea support = yes
panic action = xterm - e gdb - - pid % d
''' )
2010-12-10 04:13:58 +03:00
def join_as_member ( t , vm ) :
''' join a windows domain as a member server '''
t . setwinvars ( vm )
t . info ( " Joining $ {WIN_VM} as a member using net ads join " )
t . port_wait ( " $ {WIN_IP} " , 389 )
t . retry_cmd ( " host -t SRV _ldap._tcp.$ {WIN_REALM} $ {WIN_IP} " , [ ' has SRV record ' ] )
2010-11-19 06:08:56 +03:00
t . cmd_contains ( " bin/net ads join -Uadministrator % $ {WIN_PASS} " , [ " Joined " ] )
t . cmd_contains ( " bin/net ads testjoin " , [ " Join is OK " ] )
2010-12-10 07:09:54 +03:00
t . cmd_contains ( " bin/net ads dns register $ {HOSTNAME} .$ {WIN_REALM} -P " , [ " Successfully registered hostname with DNS " ] )
t . cmd_contains ( " host -t A $ {HOSTNAME} .$ {WIN_REALM} " ,
[ ' $ {HOSTNAME} .$ {WIN_REALM} has address ' ] )
2010-11-19 06:08:56 +03:00
2011-04-07 02:54:52 +04:00
def create_root_account ( t , vm ) :
2010-11-19 06:08:56 +03:00
t . setwinvars ( vm )
2011-04-07 02:54:52 +04:00
t . info ( " Creating ' root ' account for testing Samba3 member server " )
2010-11-19 06:08:56 +03:00
t . chdir ( ' $ {PREFIX} ' )
2010-12-03 07:31:39 +03:00
t . run_cmd ( ' bin/net ads user add root -Uadministrator % $ {WIN_PASS} ' )
2010-12-10 07:09:54 +03:00
child = t . pexpect_spawn ( ' bin/net ads password root -Uadministrator % $ {WIN_PASS} ' )
child . expect ( " Enter new password for root " )
child . sendline ( " $ {PASSWORD2} " )
child . expect ( " Password change for " ) ;
child . expect ( " completed " )
child = t . pexpect_spawn ( ' bin/net rpc shell -S $ {WIN_HOSTNAME} .$ {WIN_REALM} -Uadministrator % $ {WIN_PASS} ' )
child . expect ( " net rpc> " )
child . sendline ( " user edit disabled root no " )
child . expect ( " Set root ' s disabled flag " )
2011-04-07 02:54:52 +04:00
def test_join_as_member ( t , vm ) :
''' test the domain join '''
t . setwinvars ( vm )
t . info ( ' Testing join as member ' )
t . chdir ( ' $ {PREFIX} ' )
2010-11-19 06:08:56 +03:00
test_wbinfo ( t )
test_smbclient ( t )
def test_s3 ( t ) :
''' basic s3 testing '''
2010-12-14 02:53:34 +03:00
t . setvar ( " SAMBA_VERSION " , " Version 3 " )
2010-12-10 04:13:58 +03:00
t . check_prerequesites ( )
set_libpath ( t )
if not t . skip ( " configure_bind " ) :
t . configure_bind ( )
if not t . skip ( " stop_bind " ) :
t . stop_bind ( )
if not t . skip ( " stop_vms " ) :
t . stop_vms ( )
2010-11-19 06:08:56 +03:00
if not t . skip ( " build " ) :
build_s3 ( t )
2010-12-14 02:53:34 +03:00
set_krb5_conf ( t )
2010-12-10 04:13:58 +03:00
if not t . skip ( " configure_bind2 " ) :
t . configure_bind ( )
if not t . skip ( " start_bind " ) :
t . start_bind ( )
2010-12-14 02:53:34 +03:00
dc_started = False
2010-11-19 06:08:56 +03:00
if t . have_var ( ' W2K8R2A_VM ' ) and not t . skip ( " join_w2k8r2 " ) :
2010-12-14 02:53:34 +03:00
t . start_winvm ( ' W2K8R2A ' )
dc_started = True
2010-12-10 04:13:58 +03:00
prep_join_as_member ( t , " W2K8R2A " )
t . run_dcpromo_as_first_dc ( " W2K8R2A " , func_level = ' 2008r2 ' )
2010-11-19 06:08:56 +03:00
join_as_member ( t , " W2K8R2A " )
create_shares ( t )
2010-12-03 07:31:39 +03:00
start_s3 ( t )
2011-04-07 02:54:52 +04:00
create_root_account ( t , " W2K8R2A " )
2010-11-19 06:08:56 +03:00
test_join_as_member ( t , " W2K8R2A " )
2010-12-14 02:53:34 +03:00
if t . have_var ( ' WINDOWS7_VM ' ) and t . have_var ( ' W2K8R2A_VM ' ) and not t . skip ( " join_windows7_2008r2 " ) :
if not dc_started :
t . start_winvm ( ' W2K8R2A ' )
t . run_dcpromo_as_first_dc ( " W2K8R2A " , func_level = ' 2008r2 ' )
dc_started = True
else :
t . setwinvars ( ' W2K8R2A ' )
realm = t . getvar ( " WIN_REALM " )
dom_username = t . getvar ( " WIN_USER " )
dom_password = t . getvar ( " WIN_PASS " )
dom_realm = t . getvar ( " WIN_REALM " )
t . start_winvm ( ' WINDOWS7 ' )
t . test_remote_smbclient ( " WINDOWS7 " )
t . run_winjoin ( ' WINDOWS7 ' , realm , username = dom_username , password = dom_password )
t . test_remote_smbclient ( " WINDOWS7 " , dom_username , dom_password )
t . test_remote_smbclient ( ' WINDOWS7 ' , dom_username , dom_password , args = ' --option=clientntlmv2auth=no ' )
t . test_remote_smbclient ( ' WINDOWS7 ' , " %s @ %s " % ( dom_username , dom_realm ) , dom_password , args = " -k " )
t . test_remote_smbclient ( ' WINDOWS7 ' , " %s @ %s " % ( dom_username , dom_realm ) , dom_password , args = " -k --option=clientusespnegoprincipal=yes " )
2011-04-07 02:54:52 +04:00
t . test_net_use ( ' WINDOWS7 ' , t . getvar ( " W2K8R2A_DOMAIN " ) , ' root ' , ' $ {PASSWORD2} ' )
2010-12-14 02:53:34 +03:00
if t . have_var ( ' WINXP_VM ' ) and t . have_var ( ' W2K8R2A_VM ' ) and not t . skip ( " join_winxp_2008r2 " ) :
if not dc_started :
t . start_winvm ( ' W2K8R2A ' )
t . run_dcpromo_as_first_dc ( " W2K8R2A " , func_level = ' 2008r2 ' )
dc_started = True
else :
t . setwinvars ( ' W2K8R2A ' )
realm = t . getvar ( " WIN_REALM " )
dom_username = t . getvar ( " WIN_USER " )
dom_password = t . getvar ( " WIN_PASS " )
dom_realm = t . getvar ( " WIN_REALM " )
t . start_winvm ( ' WINXP ' )
t . run_winjoin ( ' WINXP ' , realm , username = dom_username , password = dom_password )
t . test_remote_smbclient ( ' WINXP ' , dom_username , dom_password )
t . test_remote_smbclient ( ' WINXP ' , dom_username , dom_password , args = ' --option=clientntlmv2auth=no ' )
t . test_remote_smbclient ( ' WINXP ' , " %s @ %s " % ( dom_username , dom_realm ) , dom_password , args = " -k " )
t . test_remote_smbclient ( ' WINXP ' , " %s @ %s " % ( dom_username , dom_realm ) , dom_password , args = " -k --clientusespnegoprincipal=yes " )
2011-04-07 02:54:52 +04:00
t . test_net_use ( ' WINXP ' , t . getvar ( " W2K8R2A_DOMAIN " ) , ' root ' , ' $ {PASSWORD2} ' )
2010-12-14 02:53:34 +03:00
2010-11-19 06:08:56 +03:00
t . info ( " S3 test: All OK " )
2010-12-10 04:13:58 +03:00
def test_cleanup ( t ) :
''' cleanup after tests '''
t . info ( " Cleaning up ... " )
t . restore_resolv_conf ( )
if getattr ( t , ' bind_child ' , False ) :
t . bind_child . kill ( )
2010-12-03 07:31:39 +03:00
if __name__ == ' __main__ ' :
2010-11-19 06:08:56 +03:00
t = wintest . wintest ( )
2010-12-03 07:31:39 +03:00
t . setup ( " test-s3.py " , " source3 " )
2010-11-19 06:08:56 +03:00
2010-12-10 04:13:58 +03:00
try :
test_s3 ( t )
except :
if not t . opts . nocleanup :
test_cleanup ( t )
raise
if not t . opts . nocleanup :
test_cleanup ( t )
t . info ( " S3 test: All OK " )