Results for oil-expr.test.sh

statusoshosh_ALT
pass 5656
FAIL 44
total6060
caseoshosh_ALTdescription
0pass pass command sub $(echo hi)
1pass pass shell array %(a 'b c')
2pass pass empty array and simple_word_eval (regression test)
3pass pass Empty array and assignment builtin (regression)
4pass pass Shell arrays support tilde detection, static globbing, brace detection
5pass pass augmented assignment doesn't work on shell arrays
6pass pass Set $HOME using 'var' (i.e. Oil string var in word evaluator)
7pass pass Use shell var in Oil expression
8pass pass Length in two different contexts
9pass pass $len(x) inside strings
10pass pass Func with multiple args in multiple contexts
11pass pass Trailing Comma in Param list
12pass pass @range()
13FAIL FAIL Wrong sigil $range() shows representation of iterator?
detailsdetails
14FAIL FAIL Wrong sigil @max(3, 4)
detailsdetails
15pass pass nested expr contexts
16pass pass Test value.Obj inside shell arithmetic
17pass pass Parse { var x = 42 }
18pass pass double quoted
19pass pass double quoted respects strict_array
20pass pass simple var sub $name $0 $1 $? etc.
21pass pass braced var sub ${x:-default}
22pass pass braced var sub respects strict_array
23pass pass null / true / false
24pass pass Integer literals
25pass pass Integer literals with underscores
26pass pass Backslash char literal (is an integer)
27pass pass \u{3bc} is char literal
28pass pass Pound char literal (is an integer)
29pass pass The literal #''' isn't accepted (use \' instead)
30pass pass Float Literals
31FAIL FAIL Float Literals with _ (requires re2c refinement)
detailsdetails
32pass pass Tuples
33pass pass List comprehension (deferred)
34pass pass in, not in
35pass pass Chained Comparisons
36pass pass dict with 'bare word' keys
37pass pass dict with expression keys
38pass pass dict literal with implicit value
39pass pass Dict literal with string keys
40pass pass Bitwise logical
41pass pass Shift operators
42pass pass Exponentiation with **
43pass pass Two Kinds of Division
44pass pass mod operator
45pass pass Logical operators
46pass pass x if b else y
47pass pass multiline strings, list, tuples, etc.
48pass pass multiline dict
49pass pass multiline array and command sub (only here docs disallowed)
50pass pass obj.attr and obj.method()
51pass pass obj.method does NOT give you a bound method
52pass pass d->key
53pass pass a ++ b for string/list concatenation
54pass pass s ~~ glob and s !~~ glob
55pass pass Exact equality with === and !==
56pass pass Approximate equality of Str x {Str, Int, Bool} with ~==
57pass pass Wrong Types with ~==
58FAIL FAIL Equality of ~== with Float (deferred)
detailsdetails
59pass pass Type Errors
112 passed, 0 OK, 0 not implemented, 0 BUG, 4 failed, 0 timeouts, 0 cases skipped
4 failed under osh

Details on runs that didn't PASS

osh13 Wrong sigil $range() shows representation of iterator?

[osh stdout] Expected 'TODO\n', got ''
[osh status] Expected 0, got 1

stdout:
stderr: 
  echo $range(10, 15, 2)
  ^~~~
[ stdin ]:2: fatal: Expected function to return a bool, int, float, or string.  Got <type 'xrange'>
osh_ALT13 Wrong sigil $range() shows representation of iterator?

[osh_ALT stdout] Expected 'TODO\n', got ''
[osh_ALT status] Expected 0, got 1

stdout:
stderr: 
  echo $range(10, 15, 2)
  ^~~~
[ stdin ]:2: fatal: Expected function to return a bool, int, float, or string.  Got <type 'xrange'>
osh14 Wrong sigil @max(3, 4)

[osh stdout] Expected 'TODO\n', got ''
[osh status] Expected 0, got 1
[osh stderr] Found 'Traceback (most recent'

stdout:
stderr: 
Traceback (most recent call last):
  File "/home/andy/git/oilshell/oil/bin/oil.py", line 360, in <module>
    sys.exit(main(sys.argv))
  File "/home/andy/git/oilshell/oil/bin/oil.py", line 303, in main
    return AppBundleMain(argv)
  File "/home/andy/git/oilshell/oil/bin/oil.py", line 262, in AppBundleMain
    loader, line_input)
  File "/home/andy/git/oilshell/oil/core/shell.py", line 681, in Main
    cmd_flags=cmd_eval.IsMainProgram)
  File "/home/andy/git/oilshell/oil/core/main_loop.py", line 332, in Batch
    is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags=cmd_flags)
  File "/home/andy/git/oilshell/oil/osh/cmd_eval.py", line 1558, in ExecuteAndCatch
    status = self._Execute(node)
  File "/home/andy/git/oilshell/oil/osh/cmd_eval.py", line 1396, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/andy/git/oilshell/oil/osh/cmd_eval.py", line 659, in _Dispatch
    cmd_val = self.word_ev.EvalWordSequence2(words, allow_assign=True)
  File "/home/andy/git/oilshell/oil/osh/word_eval.py", line 2158, in EvalWordSequence2
    return self.SimpleEvalWordSequence2(words, allow_assign)
  File "/home/andy/git/oilshell/oil/osh/word_eval.py", line 2118, in SimpleEvalWordSequence2
    self._EvalWordToParts(w, part_vals, 0)  # not quoted
  File "/home/andy/git/oilshell/oil/osh/word_eval.py", line 1705, in _EvalWordToParts
    self._EvalWordPart(p, word_part_vals, eval_flags)
  File "/home/andy/git/oilshell/oil/osh/word_eval.py", line 1657, in _EvalWordPart
    a = [_Stringify(item) for item in func(*pos_args, **named_args)]
TypeError: 'int' object is not iterable
osh_ALT14 Wrong sigil @max(3, 4)

[osh_ALT stdout] Expected 'TODO\n', got ''
[osh_ALT status] Expected 0, got 1
[osh_ALT stderr] Found 'Traceback (most recent'

stdout:
stderr: 
Traceback (most recent call last):
  File "/home/andy/git/oilshell/oil/bin/oil.py", line 330, in _cpython_main_hook
    sys.exit(main(sys.argv))
  File "/home/andy/git/oilshell/oil/bin/oil.py", line 303, in main
    return AppBundleMain(argv)
  File "/home/andy/git/oilshell/oil/bin/oil.py", line 294, in AppBundleMain
    return readlink.main(main_argv)
  File "/home/andy/git/oilshell/oil/core/shell.py", line 681, in Main
    cmd_flags=cmd_eval.IsMainProgram)
  File "/home/andy/git/oilshell/oil/core/main_loop.py", line 338, in Batch
    return status
  File "/home/andy/git/oilshell/oil/osh/cmd_eval.py", line 1558, in ExecuteAndCatch
    status = self._Execute(node)
  File "/home/andy/git/oilshell/oil/osh/cmd_eval.py", line 1396, in _Execute
    status = self._Dispatch(node, cmd_st)
  File "/home/andy/git/oilshell/oil/osh/cmd_eval.py", line 716, in _Dispatch
    status = self._Execute(node.child)
  File "/home/andy/git/oilshell/oil/osh/word_eval.py", line 2158, in EvalWordSequence2
    return self.SimpleEvalWordSequence2(words, allow_assign)
  File "/home/andy/git/oilshell/oil/osh/word_eval.py", line 2118, in SimpleEvalWordSequence2
    self._EvalWordToParts(w, part_vals, 0)  # not quoted
  File "/home/andy/git/oilshell/oil/osh/word_eval.py", line 1742, in _EvalWordToParts
    part_vals.append(part_value.String('', quoted, not quoted))
  File "/home/andy/git/oilshell/oil/osh/word_eval.py", line 1670, in _EvalWordPart
    part_vals.append(part_val)
TypeError: 'int' object is not iterable
FATAL: couldn't import from app bundle '/home/andy/git/oilshell/oil/_tmp/oil-tar-test/oil-0.10.1/_bin/osh' (1)
Stripping the oil.ovm binary may cause this error.
See https://github.com/oilshell/oil/issues/47
osh31 Float Literals with _ (requires re2c refinement)

[osh stdout] Expected 'less\ngreat\n', got ''
[osh status] Expected 0, got 2

stdout:
stderr: 
  var x = 1.2 + 2_3.0e-1  # 3.5
                    ^~~~
[ stdin ]:2: Syntax error in expression (near Id.Expr_Float)
osh_ALT31 Float Literals with _ (requires re2c refinement)

[osh_ALT stdout] Expected 'less\ngreat\n', got ''
[osh_ALT status] Expected 0, got 2

stdout:
stderr: 
  var x = 1.2 + 2_3.0e-1  # 3.5
                    ^~~~
[ stdin ]:2: Syntax error in expression (near Id.Expr_Float)
osh58 Equality of ~== with Float (deferred)

[osh status] Expected 0, got 1

stdout:
stderr: 
  if (42 ~== 42.0) {
         ^~~
[ stdin ]:3: fatal: ~== expects a string on the left
osh_ALT58 Equality of ~== with Float (deferred)

[osh_ALT status] Expected 0, got 1

stdout:
stderr: 
  if (42 ~== 42.0) {
         ^~~
[ stdin ]:3: fatal: ~== expects a string on the left