Skip to content

Commit

Permalink
Add some ATF tests for ctladm
Browse files Browse the repository at this point in the history
So far only "ctladm port -c" and "ctladm port -r" are covered.

MFC after:	2 weeks
Sponsored by:	Axcient
Reviewed by:	mav
Pull Request:	freebsd/freebsd-src#1279
  • Loading branch information
asomers committed Jun 10, 2024
1 parent 0e34d09 commit 9747d11
Show file tree
Hide file tree
Showing 4 changed files with 170 additions and 0 deletions.
2 changes: 2 additions & 0 deletions etc/mtree/BSD.tests.dist
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,8 @@
..
..
usr.sbin
ctladm
..
dtrace
common
aggs
Expand Down
3 changes: 3 additions & 0 deletions usr.sbin/ctladm/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -23,4 +23,7 @@ MAN= ctladm.8
CFLAGS+= -DWANT_ISCSI
.endif

HAS_TESTS=
SUBDIR.${MK_TESTS}+= tests

.include <bsd.prog.mk>
10 changes: 10 additions & 0 deletions usr.sbin/ctladm/tests/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@

PACKAGE= tests

ATF_TESTS_SH= port

# "ctladm port" does not report the name of the port just created, so we can't
# cleanup unless we assume that no other test created a port too.
TEST_METADATA+= is_exclusive="true"

.include <bsd.test.mk>
155 changes: 155 additions & 0 deletions usr.sbin/ctladm/tests/port.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,155 @@
# Things that aren't tested due to lack of kernel support:
# * Creating camsim ports
# * Creating tpc ports
# * Creating camtgt ports
# * Creating umass ports

# TODO
# * Creating iscsi ports
# * Creating nvmf ports
# * Creating ha ports
# * Creating fc ports

skip_if_ctld() {
if service ctld onestatus > /dev/null; then
# If ctld is running on this server, let's not interfere.
atf_skip "Cannot run this test while ctld is running"
fi
}

cleanup() {
driver=$1

if [ -e after-ports ]; then
diff before-ports after-ports | awk "/$driver/ {print \$2}" | xargs -n1 ctladm port -r -d ioctl -p
fi
}

atf_test_case create_ioctl cleanup
create_ioctl_head()
{
atf_set "descr" "ctladm can create a new ioctl port"
atf_set "require.user" "root"
}
create_ioctl_body()
{
skip_if_ctld

atf_check -o save:before-ports ctladm portlist -qf ioctl
atf_check ctladm port -c -d "ioctl"
atf_check -o save:after-ports ctladm portlist -qf ioctl
if test `wc -l before-ports | cut -w -f2` -ge `wc -l after-ports | cut -w -f2`; then
atf_fail "Did not create a new ioctl port"
fi
}
create_ioctl_cleanup()
{
cleanup ioctl
}

atf_test_case create_ioctl_options cleanup
create_ioctl_options_head()
{
atf_set "descr" "ctladm can set options when creating a new ioctl port"
atf_set "require.user" "root"
}
create_ioctl_options_body()
{
skip_if_ctld

atf_check -o save:before-ports ctladm portlist -qf ioctl
atf_check ctladm port -c -d "ioctl" -O pp=101 -O vp=102
atf_check -o save:after-ports ctladm portlist -qf ioctl
if test `wc -l before-ports | cut -w -f2` -ge `wc -l after-ports | cut -w -f2`; then
atf_fail "Did not create a new ioctl port"
fi
if ! egrep -q '101[[:space:]]+102' after-ports; then
ctladm portlist
atf_fail "Did not create the port with the specified options"
fi
}
create_ioctl_options_cleanup()
{
cleanup ioctl
}


atf_test_case disable_ioctl cleanup
disable_ioctl_head()
{
atf_set "descr" "ctladm can disable an ioctl port"
atf_set "require.user" "root"
}
disable_ioctl_body()
{
skip_if_ctld

atf_check -o save:before-ports ctladm portlist -qf ioctl
atf_check ctladm port -c -d "ioctl"
atf_check -o save:after-ports ctladm portlist -qf ioctl
if test `wc -l before-ports | cut -w -f2` -ge `wc -l after-ports | cut -w -f2`; then
atf_fail "Did not create a new ioctl port"
fi
portnum=`diff before-ports after-ports | awk '/ioctl/ {print $2}'`;
atf_check -o ignore ctladm port -o off -p $portnum
atf_check -o match:"^$portnum *NO" ctladm portlist -qf ioctl
}
disable_ioctl_cleanup()
{
cleanup ioctl
}

atf_test_case enable_ioctl cleanup
enable_ioctl_head()
{
atf_set "descr" "ctladm can enable an ioctl port"
atf_set "require.user" "root"
}
enable_ioctl_body()
{
skip_if_ctld

atf_check -o save:before-ports ctladm portlist -qf ioctl
atf_check ctladm port -c -d "ioctl"
atf_check -o save:after-ports ctladm portlist -qf ioctl
if test `wc -l before-ports | cut -w -f2` -ge `wc -l after-ports | cut -w -f2`; then
atf_fail "Did not create a new ioctl port"
fi
portnum=`diff before-ports after-ports | awk '/ioctl/ {print $2}'`;
atf_check -o ignore ctladm port -o off -p $portnum
atf_check -o ignore ctladm port -o on -p $portnum
atf_check -o match:"^$portnum *YES" ctladm portlist -qf ioctl
}
enable_ioctl_cleanup()
{
cleanup ioctl
}

atf_test_case remove_ioctl
remove_ioctl_head()
{
atf_set "descr" "ctladm can remove an ioctl port"
atf_set "require.user" "root"
}
remove_ioctl_body()
{
skip_if_ctld

atf_check -o save:before-ports ctladm portlist -qf ioctl
atf_check ctladm port -c -d "ioctl"
atf_check -o save:after-ports ctladm portlist -qf ioctl
if test `wc -l before-ports | cut -w -f2` -ge `wc -l after-ports | cut -w -f2`; then
atf_fail "Did not create a new ioctl port"
fi
portnum=`diff before-ports after-ports | awk '/ioctl/ {print $2}'`;
atf_check ctladm port -r -d ioctl -p $portnum
}

atf_init_test_cases()
{
atf_add_test_case create_ioctl
atf_add_test_case create_ioctl_options
atf_add_test_case disable_ioctl
atf_add_test_case enable_ioctl
atf_add_test_case remove_ioctl
}

0 comments on commit 9747d11

Please sign in to comment.