11.2Schristos# $NetBSD: t_dotcmd.sh,v 1.2 2016/03/27 14:57:50 christos Exp $ 21.1Schristos# 31.1Schristos# Copyright (c) 2014 The NetBSD Foundation, Inc. 41.1Schristos# All rights reserved. 51.1Schristos# 61.1Schristos# This code is derived from software contributed to The NetBSD Foundation 71.1Schristos# by Jarmo Jaakkola. 81.1Schristos# 91.1Schristos# Redistribution and use in source and binary forms, with or without 101.1Schristos# modification, are permitted provided that the following conditions 111.1Schristos# are met: 121.1Schristos# 1. Redistributions of source code must retain the above copyright 131.1Schristos# notice, this list of conditions and the following disclaimer. 141.1Schristos# 2. Redistributions in binary form must reproduce the above copyright 151.1Schristos# notice, this list of conditions and the following disclaimer in the 161.1Schristos# documentation and/or other materials provided with the distribution. 171.1Schristos# 181.1Schristos# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 191.1Schristos# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 201.1Schristos# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 211.1Schristos# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 221.1Schristos# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 231.1Schristos# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 241.1Schristos# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 251.1Schristos# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 261.1Schristos# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 271.1Schristos# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 281.1Schristos# POSSIBILITY OF SUCH DAMAGE. 291.1Schristos# 301.1Schristos 311.1Schristos# Test loop and function flow control statements in various scopes in a file 321.1Schristos# sourced by a dotcmd in various scopes. Basically, dotcmd is like #include 331.1Schristos# in C/C++ so, for example, if the dotcmd is in a loop's body, a break in 341.1Schristos# the sourced file can be used to break out of that loop. 351.1Schristos 361.2Schristos# Note that the standard does not require this, and allows lexically 371.2Schristos# scoped interpretation of break/continue (and permits dynamic scope 381.2Schristos# as an optional extension.) 391.2Schristos 401.1Schristoscmds='return break continue' 411.1Schristosscopes='case compound file for func subshell until while' 421.1Schristos 431.1Schristoscase_ids='' 441.1Schristos 451.1Schristosfor dot_scope in ${scopes} 461.1Schristosdo 471.1Schristos for cmd in ${cmds} 481.1Schristos do 491.1Schristos for cmd_scope in ${scopes} 501.1Schristos do 511.1Schristos case_id="${dot_scope}_${cmd}_${cmd_scope}" 521.1Schristos case_ids="${case_ids} ${case_id}" 531.1Schristos atf_test_case "${case_id}" 541.1Schristos eval " 551.1Schristos${case_id}_head() 561.1Schristos{ 571.1Schristos atf_set 'descr' \\ 581.1Schristos 'dotcmd in ${dot_scope}, file contains ${cmd} in ${cmd_scope}' 591.1Schristos} 601.1Schristos 611.1Schristos${case_id}_body() 621.1Schristos{ 631.1Schristos srcdir=\$(atf_get_srcdir) 641.1Schristos # for dotcmd to find the sourced files 651.1Schristos PATH=\"\${PATH}:\${srcdir}\" 661.1Schristos atf_check -o file:\"\${srcdir}/out/${case_id}.out\" \\ 671.1Schristos \"\${srcdir}/${case_id}\" 681.1Schristos} 691.1Schristos" # end eval 701.1Schristos done 711.1Schristos done 721.1Schristosdone 731.1Schristos 741.1Schristosatf_init_test_cases() 751.1Schristos{ 761.1Schristos for case_id in ${case_ids} 771.1Schristos do 781.1Schristos atf_add_test_case "${case_id}" 791.1Schristos done 801.1Schristos} 81