File: 078-refresh.exp

package info (click to toggle)
modules 5.6.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 23,036 kB
  • sloc: exp: 79,659; sh: 6,142; tcl: 5,900; makefile: 1,493; ansic: 474; python: 265; csh: 202; perl: 47; ruby: 44; lisp: 13
file content (374 lines) | stat: -rw-r--r-- 13,556 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
##############################################################################
#   Modules Revision 3.0
#   Providing a flexible user environment
#
#   File:		modules.50-cmds/%M%
#   Revision:		%I%
#   First Edition:	2005/11/21
#   Last Mod.:		%U%, %G%
#
#   Authors:        Jens Hamisch, Jens.Hamisch@Strawberry.COM
#                   R.K.Owen, rk@owen.sj.ca.us
#                   Xavier Delaruelle, xavier.delaruelle@cea.fr
#
#   Description:	Testuite testsequence
#   Command:		refresh
#   Modulefiles:	alias/2.0,setenv/1.0
#   Sub-Command:
#
#   Comment:	%C{
#			Tests the 'refresh' module subcommand for all allowed
#			shell types.
#		}C%
#
##############################################################################

#
#  Variables.
#

set module1 "alias/2.0"
set modulefile1 "$modpath/$module1"
set module2 "setenv/1.0"
set modulefile2 "$modpath/$module2"
set alias "ps -auxww | grep modulecmd"

#
#  Set up the environment for refresh ...
#

setenv_loaded_module $module1 $modulefile1
setenv_var __MODULES_LMREFRESH $module1

#
#  For the different shells ...
#

lappend ans [list alias testsuite $alias]

#
#  The tests
#

# volatile components (ie. shell aliases/functions) are reloaded.
foreach shell $supported_shells {
    if {$shell in $other_shells && !($shell in {cmd pwsh})} {
        # as modulefiles are evaluated even if no environment changes are made for
        # these shells an "return true" shell code is produced
        testouterr_cmd $shell refresh [list [list OK nop]] {}
    } else {
        testouterr_cmd $shell refresh $ans {}
    }
}

skip_if_quick_mode

# abbreviated sub-command name
testouterr_cmd sh ref $ans {}

# source modulefile with "module refresh" command in it
set module modbad/refresh
set modulefile $modpath.3/$module
set tserr [escre [msg_moderr "module: Command 'refresh' not supported" "<EXM>module refresh" $modulefile 27 {  }]]
testouterr_cmd_re sh "source $modulefile" ERR $tserr


#
# Check 'refresh' evaluation mode
#

set mp $modpath.3
setenv_path_var MODULEPATH $mp

# nothing to refresh in loaded modules
setenv_loaded_module [list foo/1.0 bar/1.0] [list $mp/foo/1.0 $mp/bar/1.0]
unsetenv_var __MODULES_LMREFRESH
testouterr_cmd ALL refresh OK {}

# many things to refresh
setenv_loaded_module refresh/1.0 $mp/refresh/1.0
setenv_var __MODULES_LMREFRESH refresh/1.0
setenv_var FOO value
setenv_path_var BAR value othervalue

set ans [list]
lappend ans [list out {echo pre refresh/1.0}]
lappend ans [list alias altags {echo loaded}]
lappend ans [list alias alspec {echo refresh/1.0}]
lappend ans [list alias alcmd {echo refresh}]
lappend ans [list alias alfoo {echo foo1}]
lappend ans [list alias almode {echo refresh}]
lappend ans [list alias alisavail {echo is-avail ok}]
lappend ans [list alias algetenv {echo getenv ok}]
lappend ans [list funcfoo "() {" "echo foo1; };"]
lappend ans [list out {echo refresh/1.0}]
testouterr_cmd sh {refresh} $ans {}

# test tags
setenv_var __MODULES_LMTAG refresh/1.0&bar

set ans [list]
lappend ans [list out {echo pre refresh/1.0}]
lappend ans [list alias altags {echo bar loaded}]
lappend ans [list alias alspec {echo refresh/1.0}]
lappend ans [list alias alcmd {echo refresh}]
lappend ans [list alias alfoo {echo foo1}]
lappend ans [list alias almode {echo refresh}]
lappend ans [list alias alisavail {echo is-avail ok}]
lappend ans [list alias algetenv {echo getenv ok}]
lappend ans [list funcfoo "() {" "echo foo1; };"]
lappend ans [list out {echo refresh/1.0}]
testouterr_cmd sh {refresh} $ans {}

# test tags and variant
setenv_loaded_module refresh/2.0 $mp/refresh/2.0
setenv_var __MODULES_LMREFRESH refresh/2.0
setenv_var __MODULES_LMTAG refresh/2.0&bar
setenv_var MODULES_ADVANCED_VERSION_SPEC 1
setenv_var __MODULES_LMVARIANT refresh/2.0&foo|1|1|0

set ans [list]
lappend ans [list out {echo pre refresh/2.0}]
lappend ans [list alias altags {echo bar loaded}]
lappend ans [list alias alspec {echo refresh/2.0}]
lappend ans [list alias alfoo {echo foo2}]
lappend ans [list funcfoo "() {" "echo foo2; };"]
lappend ans [list out {echo refresh/2.0}]
testouterr_cmd sh {refresh} $ans {}

# test evaluation order
setenv_loaded_module [list refresh/1.0 refresh/2.0] [list $mp/refresh/1.0 $mp/refresh/2.0]
setenv_var __MODULES_LMREFRESH refresh/1.0:refresh/2.0
setenv_var __MODULES_LMTAG refresh/2.0&bar

set ans [list]
lappend ans [list out {echo pre refresh/1.0}]
lappend ans [list out {echo pre refresh/2.0}]
lappend ans [list alias altags {echo bar loaded}]
lappend ans [list alias alspec {echo refresh/2.0}]
lappend ans [list alias alisloaded2 {echo is-loaded ok}]
lappend ans [list alias alcmd {echo refresh}]
lappend ans [list alias alfoo {echo foo2}]
lappend ans [list alias almode {echo refresh}]
lappend ans [list alias alisavail {echo is-avail ok}]
lappend ans [list alias algetenv {echo getenv ok}]
lappend ans [list alias alisloaded1 {echo is-loaded ok}]
lappend ans [list funcfoo "() {" "echo foo2; };"]
lappend ans [list out {echo refresh/1.0}]
lappend ans [list out {echo refresh/2.0}]
testouterr_cmd sh {refresh} $ans {}

# verbose output mode
set tserr2 [msg_refresh refresh/1.0]\n[msg_refresh {refresh/2.0{+foo} <bar>}]
testouterr_cmd sh {refresh -v} $ans $tserr2

# verbose output and hidden-loaded module
setenv_var __MODULES_LMTAG refresh/2.0&bar&hidden-loaded
set tserr1 [msg_refresh refresh/1.0]
set ans [list]
lappend ans [list out {echo pre refresh/1.0}]
lappend ans [list out {echo pre refresh/2.0}]
lappend ans [list alias altags {echo bar hidden-loaded loaded}]
lappend ans [list alias alspec {echo refresh/2.0}]
lappend ans [list alias alisloaded2 {echo is-loaded ok}]
lappend ans [list alias alcmd {echo refresh}]
lappend ans [list alias alfoo {echo foo2}]
lappend ans [list alias almode {echo refresh}]
lappend ans [list alias alisavail {echo is-avail ok}]
lappend ans [list alias algetenv {echo getenv ok}]
lappend ans [list alias alisloaded1 {echo is-loaded ok}]
lappend ans [list funcfoo "() {" "echo foo2; };"]
lappend ans [list out {echo refresh/1.0}]
lappend ans [list out {echo refresh/2.0}]
set tserr2 [msg_refresh refresh/1.0]\n[msg_refresh {refresh/2.0{+foo} <bar:H>}]
testouterr_cmd sh {refresh -v} $ans $tserr2

# verbose output and hidden-loaded module
setenv_var __MODULES_LMTAG refresh/2.0&bar&hidden-loaded&auto-loaded
set ans [list]
lappend ans [list out {echo pre refresh/1.0}]
lappend ans [list out {echo pre refresh/2.0}]
lappend ans [list alias altags {echo auto-loaded bar hidden-loaded}]
lappend ans [list alias alspec {echo refresh/2.0}]
lappend ans [list alias alisloaded2 {echo is-loaded ok}]
lappend ans [list alias alcmd {echo refresh}]
lappend ans [list alias alfoo {echo foo2}]
lappend ans [list alias almode {echo refresh}]
lappend ans [list alias alisavail {echo is-avail ok}]
lappend ans [list alias algetenv {echo getenv ok}]
lappend ans [list alias alisloaded1 {echo is-loaded ok}]
lappend ans [list funcfoo "() {" "echo foo2; };"]
lappend ans [list out {echo refresh/1.0}]
lappend ans [list out {echo refresh/2.0}]
testouterr_cmd sh {refresh -v} $ans $tserr1
set tserr2 [msg_refresh refresh/1.0]\n[msg_refresh {refresh/2.0{+foo} <aL:bar:H>}]
testouterr_cmd sh {refresh -vv} $ans $tserr2
setenv_var __MODULES_LMTAG refresh/1.0&hidden-loaded&auto-loaded:refresh/2.0&bar&hidden-loaded&auto-loaded
testouterr_cmd sh {refresh -v} $ans {}
set tserr2 [msg_refresh {refresh/1.0 <aL:H>}]\n[msg_refresh {refresh/2.0{+foo} <aL:bar:H>}]
testouterr_cmd sh {refresh -vv} $ans $tserr2
unsetenv_var __MODULES_LMTAG

# test alias/function set through source-sh
setenv_loaded_module [list refresh/3.0] [list $mp/refresh/3.0]
setenv_var __MODULES_LMREFRESH refresh/3.0

set ans [list]
lappend ans [list alias alsp {echo f\"o; echo b\\\"r; echo f\'o}]
lappend ans [list alias alfoo {echo $(grep "report .Modules " ../../modulecmd.tcl | tr -d \\ 2>/dev/null | awk '{print $3}')}]
lappend ans [list alias alcb echo\ f\{o]
lappend ans [list alias alem {}]
lappend ans [list funcfoo "() { echo foo; };"]
lappend ans [list funccb "() { echo f\{o; };"]
lappend ans [list funcwc "() { echo sou*sh; };"]
lappend ans [list funcnl "() { echo foo;
    echo bar; };"]
lappend ans [list funcsp "() { echo f\\\"o;
    echo b\\\\\\\"r;
    echo f\\'o; };"]
testouterr_cmd sh {refresh} $ans {}

#
# error during refresh evaluation
#

setenv_loaded_module [list refresh/1.0 refresh/2.0] [list $mp/refresh/1.0 $mp/refresh/2.0]
setenv_var __MODULES_LMREFRESH refresh/1.0:refresh/2.0
setenv_var __MODULES_LMTAG refresh/2.0&bar

# break during evaluation
setenv_var TESTSUITE_REFRESH break1
set ans1 [list]
lappend ans1 [list out {echo pre refresh/2.0}]
lappend ans1 [list alias altags {echo bar loaded}]
lappend ans1 [list alias alspec {echo refresh/2.0}]
lappend ans1 [list alias alfoo {echo foo2}]
lappend ans1 [list alias alisloaded1 {echo is-loaded ok}]
lappend ans1 [list funcfoo "() {" "echo foo2; };"]
lappend ans1 [list out {echo refresh/2.0}]
lappend ans1 [list ERR]
testouterr_cmd sh {refresh} $ans1 [msg_refresh refresh/1.0 $err_evalabort]

# verbose output
testouterr_cmd sh {refresh -v} $ans1 [msg_refresh refresh/1.0 $err_evalabort]\n\n[msg_refresh {refresh/2.0{+foo} <bar>}]
# hidden-loaded/auto-loaded
setenv_var __MODULES_LMTAG refresh/1.0&bar&hidden-loaded&auto-loaded:refresh/2.0&bar
set tserr [msg_refresh {refresh/1.0 <aL:bar:H>} $err_evalabort]
testouterr_cmd sh {refresh} $ans1 $tserr
setenv_var __MODULES_LMTAG refresh/2.0&bar

# break in second loaded module
setenv_var TESTSUITE_REFRESH break2

set ans2 [list]
lappend ans2 [list out {echo pre refresh/1.0}]
lappend ans2 [list alias alisloaded2 {echo is-loaded ok}]
lappend ans2 [list alias alspec {echo refresh/1.0}]
lappend ans2 [list alias altags {echo loaded}]
lappend ans2 [list alias alfoo {echo foo1}]
lappend ans2 [list alias alcmd {echo refresh}]
lappend ans2 [list alias algetenv {echo getenv ok}]
lappend ans2 [list alias alisavail {echo is-avail ok}]
lappend ans2 [list alias almode {echo refresh}]
lappend ans2 [list funcfoo "() {" "echo foo1; };"]
lappend ans2 [list out {echo refresh/1.0}]
lappend ans2 [list ERR]
set tserr [msg_refresh {refresh/2.0{+foo} <bar>} $err_evalabort]
testouterr_cmd sh {refresh} $ans2 $tserr

# break in both loaded modules
setenv_var TESTSUITE_REFRESH break0
testouterr_cmd sh {refresh} ERR [msg_refresh refresh/1.0 $err_evalabort]\n\n[msg_refresh {refresh/2.0{+foo} <bar>} $err_evalabort]

# unknown command
setenv_var TESTSUITE_REFRESH badcmd1
if {[cmpversion $tclsh_version 8.6] == -1} {
    set custom "    invoked from within
\"if \{\[info exists env(TESTSUITE_REFRESH)\]\} \{
    switch -- \$env(TESTSUITE_REFRESH) \{
        break0 - break1 \{
            break
        \}
        badc...\""
    set linenum 33
} else {
    set custom {}
    set linenum 39
}
set tserr [msg_refresh refresh/1.0 [msg_moderr {invalid command name "unk"} {unk} $mp/refresh/1.0 $linenum {} {} {} $custom]]
testouterr_cmd sh {refresh} $ans1 $tserr
setenv_var TESTSUITE_REFRESH badcmd2
if {[cmpversion $tclsh_version 8.6] == -1} {
    set custom "    invoked from within
\"if \{\[info exists env(TESTSUITE_REFRESH)\]\} \{
    switch -- \$env(TESTSUITE_REFRESH) \{
        break0 - break2 \{
            break
        \}
        badc...\""
    set linenum 13
} else {
    set custom {}
    set linenum 19
}
set tserr [msg_refresh {refresh/2.0{+foo} <bar>} [msg_moderr {invalid command name "unk"} {unk} $mp/refresh/2.0 $linenum {} {} {} $custom]]
testouterr_cmd sh {refresh} $ans2 $tserr

# continue command
setenv_var TESTSUITE_REFRESH continue1
set ans [list]
lappend ans [list out {echo pre refresh/2.0}]
lappend ans [list alias altags {echo bar loaded}]
lappend ans [list alias alspec {echo refresh/2.0}]
lappend ans [list alias alisloaded2 {echo is-loaded ok}]
lappend ans [list alias alfoo {echo foo2}]
lappend ans [list alias alisavail {echo is-avail ok}]
lappend ans [list alias algetenv {echo getenv ok}]
lappend ans [list alias alisloaded1 {echo is-loaded ok}]
lappend ans [list funcfoo "() {" "echo foo2; };"]
lappend ans [list out {echo refresh/2.0}]
testouterr_cmd sh {refresh} $ans {}

setenv_var TESTSUITE_REFRESH continue2
set ans [list]
lappend ans [list out {echo pre refresh/1.0}]
lappend ans [list alias altags {echo bar loaded}]
lappend ans [list alias alspec {echo refresh/2.0}]
lappend ans [list alias alisloaded2 {echo is-loaded ok}]
lappend ans [list alias alcmd {echo refresh}]
lappend ans [list alias alfoo {echo foo2}]
lappend ans [list alias almode {echo refresh}]
lappend ans [list alias alisavail {echo is-avail ok}]
lappend ans [list alias algetenv {echo getenv ok}]
lappend ans [list alias alisloaded1 {echo is-loaded ok}]
lappend ans [list funcfoo "() {" "echo foo2; };"]
lappend ans [list out {echo refresh/1.0}]
testouterr_cmd sh {refresh} $ans {}

# verbose output
set tserr [msg_refresh refresh/1.0]\n[msg_refresh {refresh/2.0{+foo} <bar>}]
testouterr_cmd sh {refresh -v} $ans $tserr

# exit command
setenv_var TESTSUITE_REFRESH exit1
set tserr [msg_refresh refresh/1.0 $err_evalabort]
testouterr_cmd sh {refresh} ERR $tserr
setenv_var TESTSUITE_REFRESH exit2
set tserr [msg_refresh {refresh/2.0{+foo} <bar>} $err_evalabort]
testouterr_cmd sh {refresh} $ans2 $tserr

# verbose output, 2 module loaded, only one made for refresh
setenv_loaded_module [list refresh/4.0 refresh/6.0] [list $mp/refresh/4.0 $mp/refresh/6.0]
setenv_var __MODULES_LMREFRESH refresh/4.0
set ans [list]
lappend ans [list alias alfoo {echo foo4}]
lappend ans [list funcfoo "() {" "echo foo4; };"]
set tserr [msg_refresh refresh/4.0]
testouterr_cmd sh {refresh -v} $ans $tserr


#
#  Cleanup
#

reset_test_env