X-Git-Url: https://git.exim.org/users/heiko/exim.git/blobdiff_plain/9c57cbc06f4506e05f63190afddfc9b3648813cb..30d678d5cee88e21aaac4e1de3130d91bdf51abc:/test/scripts/0000-Basic/0002 diff --git a/test/scripts/0000-Basic/0002 b/test/scripts/0000-Basic/0002 index f32b605b0..c2dcc40d9 100644 --- a/test/scripts/0000-Basic/0002 +++ b/test/scripts/0000-Basic/0002 @@ -4,6 +4,7 @@ # be present in the basic Exim binary which we require in order to run these # tests at all. Specialized expansion tests also exist for optional features # in other test scripts. +munge dnssec exim -be @@ -14,11 +15,15 @@ exim -be # Some fixed variables exim_path: $exim_path +exim_version: $exim_version +config_dir: $config_dir +config_file: $config_file primary_hostname: $primary_hostname primary_hostname: ${primary_hostname} qualify_domain: $qualify_domain bounce_return_size_limit: ${bounce_return_size_limit} spool_directory: $spool_directory +queue_name: $queue_name unknown: ${unknown} h_subject: $h_subject:(should be empty) h_subject:$h_subject (should be empty) @@ -40,13 +45,96 @@ x\ +$11111111111111111111111111111111111 +${11111111111111111111111111111111111} +# List operations + +filter: "${filter{a:b:c}{eq{1}{1}}}" +filter: ${filter{a:b:c}{!eq{$item}{b}}} +filter: ${filter{<' a'b'c}{!eq{$item}{b}}} +filter: ${filter{<' ''a'b' ''c}{!eq{$item}{b}}} +filter: "${filter{}{!eq{$item}{b}}}" + +map: "${map{}{$item}}" +map: ${map{a:b:c}{$item}} +map: ${map{a:b:c}{:$item:}} +map: ${if eq{1}{0}{${map{a:b:c}{:$item:}}}{fail string}} +map: ${map{:b:c}{[$item]}} + +reduce: "${reduce{}{+}{$value$item}}" +reduce: ${reduce{a:b:c}{+}{$value$item}} +reduce: ${reduce {<, 1,2,3}{0}{${eval:$value+$item}}} +reduce: ${reduce {3:0:9:4:6}{0}{${if >{$item}{$value}{$item}{$value}}}} + +listnamed: ${listnamed:dlist} +listnamed: ${listnamed:+dlist} +listnamed: ${listnamed:hlist} +listnamed: ${listnamed:elist} +listnamed: ${listnamed:flist} +listnamed: ${listnamed:nolist} +listnamed: ${listnamed_d:dlist} +listnamed: ${listnamed_d:hlist} +listnamed: ${listnamed_z:dlist} + +listcount: ${listcount:a:b:c} +listcount: ${listcount:} +listcount: ${listcount:<;a;b;c} +listcount: ${listcount:${listnamed:dlist}} + +listextract: ${listextract{ 2}{a:b:c:d}} +listextract: ${listextract{-2}{<,a,b,c,d}{X${value}X}} +listextract: ${listextract{ 5}{a:b:c:d}} +listextract: ${listextract{-5}{a:b:c:d}} +listextract: ${listextract{ 5}{a:b:c:d}{}{fail}} +listextract: ${listextract{ 5}{a:b:c:d}{}fail} + +sort: ${sort{3:2:1:4}{<}{$item}} +sort: ${sort {<, 3,2,1,4}{>}{$item}} +sort: ${sort{c:B:a:aa}{lti}{$item}} +sort: ${sort{666 r99.ex.com:10 smtp.ex.com:100 r2.ex.com}{<}{${sg {$item}{([0-9]*).*\$}{\$1}}}} +sort: ${sort{666,r99.ex.com:10,smtp.ex.com:100,r2.ex.com}{<}{${listextract{1}{<,$item}}}} +sort: "${sort{}{<}{$item}}" + +# Tests with iscntrl() and illegal separators + +map: ${map{<\n a\n\nb\nc}{'$item'}} + +reduce: ${reduce { (that's me)} domain: ${domain:local-part@dom.ain} domain: ${domain:Exim Person (that's me)} -escape: ${escape:B7·F2ò} + +addresses: ${addresses:>' 'abc@xyz, 'pqr@xyz} +addresses: ${addresses:Exim Person (that's me)} +addresses: ${addresses:>+ Exim Person (that's me),\ + xyz@abc} +addresses: ${addresses:Exim Person (that's me), \ + xyz@abc, nullgroupname:;, group: p@q, r@s; } +addresses: ${addresses:local-part@dom.ain } + +escape: ${escape:B7·F2ò} +excape8bit: ${escape8bit:undisturbed text\ttab\nnewline\ttab\\backslash \176tilde\177DEL\200\x81.} + eval: ${eval:1+1} eval: ${eval:1+2*3} eval: ${eval:(1+2)*3} @@ -69,17 +157,17 @@ eval10: ${eval10:077} eval10: ${eval10:08} eval10: ${eval10:0x1234} eval: ${eval:2+42%5} -eval: ${eval:0xc&5} -eval: ${eval:0xc & 5 } -eval: ${eval:0x0c|5} -eval: ${eval:0xc^5} -eval: ${eval:0xc>>1} -eval: ${eval:0xc >> 2} -eval: ${eval:0xc >> 4 } -eval: ${eval:0xc<<1} -eval: ${eval:~255&0x1234} -eval: ${eval:~ 255&0x1234} -eval: ${eval: -(~255&0x1234)} +eval: ${eval:0xc&5} +eval: ${eval:0xc & 5 } +eval: ${eval:0x0c|5} +eval: ${eval:0xc^5} +eval: ${eval:0xc>>1} +eval: ${eval:0xc >> 2} +eval: ${eval:0xc >> 4 } +eval: ${eval:0xc<<1} +eval: ${eval:~255&0x1234} +eval: ${eval:~ 255&0x1234} +eval: ${eval: -(~255&0x1234)} expand: \$primary_hostname ${expand:\$primary_hostname} hash: ${hash_3:monty} ${hash_5:monty} ${hash_4_62:monty python} @@ -93,6 +181,20 @@ hex2b64:${hex2b64:1a2b3c4d5e6g} hex2b64:${hex2b64:${md5:the quick brown fox}} hex2b64:${hex2b64:${sha1:the quick brown fox}} +base32: 0 <${base32:0}> +base32: 1 <${base32:1}> +base32: 31 <${base32:31}> +base32: 32 <${base32:32}> +base32: 42 <${base32:42}> +base32 error: 0x1 ${base32:0x1} + +base32d: 0 ${base32d:${base32:0}} +base32d: 1 ${base32d:${base32:1}} +base32d: 31 ${base32d:${base32:31}} +base32d: 32 ${base32d:${base32:32}} +base32d: 42 ${base32d:${base32:42}} +base32d error: ABC ${base32d:ABC} + The base62 operator is actually a base36 operator in the Darwin and Cygwin environments. Write cunning tests that produce the same output in both cases, while doing a reasonable check. @@ -100,15 +202,15 @@ while doing a reasonable check. base62: ${if or {\ {eq {${base62:12345}}{0003D7}}\ {eq {${base62:12345}}{0009IX}}\ - }{OK}{NOT OK}} + }{OK}{NOT OK}} base62d: ${if or {\ {eq {${base62d:0003D7}}{12345}}\ {eq {${base62d:0009IX}}{12345}}\ - }{OK}{NOT OK}} + }{OK}{NOT OK}} base62d: ${if or {\ {eq {${base62d:3D7}}{12345}}\ {eq {${base62d:9IX}}{12345}}\ - }{OK}{NOT OK}} + }{OK}{NOT OK}} base62 error: ${base62:12345x} base62d error:${base62d:0003D7.} @@ -123,6 +225,17 @@ mask: ${mask:192.168.10.206/33} mask: ${mask:192.168.10.206/0} mask: ${mask:192.168.10.206} mask: ${mask:a.b.c.d} +ipv6denorm: ${ipv6denorm:::1} +ipv6denorm: ${ipv6denorm:fe00::1} +ipv6denorm: ${ipv6denorm:192.168.0.1} +ipv6denorm: ${ipv6denorm:fe80::192.168.0.1} +ipv6norm: ${ipv6norm:0:0:0::1} +ipv6norm: ${ipv6norm:2a00::0} +ipv6norm: ${ipv6norm:2a00::1} +ipv6norm: ${ipv6norm:2a00:eadf:0000:0000:0000:0000:0001:0000} +ipv6norm: ${ipv6norm:2a00:eadf:0000:0001:0000:0000:0000:0000} +ipv6norm: ${ipv6norm:2a00:0:0:0::} +ipv6norm: ${ipv6norm:2a00:2:3:4:5:6:7:8} nhash: ${nhash_24:monty} ${nhash_8_63:monty python} lc/uc: ${lc:The Quick} ${uc: Brown Fox} length: ${length_10:The quick brown fox} ${l_10:abc} @@ -147,12 +260,25 @@ quote_local_part: ${quote_local_part:x:y} quote_local_part: ${quote_local_part:ab\cd"ef} quote_local_part: ${quote_local_part:} rxquote:${rxquote:aZ09_,-Q} ${rxquote:ab*cd} ${rxquote:ab\cd"ef} +hexquote: ${hexquote:\ + \001\002\003\004\005\006\007 \010\011\012\013\014\015\016\017 \ +\020\021\022\023\024\025\026\027 \030\031\032\033\034\035\036\037 \ +\040\041\042\043\044\045\046\047 \050\051\052\053\054\055\056\057 \ +\060\061\062\063\064\065\066\067 \070\071\072\073\074\075\076\077 \ +\100\101\102\103\104\105\106\107 \110\111\112\113\114\115\116\117 \ +\120\121\122\123\124\125\126\127 \130\131\132\133\134\135\136\137 \ +\140\141\142\143\144\145\146\147 \150\151\152\153\154\155\156\157 \ +\160\161\162\163\164\165\166\167 \170\171\172\173\174\175\176\177} substr: ${substr_3_2:rhubarb} ${s_-5_2:1234567} ${s_-5_2:12} ${s_-3_2:12} substr: ${s_3:rhubarb} ${s_-2:rhubarb} substr: ${s_1:} substr: ${substr_10:abc} str2b64:${str2b64:abcd} str2b64:${str2b64:The quick brown \n fox} +base64: ${base64:abcd} +base64: ${base64:The quick brown \n fox} +base64d:${base64d:YWJjZA==} +base64d:${base64d:VGhlIHF1aWNrIGJyb3duIAogZm94} strlen: ${strlen:} strlen: ${strlen:a} strlen: ${strlen:abcdefgh} @@ -201,10 +327,21 @@ hash: ${if eq {1}{2}{${hash_3:invalid}}{NO}} md5: ${if eq {1}{2}{${md5:invalid}}{NO}} mask: ${if eq {1}{2}{${mask:invalid}}{NO}} +# Number suffixes in conditions +1k: ${if >{1}{1k}{n}{y}} +1K: ${if >{1}{1K}{n}{y}} +1M: ${if >{1}{1M}{n}{y}} +1G: ${if >{1}{1G}{n}{y}} + # Numeric overflow +# >32b should work, >64b not -4096M ${if >{1}{4096M}{y}{n}} -4096000000 ${if >{1}{4096000000}{y}{n}} +1 > 2047M ${if >{1}{2047M}{y}{n}} +1 > 2048M ${if >{1}{2048M}{y}{n}} +1 > 4096000000 ${if >{1}{4096000000}{y}{n}} +1 > 4096M ${if >{1}{4096M}{y}{n}} +1 > 4611686018427387904 ${if >{1}{4611686018427387904} {y}{n}} +1 > 46116860184273879040 ${if >{1}{46116860184273879040}{y}{n}} # Conditions @@ -236,6 +373,7 @@ mask: ${if eq {1}{2}{${mask:invalid}}{NO}} 5>3m: ${if >{5 } {3m }{y}{n}} 5>3z: ${if >{5 } {3z }{y}{n}} 5>a: ${if >{ 5 } {a}{y}{n}} +5>bad: ${if >{5 } {${lookup{trick}lsearch{DIR/aux-fixed/0002.lsearch}}} {y}{n}} >0: ${if > {}{0}{y}{n}} =: ${if = {}{}{y}{n}} @@ -304,19 +442,19 @@ match_domain: ${if match_domain{xyz}{+dlist}{yes}{no}} ${if match{x@zz.aa.bb}{^(.*)} \ { \ - >$1< \ + >$1< \ ${if match_domain{${domain:$1}}{+dlist}{[$1]}} \ >$1< \ } \ - { CAN'T HAPPEN}} + { CAN'T HAPPEN}} ${if match{x@xxxabc}{^(.*)} \ { \ - >$1< \ + >$1< \ ${if match_domain{${domain:$1}}{^\Nxxx(.*)\N}{[$1]}} \ >$1< \ } \ - { CAN'T HAPPEN}} + { CAN'T HAPPEN}} match_address: ${if match_address{x@y.z}{p@q:*@y.z}{yes}{no}} match_address: ${if match_address{x@y.z}{p@q:x@*.z}{yes}{no}} @@ -338,6 +476,7 @@ match_ip: 11 ${if match_ip{somename}{+hlist}} match_ip: 12 ${if match_ip{1.2.3.4}{lsearch;DIR/aux-fixed/0002.matchip}} match_ip: 13 ${if match_ip{1.2.3.4}{net-lsearch;DIR/aux-fixed/0002.matchip}} match_ip: 14 ${if match_ip{5.6.7.8}{net24-lsearch;DIR/aux-fixed/0002.matchip}} +match_ip: 15 ${if match_ip{abcd::dcba}{net-iplsearch;DIR/aux-fixed/0002.matchip}} queue_running: ${if queue_running{y}{n}} first_delivery: ${if first_delivery{y}{n}} @@ -345,6 +484,12 @@ first_delivery: ${if first_delivery{y}{n}} queue_running after or: ${if or{{eq {0}{0}}{queue_running}}{y}{n}} first_delivery after or: ${if or{{eq {0}{0}}{first_delivery}}{y}{n}} +# acl expansion condition +acl if: ${if acl {{a_ret}} {Y:$value}{N:$value}} +acl if: ${if acl {{a_ret}{argY}} {Y:$value}{N:$value}} +acl if: ${if acl {{a_deny}{argN}{arg2}} {Y:$value}{N:$value}} +acl if: ${if acl {{a_defer}{argN}{arg2}} {Y:$value}{N:$value}} + # Default values for both if strings \${if eq{1}{1}} >${if eq{1}{1}}< @@ -487,6 +632,10 @@ ${extract{}{X=3}} ${extract{ }{X=3}} ${extract{ 2 }{ }{a b c}} +${map{a,1:b,2:c,3}{${extract{1}{,}{$item}{$value}{}}}} +${map{a,1:b,2:c,3}{${extract{1}{,}{$item}{$value}{failcase}{bogus_argument}}}} +${map{a,1:b,2:c,3}{${extract{1}{,}{$item}{$value}fail}}} + # Translation abcdea aaa xyz ${tr{abcdea}{aaa}{xyz}} @@ -494,6 +643,50 @@ abcdea a z ${tr{abcdea}{a}{z}} abcdea a ${tr{abcdea}{a}{}} abcdea abc z ${tr{abcdea}{abc}{z}} +# Boolean +"TrUe" ${if bool{TrUe}{true}{false}} EXPECT: true +"FALSE" ${if bool{FALSE}{true}{false}} EXPECT: false +" yes" ${if bool{ yes}{true}{false}} EXPECT: true +" no" ${if bool{ no}{true}{false}} EXPECT: false +"yes " ${if bool{yes }{true}{false}} EXPECT: true +"-1" ${if bool{-1}{true}{false}} EXPECT: true +"0" ${if bool{0}{true}{false}} EXPECT: false +"1" ${if bool{1}{true}{false}} EXPECT: true +" 0 " ${if bool{ 0 }{true}{false}} EXPECT: false +" 1 " ${if bool{ 1 }{true}{false}} EXPECT: true +"1111111111111111111" ${if bool{1111111111111111111}{true}{false}} EXPECT: true +"9" ${if bool{9}{true}{false}} EXPECT: true +" " ${if bool{ }{true}{false}} EXPECT: false +"text" ${if bool{text}{true}{false}} EXPECT: error +" text" ${if bool{ text}{true}{false}} EXPECT: error +"-text" ${if bool{-text}{true}{false}} EXPECT: error +"text " ${if bool{text }{true}{false}} EXPECT: error +" text " ${if bool{ text }{true}{false}} EXPECT: error +"00" ${if bool{00}{true}{false}} EXPECT: false +"!true" ${if !bool{true}{true}{false}} EXPECT: false +"!false" ${if !bool{false}{true}{false}} EXPECT: true + +"TrUe" ${if bool_lax{TrUe}{true}{false}} EXPECT: true +"FALSE" ${if bool_lax{FALSE}{true}{false}} EXPECT: false +" yes" ${if bool_lax{ yes}{true}{false}} EXPECT: true +" no" ${if bool_lax{ no}{true}{false}} EXPECT: false +"yes " ${if bool_lax{yes }{true}{false}} EXPECT: true +"-1" ${if bool_lax{-1}{true}{false}} EXPECT: true +"0" ${if bool_lax{0}{true}{false}} EXPECT: false +"1" ${if bool_lax{1}{true}{false}} EXPECT: true +" 0 " ${if bool_lax{ 0 }{true}{false}} EXPECT: false +" 1 " ${if bool_lax{ 1 }{true}{false}} EXPECT: true +"1111111111111111111" ${if bool_lax{1111111111111111111}{true}{false}} EXPECT: true +"9" ${if bool_lax{9}{true}{false}} EXPECT: true +" " ${if bool_lax{ }{true}{false}} EXPECT: false +"text" ${if bool_lax{text}{true}{false}} EXPECT: true +" text" ${if bool_lax{ text}{true}{false}} EXPECT: true +"text " ${if bool_lax{text }{true}{false}} EXPECT: true +" text " ${if bool_lax{ text }{true}{false}} EXPECT: true +"00" ${if bool_lax{00}{true}{false}} EXPECT: true +"!true" ${if !bool_lax{true}{true}{false}} EXPECT: false +"!false" ${if !bool_lax{false}{true}{false}} EXPECT: true + # RFC 2047 abcd ${rfc2047:abcd} @@ -569,7 +762,7 @@ ${prvs{userx@test.ex}{secret}{rhubarb}} ${prvs{userx@test.ex}{secret}{}} # Correct checks; can't put explicit addresses in the tests, because they -# will change over time. +# will change over time. ${prvscheck{${prvs{userx@test.ex}{secret}}}{secret}} result=$prvscheck_result @@ -613,10 +806,68 @@ ${if or {{eq {}{}}{yes}{no}} ${substr_1_:12345} ${substr__3:12345} +# Iterations: forany and forall + +${if forany{a:b:c}{eq{$item}{a}}{yes}{no}} +${if forany{a:b:c}{eq{$item}{b}}{yes}{no}} +${if forany{a:b:c}{eq{$item}{c}}{yes}{no}} +${if forany {a:b:c} {eq {$item} {z}} {yes} {no}} +${if !forany{a:b:c}{eq{$item}{z}}{yes}{no}} +${if !forany{a:b:c}{eq{$item}{a}}{yes}{no}} +${if forany{}{eq{$item}{a}}{yes}{no}} +${if !forany{}{eq{$item}{a}}{yes}{no}} +${if forany{<, $primary_hostname,foo,bar}{eq{$item}{$primary_hostname}}{yes}{no}} + +${if forany{}{yes}{no}} +${if forany{a:b:c}{gt{$item}{a}{yes}{no}} + +${if forall{a:b:c}{match{$item}{^[a-c]\$}}{yes}{no}} +${if forall{q:b:c}{match{$item}{^[a-c]\$}}{yes}{no}} +${if forall{a:b:z}{match{$item}{^[a-c]\$}}{yes}{no}} +${if forall{}{match{$item}{^[a-c]\$}}{yes}{no}} + +${if !forall{a:b:c}{match{$item}{^[a-c]\$}}{yes}{no}} +${if !forall{q:b:c}{match{$item}{^[a-c]\$}}{yes}{no}} +${if !forall{a:b:z}{match{$item}{^[a-c]\$}}{yes}{no}} +${if !forall{}{match{$item}{^[a-c]\$}}{yes}{no}} + +# Expect yes +${if forany{a:b:c}\ + {\ + eq\ + {$item: ${if forall{x:y:z}{match{$item}{^[x-z]\$}}{true}{false}}}\ + {$item: true}\ + }\ +{outer=yes}{outer=no}} item='$item' (unset) + +# Expect no +${if forany{a:b:c}\ + {\ + eq\ + {$item: ${if !forall{x:y:z}{match{$item}{^[x-z]\$}}{true}{false}}}\ + {$item: true}\ + }\ +{outer=yes}{outer=no}} + +# Error inside nest - check message is helpful +${if forany{a:b:c}\ + {\ + eq\ + {$item: ${if forall{x:y:z}{match{$item}{^[x-z]\$}{true}{false}}}\ + {$item: true}\ + }\ +{outer=yes}{outer=no}} + + # Miscellaneous (for bug fixes, etc) ${if ={1}{1} {true}{${if ={1}{1} {true}{${if ={1}{1}{true}fail}}}}} +# Environment access + +${env {USER}} +${env {NO_SUCH_VARIABLE} {oops, success} {correct}} + **** # Test "escape" with print_topbitchars exim -be -DPTBC=print_topbitchars @@ -632,6 +883,7 @@ match_address: ${if match_address{a.b.c}{a.b.c}{yes}{no}} **** # Sender host name and address etc, all unset exim -be +-be Sender host name and address etc, all unset -oMa sender_host_address = $sender_host_address sender_host_port = $sender_host_port -oMaa sender_host_authenticated = $sender_host_authenticated @@ -645,6 +897,7 @@ exim -be **** # Sender host name and address etc, all set except host name. exim -d-all+expand -be -oMa V4NET.0.0.1.1234 -oMaa AAA -oMai philip -oMas xx@yy.zz -oMi 1.1.1.1.99 -oMr special -oMt me +-be Sender host name and address etc, all set except host name. -oMa sender_host_address = $sender_host_address sender_host_port = $sender_host_port -oMaa sender_host_authenticated = $sender_host_authenticated @@ -657,17 +910,20 @@ exim -d-all+expand -be -oMa V4NET.0.0.1.1234 -oMaa AAA -oMai philip -oMas xx@yy. **** # Sender host name explicitly set exim -be -oMa V4NET.0.0.1.1234 -oMs my.host.name +-be Sender host name explicitly set -oMa sender_host_address = $sender_host_address sender_host_port = $sender_host_port -oMs sender_host_name = $sender_host_name **** # Sender host name lookup fails (V4NET.11.12.13 is not reverse registered) exim -be -oMa V4NET.11.12.13 +be Sender host name lookup fails (V4NET.11.12.13 is not reverse registered) -oMs sender_host_name = $sender_host_name host_lookup_failed = $host_lookup_failed **** # Sender host name and protocol set by Sendmail-compatible option exim -be -pspecial:host.name +-be Sender host name and protocol set by Sendmail-compatible option -p received_protocol = $received_protocol -p sender_host_name = $sender_host_name **** @@ -676,6 +932,7 @@ exim -be -pspecial:host.name # we are skipping. The debug output for this test will show when # the lookup occurs. exim -d-all+host_lookup+expand -be -oMa V4NET.0.0.1.1234 -oMaa AAA -oMai philip -oMas xx@yy.zz -oMi 1.1.1.1.99 -oMr special -oMt me +-be Sender host name and address etc, all set except host name -oMa sender_host_address = $sender_host_address sender_host_port = $sender_host_port -oMaa sender_host_authenticated = $sender_host_authenticated @@ -746,3 +1003,8 @@ exim -d -be match_ip: 15 ${if match_ip{1.2.3.4}{1.2.3}} match_ip: 16 ${if match_ip{1.2.3.4}{1.2.3.4/abc}} **** +# Operation of inlist and negated inlist +exim -be +${if inlist{aa}{aa} {in list}{not in list}} +${if !inlist{aa}{aa} {not in list}{in list}} +****