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