1*96c8483aSYuri Pankov#!/bin/ksh -p
2*96c8483aSYuri Pankov#
3*96c8483aSYuri Pankov# CDDL HEADER START
4*96c8483aSYuri Pankov#
5*96c8483aSYuri Pankov# The contents of this file are subject to the terms of the
6*96c8483aSYuri Pankov# Common Development and Distribution License (the "License").
7*96c8483aSYuri Pankov# You may not use this file except in compliance with the License.
8*96c8483aSYuri Pankov#
9*96c8483aSYuri Pankov# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10*96c8483aSYuri Pankov# or http://www.opensolaris.org/os/licensing.
11*96c8483aSYuri Pankov# See the License for the specific language governing permissions
12*96c8483aSYuri Pankov# and limitations under the License.
13*96c8483aSYuri Pankov#
14*96c8483aSYuri Pankov# When distributing Covered Code, include this CDDL HEADER in each
15*96c8483aSYuri Pankov# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16*96c8483aSYuri Pankov# If applicable, add the following below this CDDL HEADER, with the
17*96c8483aSYuri Pankov# fields enclosed by brackets "[]" replaced with your own identifying
18*96c8483aSYuri Pankov# information: Portions Copyright [yyyy] [name of copyright owner]
19*96c8483aSYuri Pankov#
20*96c8483aSYuri Pankov# CDDL HEADER END
21*96c8483aSYuri Pankov#
22*96c8483aSYuri Pankov
23*96c8483aSYuri Pankov#
24*96c8483aSYuri Pankov# Copyright 2010 Sun Microsystems, Inc.  All rights reserved.
25*96c8483aSYuri Pankov#
26*96c8483aSYuri Pankov
27*96c8483aSYuri Pankov#
28*96c8483aSYuri Pankov# ID: error_001
29*96c8483aSYuri Pankov#
30*96c8483aSYuri Pankov# DESCRIPTION:
31*96c8483aSYuri Pankov#        Verify link error on the smbfs
32*96c8483aSYuri Pankov#
33*96c8483aSYuri Pankov# STRATEGY:
34*96c8483aSYuri Pankov#        1. run "mount -F smbfs //server/public $TMNT" on the smb
35*96c8483aSYuri Pankov#        2. touch file and create link
36*96c8483aSYuri Pankov#	 3. The "ln -s" can get the right message
37*96c8483aSYuri Pankov#
38*96c8483aSYuri Pankov
39*96c8483aSYuri Pankov. $STF_SUITE/include/libtest.ksh
40*96c8483aSYuri Pankov
41*96c8483aSYuri Pankovtc_id="error001"
42*96c8483aSYuri Pankovtc_desc=" Verify link error on the smbfs"
43*96c8483aSYuri Pankovprint_test_case $tc_id - $tc_desc
44*96c8483aSYuri Pankov
45*96c8483aSYuri Pankovif [[ $STC_CIFS_CLIENT_DEBUG == 1 ]] || \
46*96c8483aSYuri Pankov	[[ *:${STC_CIFS_CLIENT_DEBUG}:* == *:$tc_id:* ]]; then
47*96c8483aSYuri Pankov    set -x
48*96c8483aSYuri Pankovfi
49*96c8483aSYuri Pankov
50*96c8483aSYuri Pankovserver=$(server_name) || return
51*96c8483aSYuri Pankov
52*96c8483aSYuri Pankovtestdir_init $TDIR
53*96c8483aSYuri Pankovsmbmount_clean $TMNT
54*96c8483aSYuri Pankovsmbmount_init $TMNT
55*96c8483aSYuri Pankov
56*96c8483aSYuri Pankovcmd="mount -F smbfs //$TUSER:$TPASS@$server/public $TMNT"
57*96c8483aSYuri Pankovcti_execute -i '' FAIL $cmd
58*96c8483aSYuri Pankovif [[ $? != 0 ]]; then
59*96c8483aSYuri Pankov	cti_fail "smbmount  can't mount the public share"
60*96c8483aSYuri Pankov	return
61*96c8483aSYuri Pankovelse
62*96c8483aSYuri Pankov	cti_report "smbmount  can mount the public share"
63*96c8483aSYuri Pankovfi
64*96c8483aSYuri Pankov
65*96c8483aSYuri Pankov# cleanup
66*96c8483aSYuri Pankovcti_execute_cmd "rm -rf $TMNT/*"
67*96c8483aSYuri Pankov
68*96c8483aSYuri Pankovcti_execute_cmd "touch $TMNT/file"
69*96c8483aSYuri Pankovif [[ $? != 0 ]]; then
70*96c8483aSYuri Pankov	cti_fail "FAIL: touch file failed on smbfs"
71*96c8483aSYuri Pankov	return
72*96c8483aSYuri Pankovelse
73*96c8483aSYuri Pankov	cti_report "PASS: touch file succeeded on smbfs"
74*96c8483aSYuri Pankovfi
75*96c8483aSYuri Pankov
76*96c8483aSYuri Pankovcti_execute_cmd "(cd $TMNT; ln file file_ln)"
77*96c8483aSYuri Pankovif [[ $? == 0 ]]; then
78*96c8483aSYuri Pankov	cti_fail "FAIL: ln file file_ln succeeded on smbfs"
79*96c8483aSYuri Pankov	return
80*96c8483aSYuri Pankovelse
81*96c8483aSYuri Pankov	cti_report "PASS: ln file file_ln failed on smbfs"
82*96c8483aSYuri Pankovfi
83*96c8483aSYuri Pankov
84*96c8483aSYuri Pankovcti_execute_cmd "(cd $TMNT; ln -s file file_ln)"
85*96c8483aSYuri Pankovif [[ $? == 0 ]]; then
86*96c8483aSYuri Pankov	cti_fail "ln -s file file_ln succeeded on smbfs"
87*96c8483aSYuri Pankov	return
88*96c8483aSYuri Pankovelse
89*96c8483aSYuri Pankov	cti_report "ln -s file file_ln failed on smbfs"
90*96c8483aSYuri Pankovfi
91*96c8483aSYuri Pankovcti_execute_cmd "rm $TMNT/file"
92*96c8483aSYuri Pankov
93*96c8483aSYuri Pankovcti_execute_cmd "mkdir $TMNT/dir"
94*96c8483aSYuri Pankovif [[ $? != 0 ]]; then
95*96c8483aSYuri Pankov	cti_fail "mkdir dir failed on smbfs"
96*96c8483aSYuri Pankov	return
97*96c8483aSYuri Pankovelse
98*96c8483aSYuri Pankov	cti_report "mkdir dir succeeded on smbfs"
99*96c8483aSYuri Pankovfi
100*96c8483aSYuri Pankov
101*96c8483aSYuri Pankovcti_execute_cmd "(cd $TMNT; ln -s dir dir_ln)"
102*96c8483aSYuri Pankovif [[ $? == 0 ]]; then
103*96c8483aSYuri Pankov	cti_fail "ln -s dir dir_ln succeeded on smbfs"
104*96c8483aSYuri Pankov	return
105*96c8483aSYuri Pankovelse
106*96c8483aSYuri Pankov	cti_report "ln -s dir dir_ln failed on smbfs"
107*96c8483aSYuri Pankovfi
108*96c8483aSYuri Pankov
109*96c8483aSYuri Pankovcti_execute_cmd "rmdir $TMNT/dir"
110*96c8483aSYuri Pankov
111*96c8483aSYuri Pankovsmbmount_clean $TMNT
112*96c8483aSYuri Pankovcti_pass "${tc_id}: PASS"
113