File: 068-transitive-deep.exp

package info (click to toggle)
modules 5.2.0-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 20,572 kB
  • sloc: exp: 46,525; sh: 5,261; tcl: 3,182; makefile: 1,355; ansic: 466; python: 251; csh: 201; perl: 47; ruby: 44
file content (520 lines) | stat: -rw-r--r-- 19,065 bytes parent folder | download | duplicates (4)
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
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
##############################################################################
#   Modules Revision 3.0
#   Providing a flexible user environment
#
#   File:		modules.80-deep/%M%
#   Revision:		%I%
#   First Edition:	2017/08/16
#   Last Mod.:		%U%, %G%
#
#   Authors:		Xavier Delaruelle, xavier.delaruelle@cea.fr
#
#   Description:	Testuite testsequence
#   Command:        load, display, help, test, avail, whatis, paths
#   Modulefiles:	modtr
#   Sub-Command:
#
#   Comment:	%C{
#           Test the correct resolution of module aliases and symbolic
#           versions set in a transitive manner on deep modules
#		}C%
#
##############################################################################

skip_if_quick_mode

# ensure regular avail search match is set for these tests
setenv_var MODULES_SEARCH_MATCH starts_with

# ensure auto symbolic versions are not set for these tests
setenv_var MODULES_ADVANCED_VERSION_SPEC 0

set datetime_re "\[0-9\/]{10} \[0-9:]{8}"

# symbol set on symbol
set modsym_1 "modtr/dir1/stable"
set module_1 "modtr/dir1/1.0"
set modalt_1 modtr/dir1/cur&modtr/dir1/stable
set modulefile_1 "$modpath/$module_1"
set modulefilere_1 "$modpathre/$module_1"
set modavail_1 "$module_1\\s+cur:stable\\s+$datetime_re"

# alias set on symbol (alias set before target symbol definition)
set modsym_2 "modtr/al1"
set module_2 "modtr/dir2/2.0"
set modalt_2 modtr/dir2/next&modtr/unstable&modtr/dir2/unstable&al|modtr/al1
set modulefile_2 "$modpath/$module_2"
set modulefilere_2 "$modpathre/$module_2"
set modavail_2 "$modsym_2 -> modtr/dir2/next\\s+unstable\\s+"

# symbol set on alias of symbol (alias set before target symbol definition)
set modsym_3 "modtr/unstable"
set module_3 "$module_2"
set modalt_3 $modalt_2
set modulefile_3 "$modulefile_2"
set modulefilere_3 "$modulefilere_2"
# alias is returned on avail as symbol refers to an alias in dir
set modavail_3 "$modavail_2"

# alias set on symbol (alias set after target symbol definition)
set modsym_4 "modtr/dir3/al2"
set module_4 "modtr/3.0"
set modalt_4 modtr/foo&modtr/dir3/bar&modtr/bar&modtr/dir3/exp&modtr/default&modtr&modtr/reg&modtr/dir3/default&modtr/dir3&modtr/dir3/reg&modtr/exp&al|modtr/dir3/al2&al|modtr/dir3/al3&al|modtr/al4
set modulefile_4 "$modpath/$module_4"
set modulefilere_4 "$modpathre/$module_4"
# symbol set on alias targeting this alias also appear here
set modavail_4 "$modsym_4 -> modtr/foo\\s+bar:default:exp:reg\\s+"

# symbol set on alias of symbol (alias set after target symbol definition)
set modsym_5 "modtr/dir3/bar"
set module_5 "$module_4"
set modalt_5 $modalt_4
set modulefile_5 "$modulefile_4"
set modulefilere_5 "$modulefilere_4"
# alias is returned on avail as symbol refers to an alias in dir
set modavail_5 "$modavail_4"

# alias set on alias of symbol
set modsym_6 "modtr/dir3/al3"
set module_6 "$module_4"
set modalt_6 $modalt_4
set modulefile_6 "$modulefile_4"
set modulefilere_6 "$modulefilere_4"
set modavail_6 "$modsym_6 -> modtr/dir3/al2\\s+default:exp:reg\\s+"

# symbol set on alias of alias of symbol
set modsym_7 "modtr/dir3/exp"
set module_7 "$module_4"
set modalt_7 $modalt_4
set modulefile_7 "$modulefile_4"
set modulefilere_7 "$modulefilere_4"
# alias is returned on avail as symbol refers to an alias in dir
# but this is last resolved alias in dir which will be returned
set modavail_7 "$modavail_4"

# alias set on symbol set on alias of alias of symbol
set modsym_8 "modtr/al4"
set module_8 "$module_4"
set modalt_8 $modalt_4
set modulefile_8 "$modulefile_4"
set modulefilere_8 "$modulefilere_4"
set modavail_8 "$modsym_8 -> modtr/dir3/exp\\s+default:reg\\s+"

# alias set on directory
set modsym_9 "modtr/al5"
set module_9 "modtr/dir4/mod4.0"
set modalt_9 modtr/fld&al|modtr/al5
set modulefile_9 "$modpath/$module_9"
set modulefilere_9 "$modpathre/$module_9"
set modavail_9 "$modsym_9 -> modtr/dir4\\s+fld\\s+"
set nodefault_9 "$err_nodefault'modtr/dir4'"

# symbol set on alias of directory
set modsym_10 "modtr/fld"
set module_10 "$module_9"
set modalt_10 $modalt_9
set modulefile_10 "$modulefile_9"
set modulefilere_10 "$modulefilere_9"
set modavail_10 [if_availindepth "modtr/dir4/\\s+fld\\s+\nmodtr/dir4/al7 -> modtr/dir5/subdir/mod5.0\\s*madj\\s+\nmodtr/dir4/al8 -> modtr/dir5/sfld\\s+dadj\\s+\n$module_9\\s+$datetime_re" "modtr/dir4/\\s+fld\\s+"]
set nodefault_10 $nodefault_9
set extrawhatis_10 "\n\\s*modtr/dir5/subdir/mod5.0: modtr/dir5/subdir/mod5.0"
set extrapaths_10 "$modpath/modtr/dir5/subdir/mod5.0"

# alias set on sub-directory
set modsym_11 "modtr/al6"
set module_11 "modtr/dir5/subdir/mod5.0"
set modalt_11 modtr/sfld&modtr/dir5/sfld&modtr/dir4/dadj&modtr/dir5/dadj&modtr/dir4/madj&modtr/dir5/subdir/madj&al|modtr/al6&al|modtr/dir4/al8&al|modtr/dir4/al7
set modulefile_11 "$modpath/$module_11"
set modulefilere_11 "$modpathre/$module_11"
set modavail_11 "$modsym_11 -> modtr/dir5/subdir\\s+sfld\\s+"
set nodefault_11 "$err_nodefault'modtr/dir5/subdir'"

# symbol set on alias of sub-directory
set modsym_12 "modtr/sfld"
set module_12 "$module_11"
set modalt_12 $modalt_11
set modulefile_12 "$modulefile_11"
set modulefilere_12 "$modulefilere_11"
set modavail_12 "$modavail_11"
set nodefault_12 $nodefault_11

# alias set on modulefile of an adjacent sub-directory
set modsym_13 "modtr/dir4/al7"
set module_13 "$module_11"
set modalt_13 $modalt_11
set modulefile_13 "$modulefile_11"
set modulefilere_13 "$modulefilere_11"
set modavail_13 "$modsym_13 -> modtr/dir5/subdir/mod5.0\\s*madj\\s+"

# symbol set on alias of modulefile of an adjacent sub-directory
set modsym_14 "modtr/dir4/madj"
set module_14 "$module_11"
set modalt_14 $modalt_11
set modulefile_14 "$modulefile_11"
set modulefilere_14 "$modulefilere_11"
set modavail_14 "$modavail_13"

# alias set on symbol of an adjacent sub-directory
set modsym_15 "modtr/dir4/al8"
set module_15 "$module_11"
set modalt_15 $modalt_11
set modulefile_15 "$modulefile_11"
set modulefilere_15 "$modulefilere_11"
set modavail_15 "$modsym_15 -> modtr/dir5/sfld\\s+dadj\\s+"
set nodefault_15 "$err_nodefault'modtr/dir5/subdir'"

# symbol set on alias of symbol of an adjacent sub-directory
set modsym_16 "modtr/dir4/dadj"
set module_16 "$module_11"
set modalt_16 $modalt_11
set modulefile_16 "$modulefile_11"
set modulefilere_16 "$modulefilere_11"
set modavail_16 "$modavail_15"
set nodefault_16 $nodefault_15

# symbol set on alias of symbol (alias set before target symbol definition)
# test symbolic version from target modulefile directory
set modsym_17 "modtr/dir2/unstable"
set module_17 "$module_2"
set modalt_17 $modalt_2
set modulefile_17 "$modulefile_2"
set modulefilere_17 "$modulefilere_2"
set modavail_17 "$module_2\\s+next:unstable\\s+$datetime_re"

# symbol set on alias of symbol (alias set after target symbol definition)
# test symbolic version from target modulefile directory
set modsym_18 "modtr/bar"
set module_18 "$module_4"
set modalt_18 $modalt_4
set modulefile_18 "$modulefile_4"
set modulefilere_18 "$modulefilere_4"
set modavail_18 "$module_4\\s+bar:default:exp:foo:reg$datetime_re"

# symbol set on alias of alias of symbol
# test symbolic version from target modulefile directory
set modsym_19 "modtr/exp"
set module_19 "$module_4"
set modalt_19 $modalt_4
set modulefile_19 "$modulefile_4"
set modulefilere_19 "$modulefilere_4"
set modavail_19 "$modavail_18"

# symbol set on alias of sub-directory
# test symbolic version from target modulefile directory
set modsym_20 "modtr/dir5/sfld"
set module_20 "$module_11"
set modalt_20 $modalt_11
set modulefile_20 "$modulefile_11"
set modulefilere_20 "$modulefilere_11"
set modavail_20 [if_availindepth "modtr/dir5/subdir/\\s+dadj:sfld\\s+\n$module_11\\s+madj\\s+$datetime_re" "modtr/dir5/subdir/\\s+dadj:sfld\\s+"]
set nodefault_20 $nodefault_15

# symbol set on alias of modulefile of an adjacent sub-directory
# test symbolic version from target modulefile directory
set modsym_21 "modtr/dir5/subdir/madj"
set module_21 "$module_11"
set modalt_21 $modalt_11
set modulefile_21 "$modulefile_11"
set modulefilere_21 "$modulefilere_11"
set modavail_21 "$module_11\\s+madj\\s+$datetime_re"

# symbol set on alias of symbol of an adjacent sub-directory
# test symbolic version from target modulefile directory
set modsym_22 "modtr/dir5/dadj"
set module_22 "$module_11"
set modalt_22 $modalt_11
set modulefile_22 "$modulefile_11"
set modulefilere_22 "$modulefilere_11"
set modavail_22 "$modavail_20"
set nodefault_22 $nodefault_15


# alias set on distant deep symbol
set modsym_23 "trmod/al1"
set module_23 "$module_2"
# as an alias is set across modulename, alternative names for loaded modules is different than modalt_2
set modalt_23 modtr/dir2/next&trmod/trunstable&modtr/dir2/trunstable&modtr/unstable&modtr/dir2/unstable&al|trmod/al1&al|modtr/al1
set modulefile_23 "$modulefile_2"
set modulefilere_23 "$modulefilere_2"
set modavail_23 "$modsym_23 -> modtr/dir2/next\\s+trunstable\\s+"
set modwarn_23 "$warn_msgs: Symbolic version 'modtr/default' already defined"

# symbol set on alias of distant deep symbol
set modsym_24 "trmod/trunstable"
set module_24 "$module_2"
set modalt_24 $modalt_23
set modulefile_24 "$modulefile_2"
set modulefilere_24 "$modulefilere_2"
set modavail_24 "$modavail_23"
set modwarn_24 "$modwarn_23"

# alias set on distant deep alias
set modsym_25 "trmod/dir3/al2"
set module_25 "$module_4"
# as an alias is set across modulename, alternative names for loaded modules is different than modalt_4
set modalt_25 modtr/foo&trmod/dir3/trbar&modtr/dir3/trbar&modtr/trbar&modtr/dir3/bar&modtr/bar&modtr/dir3/exp&modtr/exp&al|modtr/dir3/al2&al|trmod/dir3/al2&al|modtr/dir3/al3&al|modtr/al4
set modulefile_25 "$modulefile_4"
set modulefilere_25 "$modulefilere_4"
set modavail_25 "$modsym_25 -> modtr/dir3/al2\\s+trbar\\s+"
set modwarn_25 "$modwarn_23"

# symbol set on alias of distant deep alias
set modsym_26 "trmod/dir3/trbar"
set module_26 "$module_4"
set modalt_26 $modalt_25
set modulefile_26 "$modulefile_4"
set modulefilere_26 "$modulefilere_4"
set modavail_26 "$modavail_25"
set modwarn_26 "$modwarn_23"

# alias set on distant deep directory
set modsym_27 "trmod/al5"
set module_27 "$module_9"
set modalt_27 trmod/trfld&modtr/trfld&trmod/default&trmod&modtr/default&modtr&trmod/trreg&modtr/trreg&modtr/fld&modtr/reg&al|trmod/al5&al|modtr/al5
set modulefile_27 "$modulefile_9"
set modulefilere_27 "$modulefilere_9"
set modavail_27 "$modsym_27 -> modtr/dir4\\s+default:trfld:trreg\\s+"
set modwarn_27 "$modwarn_23"
set nodefaultwarn_27 $modwarn_27
set nodefault_27 $nodefault_9

# symbol set on alias of distant deep directory
set modsym_28 "trmod/trfld"
set module_28 "$module_9"
set modalt_28 $modalt_27
set modulefile_28 "$modulefile_9"
set modulefilere_28 "$modulefilere_9"
set modavail_28 "$modavail_27"
set modwarn_28 "$modwarn_23"
set nodefaultwarn_28 $modwarn_28
set nodefault_28 $nodefault_9


# alias set on distant symbol of distant deep alias of distant symbol
set modsym_29 "tr2mod/al1"
set module_29 "$module_2"
set modalt_29 modtr/dir2/next&trmod/trunstable&tr2mod/tr2unstable&trmod/tr2unstable&modtr/dir2/tr2unstable&modtr/dir2/trunstable&modtr/unstable&modtr/dir2/unstable&al|trmod/al1&al|tr2mod/al1&al|modtr/al1
set modulefile_29 "$modulefile_2"
set modulefilere_29 "$modulefilere_2"
set modavail_29 "$modsym_29 -> trmod/trunstable\\s+tr2unstable\\s+"
set modwarn_29 "$modwarn_23"

# symbol set on alias of distant symbol of distant deep alias of distant symbol
set modsym_30 "tr2mod/tr2unstable"
set module_30 "$module_2"
set modalt_30 $modalt_29
set modulefile_30 "$modulefile_2"
set modulefilere_30 "$modulefilere_2"
set modavail_30 "$modavail_29"
set modwarn_30 "$modwarn_23"

# alias set on distant deep alias of distant deep alias
set modsym_31 "tr2mod/dir3/al2"
set module_31 "$module_4"
set modalt_31 [if_implicitdefault modtr/foo&tr2mod/dir3/tr2bar&trmod/dir3/tr2bar&modtr/dir3/tr2bar&trmod/dir3/trbar&modtr/dir3/trbar&modtr/tr2bar&modtr/trbar&modtr/dir3/bar&modtr/bar&modtr/dir3/exp&modtr/exp&tr2mod/tr2fld&trmod/tr2fld&al|modtr/dir3/al2&al|trmod/dir3/al2&al|tr2mod/dir3/al2&al|modtr/dir3/al3&al|modtr/al4&al|tr2mod/al5 modtr/foo&tr2mod/dir3/tr2bar&trmod/dir3/tr2bar&modtr/dir3/tr2bar&trmod/dir3/trbar&modtr/dir3/trbar&modtr/tr2bar&modtr/trbar&modtr/dir3/bar&modtr/bar&modtr/dir3/exp&modtr/exp&al|modtr/dir3/al2&al|trmod/dir3/al2&al|tr2mod/dir3/al2&al|modtr/dir3/al3&al|modtr/al4]
set modulefile_31 "$modulefile_4"
set modulefilere_31 "$modulefilere_4"
set modavail_31 "$modsym_31 -> trmod/dir3/al2\\s+tr2bar\\s+"
set modwarn_31 "$modwarn_23"

# symbol set on alias of distant deep alias of distant deep alias
set modsym_32 "tr2mod/dir3/tr2bar"
set module_32 "$module_4"
set modalt_32 $modalt_31
set modulefile_32 "$modulefile_4"
set modulefilere_32 "$modulefilere_4"
set modavail_32 "$modavail_31"
set modwarn_32 "$modwarn_23"

# alias set on distant deep directory composed of distant alias
set modsym_33 "tr2mod/al5"
set module_33 "$module_4"
set modalt_33 $modalt_31
set modulefile_33 "$modulefile_4"
set modulefilere_33 "$modulefilere_4"
set modavail_33 "$modsym_33 -> trmod/dir3\\s+tr2fld\\s+"
set modwarn_33 "$modwarn_23"
set modforcewarn_33 1
set nodefault_33 "$err_nodefault'trmod/dir3'"

# symbol set on alias of distant deep directory composed of distant alias
set modsym_34 "tr2mod/tr2fld"
set module_34 "$module_4"
set modalt_34 $modalt_31
set modulefile_34 "$modulefile_4"
set modulefilere_34 "$modulefilere_4"
set modavail_34 "$modavail_33"
set modwarn_34 "$modwarn_23"
set modforcewarn_34 1
set nodefault_34 $nodefault_33


# default symbol set on alias set on symbol set on alias of alias of symbol
set modsym_35 "modtr/default"
set module_35 "$module_4"
set modalt_35 $modalt_4
set modulefile_35 "$modulefile_4"
set modulefilere_35 "$modulefilere_4"
set modavail_35 "$modavail_18"

# symbol set on default symbol set on alias set on symbol set on alias of alias of symbol (before default def)
set modsym_36 "modtr/reg"
set module_36 "$module_4"
set modalt_36 $modalt_4
set modulefile_36 "$modulefile_4"
set modulefilere_36 "$modulefilere_4"
set modavail_36 "$modavail_35"

# default symbol set on alias set on distant deep directory
set modsym_37 "trmod/default"
set module_37 "$module_9"
set modalt_37 $modalt_27
set modulefile_37 "$modulefile_9"
set modulefilere_37 "$modulefilere_9"
set modavail_37 "trmod/al5 -> modtr/dir4\\s+default:trfld:trreg\\s+"
set modwarn_37 "$modwarn_23"
set nodefaultwarn_37 $modwarn_37
set nodefault_37 $nodefault_9

# symbol set on default symbol set on alias set on distant deep directory
set modsym_38 "trmod/trreg"
set module_38 "$module_9"
set modalt_38 $modalt_27
set modulefile_38 "$modulefile_9"
set modulefilere_38 "$modulefilere_9"
set modavail_38 "$modavail_37"
set modwarn_38 "$modwarn_23"
set nodefaultwarn_38 $modwarn_38
set nodefault_38 $nodefault_9


set help_pre "$modlin\nModule Specific Help for "
set help_post ":\n\n$modlin"
set test_pre "$modlin\nModule Specific Test for "
set test_post ":\n\nTest result: PASS\n$modlin"
set disp_pre "$modlin\n"
set disp_wi "module-whatis\\s+"
set disp_post "\nsetenv\\s+testsuite\\s+yes\n$modlin"
set avail_pre "- Package/Alias $modlin.- Versions $modlin.- Last mod. $modlin\n$modpathre:"
set whatis_pre "$modlin $modpathre $modlin\n\\s*"


#
#  The tests
#

for {set i 1} {$i <= 38} {incr i} {
    set modsym [set "modsym_${i}"]
    set module [set "module_${i}"]
    if {[info exists "modalt_${i}"]} {
        set modalt $module&[set "modalt_${i}"]
    } else {
        set modalt ""
    }
    set modulefile [set "modulefile_${i}"]
    set modulefilere [set "modulefilere_${i}"]
    set modavail [set "modavail_${i}"]
    if {[info exists "modwarn_${i}"]} {
        set modwarn [set "modwarn_${i}"]
        set modwarnnl "$modwarn\n"
    } else {
        set modwarn ""
        set modwarnnl ""
    }
    if {[info exists "modforcewarn_${i}"]} {
        set modforcewarn 1
    } else {
        set modforcewarn 0
    }
    if {[info exists "nodefaultwarn_${i}"]} {
        set nodefaultwarn [set "nodefaultwarn_${i}"]\n
    } else {
        set nodefaultwarn {}
    }
    if {[info exists "nodefault_${i}"]} {
        set nodefault [set "nodefault_${i}"]
    } else {
        set nodefault {}
    }
    if {[info exists "extrawhatis_${i}"]} {
        set extrawhatis [set "extrawhatis_${i}"]
    } else {
        set extrawhatis {}
    }
    if {[info exists "extrapaths_${i}"]} {
        set extrapaths [set "extrapaths_${i}"]
    } else {
        set extrapaths {}
    }

    # setup clean environment
    unsetenv_loaded_module
    unsetenv_var __MODULES_LMALTNAME

    set ans [list]
    if {$modalt ne ""} {
        lappend ans [list set __MODULES_LMALTNAME $modalt]
    }
    lappend ans [list set _LMFILES_ $modulefile]
    lappend ans [list set LOADEDMODULES $module]
    lappend ans [list set testsuite "yes"]

    set displayerr "$modwarnnl$disp_pre$modulefilere:\n\n$disp_wi$module$disp_post"
    set helperr "$modwarnnl$help_pre$modulefilere$help_post"
    set testerr "$modwarnnl$test_pre$modulefilere$test_post"
    set whatiserr "$whatis_pre$module: $module$extrawhatis"

    if {$nodefault eq {}} {
        testouterr_cmd "sh" "load $modsym" $ans "$modwarn"
        testouterr_cmd_re "sh" "display $modsym" "OK" $displayerr
        testouterr_cmd_re "sh" "help $modsym" "OK" $helperr
        testouterr_cmd_re "sh" "test $modsym" "OK" $testerr
    } else {
        testouterr_cmd "sh" "load $modsym" [if_implicitdefault $ans ERR] [if_implicitdefault $modwarn $nodefaultwarn$nodefault]
        testouterr_cmd_re "sh" "display $modsym" [if_implicitdefault OK ERR] [if_implicitdefault $displayerr $nodefaultwarn$nodefault]
        testouterr_cmd_re "sh" "help $modsym" [if_implicitdefault OK ERR] [if_implicitdefault $helperr $nodefaultwarn$nodefault]
        testouterr_cmd_re "sh" "test $modsym" [if_implicitdefault OK ERR] [if_implicitdefault $testerr $nodefaultwarn$nodefault]
    }

    testouterr_cmd_re "sh" "avail -l $modsym" "OK" "$avail_pre\n$modavail"
    testouterr_cmd_re "sh" "whatis $modsym" "OK" $whatiserr

    set ans [list]
    lappend ans [list text $modulefile]
    if {$extrapaths ne {}} {
        lappend ans [list text $extrapaths]
    }
    testouterr_cmd "sh" "paths $modsym" $ans "$modwarn"

    # setup environment for unload action
    setenv_loaded_module $module $modulefile
    if {$modalt ne ""} {
        setenv_var __MODULES_LMALTNAME $modalt
    }

    set ans [list]
    if {$modalt ne ""} {
        lappend ans [list unset __MODULES_LMALTNAME]
        # resolution warning is not triggered if alias/symbol are found through alternative names
        # except if we work on some distant deep alias case
        if {!$modforcewarn} {
            set modwarn ""
        }
    }
    lappend ans [list unset _LMFILES_]
    lappend ans [list unset LOADEDMODULES]
    lappend ans [list unset testsuite]

    #FIXME: skip unload test for the time being, until deep alias resolution
    # set through different directory trees will be altname-ready
    if {!$modforcewarn} {
        testouterr_cmd "sh" "unload $modsym" $ans "$modwarn"
    }
}


#
#  Cleanup
#

reset_test_env