exim-filter dynamic module
[exim.git] / test / stderr / 0023
index 13e7e6109b03fb6425e65ccaa7ebf9d57b94c4cb..18113e6e13b2115110aaa9674d51d992394bb15a 100644 (file)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_1_2_3"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 44)
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 44)
 >>> check domains = !nopass
 >>> check domains = !nopass
+>>> test.ex in "!nopass"?
+>>>  list element: !nopass
 >>> test.ex in "!nopass"? yes (end of list)
 >>> test.ex in "!nopass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 46)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 46)
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
+>>> test.ex in "!wontpass"?
+>>>  list element: !wontpass
 >>> test.ex in "!wontpass"? yes (end of list)
 >>> test.ex in "!wontpass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "deny" (TESTSUITE/test-config 49)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "deny" (TESTSUITE/test-config 49)
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
+>>> test.ex in "deny.test.ex"?
+>>>  list element: deny.test.ex
 >>> test.ex in "deny.test.ex"? no (end of list)
 >>> test.ex in "deny.test.ex"? no (end of list)
->>> deny: condition test failed in ACL "acl_1_2_3"
->>> processing "accept" (TESTSUITE/test-config 54)
+>>> deny: condition test failed in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "accept" (TESTSUITE/test-config 54)
 >>> check domains = +local_domains
 >>> check domains = +local_domains
->>> test.ex in "test.ex : *.test.ex"? yes (matched "test.ex")
->>> test.ex in "+local_domains"? yes (matched "+local_domains")
+>>> test.ex in "+local_domains"?
+>>>  list element: +local_domains
+>>>   start sublist local_domains
+>>>    test.ex in "test.ex : *.test.ex"?
+>>>    ╎list element: test.ex
+>>>    ╎test.ex in "test.ex : *.test.ex"? yes (matched "test.ex")
+>>>   end sublist local_domains
+>>>  data from lookup saved for cache for +local_domains: key 'test.ex' value 'test.ex'
+>>>  test.ex in "+local_domains"? yes (matched "+local_domains")
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
+>>> test.ex in "!refuse.test.ex"?
+>>>  list element: !refuse.test.ex
 >>> test.ex in "!refuse.test.ex"? yes (end of list)
 >>> test.ex in "!refuse.test.ex"? yes (end of list)
->>> accept: condition test succeeded in ACL "acl_1_2_3"
->>> end of ACL "acl_1_2_3": ACCEPT
+>>> accept: condition test succeeded in ACL acl_1_2_3
+>>> end of ACL acl_1_2_3: ACCEPT
 >>> using ACL "acl_1_2_3"
 >>> using ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 44)
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 44)
 >>> check domains = !nopass
 >>> check domains = !nopass
+>>> z in "!nopass"?
+>>>  list element: !nopass
 >>> z in "!nopass"? yes (end of list)
 >>> z in "!nopass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 46)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 46)
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
+>>> z in "!wontpass"?
+>>>  list element: !wontpass
 >>> z in "!wontpass"? yes (end of list)
 >>> z in "!wontpass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "deny" (TESTSUITE/test-config 49)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "deny" (TESTSUITE/test-config 49)
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
+>>> z in "deny.test.ex"?
+>>>  list element: deny.test.ex
 >>> z in "deny.test.ex"? no (end of list)
 >>> z in "deny.test.ex"? no (end of list)
->>> deny: condition test failed in ACL "acl_1_2_3"
->>> processing "accept" (TESTSUITE/test-config 54)
+>>> deny: condition test failed in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "accept" (TESTSUITE/test-config 54)
 >>> check domains = +local_domains
 >>> check domains = +local_domains
->>> z in "test.ex : *.test.ex"? no (end of list)
+>>> z in "+local_domains"?
+>>>  list element: +local_domains
+>>>   start sublist local_domains
+>>>    z in "test.ex : *.test.ex"?
+>>>    ╎list element: test.ex
+>>>    ╎list element: *.test.ex
+>>>    z in "test.ex : *.test.ex"? no (end of list)
+>>>   end sublist local_domains
 >>> z in "+local_domains"? no (end of list)
 >>> z in "+local_domains"? no (end of list)
->>> accept: condition test failed in ACL "acl_1_2_3"
->>> processing "accept" (TESTSUITE/test-config 60)
+>>> accept: condition test failed in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "accept" (TESTSUITE/test-config 60)
 >>> check domains = +relay_domains
 >>> check domains = +relay_domains
->>> z in "relay.test.ex"? no (end of list)
+>>> z in "+relay_domains"?
+>>>  list element: +relay_domains
+>>>   start sublist relay_domains
+>>>    z in "relay.test.ex"?
+>>>    ╎list element: relay.test.ex
+>>>    z in "relay.test.ex"? no (end of list)
+>>>   end sublist relay_domains
 >>> z in "+relay_domains"? no (end of list)
 >>> z in "+relay_domains"? no (end of list)
->>> accept: condition test failed in ACL "acl_1_2_3"
->>> processing "accept" (TESTSUITE/test-config 61)
+>>> accept: condition test failed in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "accept" (TESTSUITE/test-config 61)
 >>> check domains = +relay_domains
 >>> check domains = +relay_domains
+>>> z in "+relay_domains"?
+>>>  list element: +relay_domains
+>>>   start sublist relay_domains
+>>>  cached no match for +relay_domains
+>>>  cached lookup data = NULL
 >>> z in "+relay_domains"? no (end of list)
 >>> z in "+relay_domains"? no (end of list)
->>> accept: condition test failed in ACL "acl_1_2_3"
->>> end of ACL "acl_1_2_3": implicit DENY
+>>> accept: condition test failed in ACL acl_1_2_3
+>>> end of ACL acl_1_2_3: implicit DENY
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <z@z>
 >>> using ACL "acl_1_2_3"
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <z@z>
 >>> using ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 44)
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 44)
 >>> check domains = !nopass
 >>> check domains = !nopass
+>>> test.ex in "!nopass"?
+>>>  list element: !nopass
 >>> test.ex in "!nopass"? yes (end of list)
 >>> test.ex in "!nopass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 46)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 46)
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
+>>> test.ex in "!wontpass"?
+>>>  list element: !wontpass
 >>> test.ex in "!wontpass"? yes (end of list)
 >>> test.ex in "!wontpass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "deny" (TESTSUITE/test-config 49)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "deny" (TESTSUITE/test-config 49)
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
+>>> test.ex in "deny.test.ex"?
+>>>  list element: deny.test.ex
 >>> test.ex in "deny.test.ex"? no (end of list)
 >>> test.ex in "deny.test.ex"? no (end of list)
->>> deny: condition test failed in ACL "acl_1_2_3"
->>> processing "accept" (TESTSUITE/test-config 54)
+>>> deny: condition test failed in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "accept" (TESTSUITE/test-config 54)
 >>> check domains = +local_domains
 >>> check domains = +local_domains
->>> test.ex in "test.ex : *.test.ex"? yes (matched "test.ex")
->>> test.ex in "+local_domains"? yes (matched "+local_domains")
+>>> test.ex in "+local_domains"?
+>>>  list element: +local_domains
+>>>   start sublist local_domains
+>>>    test.ex in "test.ex : *.test.ex"?
+>>>    ╎list element: test.ex
+>>>    ╎test.ex in "test.ex : *.test.ex"? yes (matched "test.ex")
+>>>   end sublist local_domains
+>>>  data from lookup saved for cache for +local_domains: key 'test.ex' value 'test.ex'
+>>>  test.ex in "+local_domains"? yes (matched "+local_domains")
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
+>>> test.ex in "!refuse.test.ex"?
+>>>  list element: !refuse.test.ex
 >>> test.ex in "!refuse.test.ex"? yes (end of list)
 >>> test.ex in "!refuse.test.ex"? yes (end of list)
->>> accept: condition test succeeded in ACL "acl_1_2_3"
->>> end of ACL "acl_1_2_3": ACCEPT
+>>> accept: condition test succeeded in ACL acl_1_2_3
+>>> end of ACL acl_1_2_3: ACCEPT
 >>> using ACL "acl_1_2_3"
 >>> using ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 44)
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 44)
 >>> check domains = !nopass
 >>> check domains = !nopass
+>>> test.ex in "!nopass"?
+>>>  list element: !nopass
 >>> test.ex in "!nopass"? yes (end of list)
 >>> test.ex in "!nopass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 46)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 46)
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
+>>> test.ex in "!wontpass"?
+>>>  list element: !wontpass
 >>> test.ex in "!wontpass"? yes (end of list)
 >>> test.ex in "!wontpass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "deny" (TESTSUITE/test-config 49)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "deny" (TESTSUITE/test-config 49)
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
+>>> test.ex in "deny.test.ex"?
+>>>  list element: deny.test.ex
 >>> test.ex in "deny.test.ex"? no (end of list)
 >>> test.ex in "deny.test.ex"? no (end of list)
->>> deny: condition test failed in ACL "acl_1_2_3"
->>> processing "accept" (TESTSUITE/test-config 54)
+>>> deny: condition test failed in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "accept" (TESTSUITE/test-config 54)
 >>> check domains = +local_domains
 >>> check domains = +local_domains
->>> test.ex in "test.ex : *.test.ex"? yes (matched "test.ex")
->>> test.ex in "+local_domains"? yes (matched "+local_domains")
+>>> test.ex in "+local_domains"?
+>>>  list element: +local_domains
+>>>   start sublist local_domains
+>>>    test.ex in "test.ex : *.test.ex"?
+>>>    ╎list element: test.ex
+>>>    ╎test.ex in "test.ex : *.test.ex"? yes (matched "test.ex")
+>>>   end sublist local_domains
+>>>  data from lookup saved for cache for +local_domains: key 'test.ex' value 'test.ex'
+>>>  test.ex in "+local_domains"? yes (matched "+local_domains")
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
+>>> test.ex in "!refuse.test.ex"?
+>>>  list element: !refuse.test.ex
 >>> test.ex in "!refuse.test.ex"? yes (end of list)
 >>> test.ex in "!refuse.test.ex"? yes (end of list)
->>> accept: condition test succeeded in ACL "acl_1_2_3"
->>> end of ACL "acl_1_2_3": ACCEPT
+>>> accept: condition test succeeded in ACL acl_1_2_3
+>>> end of ACL acl_1_2_3: ACCEPT
 >>> using ACL "acl_1_2_3"
 >>> using ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 44)
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 44)
 >>> check domains = !nopass
 >>> check domains = !nopass
+>>> relay.test.ex in "!nopass"?
+>>>  list element: !nopass
 >>> relay.test.ex in "!nopass"? yes (end of list)
 >>> relay.test.ex in "!nopass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 46)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 46)
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
+>>> relay.test.ex in "!wontpass"?
+>>>  list element: !wontpass
 >>> relay.test.ex in "!wontpass"? yes (end of list)
 >>> relay.test.ex in "!wontpass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "deny" (TESTSUITE/test-config 49)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "deny" (TESTSUITE/test-config 49)
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
+>>> relay.test.ex in "deny.test.ex"?
+>>>  list element: deny.test.ex
 >>> relay.test.ex in "deny.test.ex"? no (end of list)
 >>> relay.test.ex in "deny.test.ex"? no (end of list)
->>> deny: condition test failed in ACL "acl_1_2_3"
->>> processing "accept" (TESTSUITE/test-config 54)
+>>> deny: condition test failed in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "accept" (TESTSUITE/test-config 54)
 >>> check domains = +local_domains
 >>> check domains = +local_domains
->>> relay.test.ex in "test.ex : *.test.ex"? yes (matched "*.test.ex")
->>> relay.test.ex in "+local_domains"? yes (matched "+local_domains")
+>>> relay.test.ex in "+local_domains"?
+>>>  list element: +local_domains
+>>>   start sublist local_domains
+>>>    relay.test.ex in "test.ex : *.test.ex"?
+>>>    ╎list element: test.ex
+>>>    ╎list element: *.test.ex
+>>>    ╎relay.test.ex in "test.ex : *.test.ex"? yes (matched "*.test.ex")
+>>>   end sublist local_domains
+>>>  data from lookup saved for cache for +local_domains: key 'relay.test.ex' value '*.test.ex'
+>>>  relay.test.ex in "+local_domains"? yes (matched "+local_domains")
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
+>>> relay.test.ex in "!refuse.test.ex"?
+>>>  list element: !refuse.test.ex
 >>> relay.test.ex in "!refuse.test.ex"? yes (end of list)
 >>> relay.test.ex in "!refuse.test.ex"? yes (end of list)
->>> accept: condition test succeeded in ACL "acl_1_2_3"
->>> end of ACL "acl_1_2_3": ACCEPT
+>>> accept: condition test succeeded in ACL acl_1_2_3
+>>> end of ACL acl_1_2_3: ACCEPT
 >>> using ACL "acl_1_2_3"
 >>> using ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 44)
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 44)
 >>> check domains = !nopass
 >>> check domains = !nopass
+>>> deny.test.ex in "!nopass"?
+>>>  list element: !nopass
 >>> deny.test.ex in "!nopass"? yes (end of list)
 >>> deny.test.ex in "!nopass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 46)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 46)
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
+>>> deny.test.ex in "!wontpass"?
+>>>  list element: !wontpass
 >>> deny.test.ex in "!wontpass"? yes (end of list)
 >>> deny.test.ex in "!wontpass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "deny" (TESTSUITE/test-config 49)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "deny" (TESTSUITE/test-config 49)
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
->>> deny.test.ex in "deny.test.ex"? yes (matched "deny.test.ex")
->>> deny: condition test succeeded in ACL "acl_1_2_3"
->>> end of ACL "acl_1_2_3": DENY
+>>> deny.test.ex in "deny.test.ex"?
+>>>  list element: deny.test.ex
+>>>  deny.test.ex in "deny.test.ex"? yes (matched "deny.test.ex")
+>>> deny: condition test succeeded in ACL acl_1_2_3
+>>> end of ACL acl_1_2_3: DENY
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <x@deny.test.ex>: DOMAIN EXPLICITLY DENIED
 >>> using ACL "acl_1_2_3"
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <x@deny.test.ex>: DOMAIN EXPLICITLY DENIED
 >>> using ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 44)
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 44)
 >>> check domains = !nopass
 >>> check domains = !nopass
+>>> refuse.test.ex in "!nopass"?
+>>>  list element: !nopass
 >>> refuse.test.ex in "!nopass"? yes (end of list)
 >>> refuse.test.ex in "!nopass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 46)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 46)
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
+>>> refuse.test.ex in "!wontpass"?
+>>>  list element: !wontpass
 >>> refuse.test.ex in "!wontpass"? yes (end of list)
 >>> refuse.test.ex in "!wontpass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "deny" (TESTSUITE/test-config 49)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "deny" (TESTSUITE/test-config 49)
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
 >>>   message: domain explicitly denied
 >>> l_message: DOMAIN EXPLICITLY DENIED
 >>> check continue = this value is not used
 >>> check domains = deny.test.ex
+>>> refuse.test.ex in "deny.test.ex"?
+>>>  list element: deny.test.ex
 >>> refuse.test.ex in "deny.test.ex"? no (end of list)
 >>> refuse.test.ex in "deny.test.ex"? no (end of list)
->>> deny: condition test failed in ACL "acl_1_2_3"
->>> processing "accept" (TESTSUITE/test-config 54)
+>>> deny: condition test failed in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "accept" (TESTSUITE/test-config 54)
 >>> check domains = +local_domains
 >>> check domains = +local_domains
->>> refuse.test.ex in "test.ex : *.test.ex"? yes (matched "*.test.ex")
->>> refuse.test.ex in "+local_domains"? yes (matched "+local_domains")
+>>> refuse.test.ex in "+local_domains"?
+>>>  list element: +local_domains
+>>>   start sublist local_domains
+>>>    refuse.test.ex in "test.ex : *.test.ex"?
+>>>    ╎list element: test.ex
+>>>    ╎list element: *.test.ex
+>>>    ╎refuse.test.ex in "test.ex : *.test.ex"? yes (matched "*.test.ex")
+>>>   end sublist local_domains
+>>>  data from lookup saved for cache for +local_domains: key 'refuse.test.ex' value '*.test.ex'
+>>>  refuse.test.ex in "+local_domains"? yes (matched "+local_domains")
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
 >>>   message: $domain gets refused
 >>> check domains = !refuse.test.ex
->>> refuse.test.ex in "!refuse.test.ex"? no (matched "!refuse.test.ex")
->>> accept: condition test failed in ACL "acl_1_2_3"
+>>> refuse.test.ex in "!refuse.test.ex"?
+>>>  list element: !refuse.test.ex
+>>>  refuse.test.ex in "!refuse.test.ex"? no (matched "!refuse.test.ex")
+>>> accept: condition test failed in ACL acl_1_2_3
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <x@refuse.test.ex>: refuse.test.ex gets refused
 >>> using ACL "acl_1_2_3"
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <x@refuse.test.ex>: refuse.test.ex gets refused
 >>> using ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 44)
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 44)
 >>> check domains = !nopass
 >>> check domains = !nopass
->>> nopass in "!nopass"? no (matched "!nopass")
->>> require: condition test failed in ACL "acl_1_2_3"
->>> end of ACL "acl_1_2_3": not OK
+>>> nopass in "!nopass"?
+>>>  list element: !nopass
+>>>  nopass in "!nopass"? no (matched "!nopass")
+>>> require: condition test failed in ACL acl_1_2_3
+>>> end of ACL acl_1_2_3: not OK
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <x@nopass>
 >>> using ACL "acl_1_2_3"
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <x@nopass>
 >>> using ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 44)
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 44)
 >>> check domains = !nopass
 >>> check domains = !nopass
+>>> wontpass in "!nopass"?
+>>>  list element: !nopass
 >>> wontpass in "!nopass"? yes (end of list)
 >>> wontpass in "!nopass"? yes (end of list)
->>> require: condition test succeeded in ACL "acl_1_2_3"
->>> processing "require" (TESTSUITE/test-config 46)
+>>> require: condition test succeeded in ACL acl_1_2_3
+>>> processing ACL acl_1_2_3 "require" (TESTSUITE/test-config 46)
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
 >>>   message: $local_part@$domain shall not pass
 >>> check domains = !wontpass
->>> wontpass in "!wontpass"? no (matched "!wontpass")
->>> require: condition test failed in ACL "acl_1_2_3"
->>> end of ACL "acl_1_2_3": not OK
+>>> wontpass in "!wontpass"?
+>>>  list element: !wontpass
+>>>  wontpass in "!wontpass"? no (matched "!wontpass")
+>>> require: condition test failed in ACL acl_1_2_3
+>>> end of ACL acl_1_2_3: not OK
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <x@wontpass>: x@wontpass shall not pass
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <x@wontpass>: x@wontpass shall not pass
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -217,39 +333,58 @@ LOG: H=(test) [1.2.3.4] F=<x@y> rejected RCPT <x@wontpass>: x@wontpass shall not
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_7"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_7"
->>> processing "accept" (TESTSUITE/test-config 64)
+>>> processing ACL acl_5_6_7 "accept" (TESTSUITE/test-config 64)
 >>> check domains = lsearch;TESTSUITE/aux-fixed/0023.doms
 >>> check domains = lsearch;TESTSUITE/aux-fixed/0023.doms
+>>> y in "lsearch;TESTSUITE/aux-fixed/0023.doms"?
+>>>  list element: lsearch;TESTSUITE/aux-fixed/0023.doms
 >>> y in "lsearch;TESTSUITE/aux-fixed/0023.doms"? no (end of list)
 >>> y in "lsearch;TESTSUITE/aux-fixed/0023.doms"? no (end of list)
->>> accept: condition test failed in ACL "acl_5_6_7"
->>> end of ACL "acl_5_6_7": implicit DENY
+>>> accept: condition test failed in ACL acl_5_6_7
+>>> end of ACL acl_5_6_7: implicit DENY
 LOG: H=(test) [5.6.7.8] F=<x@y> rejected RCPT <x@y>
 >>> using ACL "acl_5_6_7"
 LOG: H=(test) [5.6.7.8] F=<x@y> rejected RCPT <x@y>
 >>> using ACL "acl_5_6_7"
->>> processing "accept" (TESTSUITE/test-config 64)
+>>> processing ACL acl_5_6_7 "accept" (TESTSUITE/test-config 64)
 >>> check domains = lsearch;TESTSUITE/aux-fixed/0023.doms
 >>> check domains = lsearch;TESTSUITE/aux-fixed/0023.doms
->>> test.ex in "lsearch;TESTSUITE/aux-fixed/0023.doms"? yes (matched "lsearch;TESTSUITE/aux-fixed/0023.doms")
+>>> test.ex in "lsearch;TESTSUITE/aux-fixed/0023.doms"?
+>>>  list element: lsearch;TESTSUITE/aux-fixed/0023.doms
+>>>  test.ex in "lsearch;TESTSUITE/aux-fixed/0023.doms"? yes (matched "lsearch;TESTSUITE/aux-fixed/0023.doms")
 >>> check local_parts = $domain_data
 >>> check local_parts = $domain_data
+>>> x in "userx : spqr"?
+>>>  list element: userx
+>>>  list element: spqr
 >>> x in "userx : spqr"? no (end of list)
 >>> x in "userx : spqr"? no (end of list)
->>> accept: condition test failed in ACL "acl_5_6_7"
->>> end of ACL "acl_5_6_7": implicit DENY
+>>> accept: condition test failed in ACL acl_5_6_7
+>>> end of ACL acl_5_6_7: implicit DENY
 LOG: H=(test) [5.6.7.8] F=<x@y> rejected RCPT <x@test.ex>
 >>> using ACL "acl_5_6_7"
 LOG: H=(test) [5.6.7.8] F=<x@y> rejected RCPT <x@test.ex>
 >>> using ACL "acl_5_6_7"
->>> processing "accept" (TESTSUITE/test-config 64)
+>>> processing ACL acl_5_6_7 "accept" (TESTSUITE/test-config 64)
 >>> check domains = lsearch;TESTSUITE/aux-fixed/0023.doms
 >>> check domains = lsearch;TESTSUITE/aux-fixed/0023.doms
->>> test.ex in "lsearch;TESTSUITE/aux-fixed/0023.doms"? yes (matched "lsearch;TESTSUITE/aux-fixed/0023.doms")
+>>> test.ex in "lsearch;TESTSUITE/aux-fixed/0023.doms"?
+>>>  list element: lsearch;TESTSUITE/aux-fixed/0023.doms
+>>>  test.ex in "lsearch;TESTSUITE/aux-fixed/0023.doms"? yes (matched "lsearch;TESTSUITE/aux-fixed/0023.doms")
 >>> check local_parts = $domain_data
 >>> check local_parts = $domain_data
->>> userx in "userx : spqr"? yes (matched "userx")
->>> accept: condition test succeeded in ACL "acl_5_6_7"
->>> end of ACL "acl_5_6_7": ACCEPT
+>>> userx in "userx : spqr"?
+>>>  list element: userx
+>>>  userx in "userx : spqr"? yes (matched "userx")
+>>> accept: condition test succeeded in ACL acl_5_6_7
+>>> end of ACL acl_5_6_7: ACCEPT
 >>> using ACL "acl_5_6_7"
 >>> using ACL "acl_5_6_7"
->>> processing "accept" (TESTSUITE/test-config 64)
+>>> processing ACL acl_5_6_7 "accept" (TESTSUITE/test-config 64)
 >>> check domains = lsearch;TESTSUITE/aux-fixed/0023.doms
 >>> check domains = lsearch;TESTSUITE/aux-fixed/0023.doms
->>> test.ex in "lsearch;TESTSUITE/aux-fixed/0023.doms"? yes (matched "lsearch;TESTSUITE/aux-fixed/0023.doms")
+>>> test.ex in "lsearch;TESTSUITE/aux-fixed/0023.doms"?
+>>>  list element: lsearch;TESTSUITE/aux-fixed/0023.doms
+>>>  test.ex in "lsearch;TESTSUITE/aux-fixed/0023.doms"? yes (matched "lsearch;TESTSUITE/aux-fixed/0023.doms")
 >>> check local_parts = $domain_data
 >>> check local_parts = $domain_data
->>> spqr in "userx : spqr"? yes (matched "spqr")
->>> accept: condition test succeeded in ACL "acl_5_6_7"
->>> end of ACL "acl_5_6_7": ACCEPT
+>>> spqr in "userx : spqr"?
+>>>  list element: userx
+>>>  list element: spqr
+>>>  spqr in "userx : spqr"? yes (matched "spqr")
+>>> accept: condition test succeeded in ACL acl_5_6_7
+>>> end of ACL acl_5_6_7: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -258,20 +393,34 @@ LOG: H=(test) [5.6.7.8] F=<x@y> rejected RCPT <x@test.ex>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_9_9_9"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_9_9_9"
->>> processing "accept" (TESTSUITE/test-config 91)
+>>> processing ACL acl_9_9_9 "accept" (TESTSUITE/test-config 91)
 >>> check hosts = +ok9_hosts
 >>> check hosts = +ok9_hosts
->>> host in "9.9.9.9"? yes (matched "9.9.9.9")
->>> host in "+ok9_hosts"? yes (matched "+ok9_hosts")
->>> accept: condition test succeeded in ACL "acl_9_9_9"
->>> end of ACL "acl_9_9_9": ACCEPT
+>>> host in "+ok9_hosts"?
+>>>  list element: +ok9_hosts
+>>>   start sublist ok9_hosts
+>>>    host in "9.9.9.9"?
+>>>    ╎list element: 9.9.9.9
+>>>    ╎host in "9.9.9.9"? yes (matched "9.9.9.9")
+>>>   end sublist ok9_hosts
+>>>  host in "+ok9_hosts"? yes (matched "+ok9_hosts")
+>>> accept: condition test succeeded in ACL acl_9_9_9
+>>> end of ACL acl_9_9_9: ACCEPT
 >>> using ACL "acl_9_9_9"
 >>> using ACL "acl_9_9_9"
->>> processing "accept" (TESTSUITE/test-config 91)
+>>> processing ACL acl_9_9_9 "accept" (TESTSUITE/test-config 91)
 >>> check hosts = +ok9_hosts
 >>> check hosts = +ok9_hosts
->>> host in "+ok9_hosts"? yes (matched "+ok9_hosts" - cached)
->>> accept: condition test succeeded in ACL "acl_9_9_9"
->>> end of ACL "acl_9_9_9": ACCEPT
+>>> host in "+ok9_hosts"?
+>>>  list element: +ok9_hosts
+>>>   start sublist ok9_hosts
+>>>  cached yes match for +ok9_hosts
+>>>  cached lookup data = NULL
+>>>  host in "+ok9_hosts"? yes (matched "+ok9_hosts" - cached)
+>>> accept: condition test succeeded in ACL acl_9_9_9
+>>> end of ACL acl_9_9_9: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -280,31 +429,49 @@ LOG: H=(test) [5.6.7.8] F=<x@y> rejected RCPT <x@test.ex>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_9_9_9"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_9_9_9"
->>> processing "accept" (TESTSUITE/test-config 91)
+>>> processing ACL acl_9_9_9 "accept" (TESTSUITE/test-config 91)
 >>> check hosts = +ok9_hosts
 >>> check hosts = +ok9_hosts
->>> host in "9.9.9.9"? no (end of list)
+>>> host in "+ok9_hosts"?
+>>>  list element: +ok9_hosts
+>>>   start sublist ok9_hosts
+>>>    host in "9.9.9.9"?
+>>>    ╎list element: 9.9.9.9
+>>>    host in "9.9.9.9"? no (end of list)
+>>>   end sublist ok9_hosts
 >>> host in "+ok9_hosts"? no (end of list)
 >>> host in "+ok9_hosts"? no (end of list)
->>> accept: condition test failed in ACL "acl_9_9_9"
->>> processing "deny" (TESTSUITE/test-config 92)
+>>> accept: condition test failed in ACL acl_9_9_9
+>>> processing ACL acl_9_9_9 "deny" (TESTSUITE/test-config 92)
 >>>   message: don't like this host
 >>> check hosts = 9.9.9.0/26
 >>>   message: don't like this host
 >>> check hosts = 9.9.9.0/26
->>> host in "9.9.9.0/26"? yes (matched "9.9.9.0/26")
->>> deny: condition test succeeded in ACL "acl_9_9_9"
->>> end of ACL "acl_9_9_9": DENY
+>>> host in "9.9.9.0/26"?
+>>>  list element: 9.9.9.0/26
+>>>  host in "9.9.9.0/26"? yes (matched "9.9.9.0/26")
+>>> deny: condition test succeeded in ACL acl_9_9_9
+>>> end of ACL acl_9_9_9: DENY
 LOG: H=(test) [9.9.9.8] F=<x@y> rejected RCPT <x@y>: don't like this host
 >>> using ACL "acl_9_9_9"
 LOG: H=(test) [9.9.9.8] F=<x@y> rejected RCPT <x@y>: don't like this host
 >>> using ACL "acl_9_9_9"
->>> processing "accept" (TESTSUITE/test-config 91)
+>>> processing ACL acl_9_9_9 "accept" (TESTSUITE/test-config 91)
 >>> check hosts = +ok9_hosts
 >>> check hosts = +ok9_hosts
+>>> host in "+ok9_hosts"?
+>>>  list element: +ok9_hosts
+>>>   start sublist ok9_hosts
+>>>  cached no match for +ok9_hosts
+>>>  cached lookup data = NULL
 >>> host in "+ok9_hosts"? no (end of list)
 >>> host in "+ok9_hosts"? no (end of list)
->>> accept: condition test failed in ACL "acl_9_9_9"
->>> processing "deny" (TESTSUITE/test-config 92)
+>>> accept: condition test failed in ACL acl_9_9_9
+>>> processing ACL acl_9_9_9 "deny" (TESTSUITE/test-config 92)
 >>>   message: don't like this host
 >>> check hosts = 9.9.9.0/26
 >>>   message: don't like this host
 >>> check hosts = 9.9.9.0/26
->>> host in "9.9.9.0/26"? yes (matched "9.9.9.0/26")
->>> deny: condition test succeeded in ACL "acl_9_9_9"
->>> end of ACL "acl_9_9_9": DENY
+>>> host in "9.9.9.0/26"?
+>>>  list element: 9.9.9.0/26
+>>>  host in "9.9.9.0/26"? yes (matched "9.9.9.0/26")
+>>> deny: condition test succeeded in ACL acl_9_9_9
+>>> end of ACL acl_9_9_9: DENY
 LOG: H=(test) [9.9.9.8] F=<x@y> rejected RCPT <a@b>: don't like this host
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [9.9.9.8] F=<x@y> rejected RCPT <a@b>: don't like this host
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -314,38 +481,60 @@ LOG: H=(test) [9.9.9.8] F=<x@y> rejected RCPT <a@b>: don't like this host
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_9_9_9"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_9_9_9"
->>> processing "accept" (TESTSUITE/test-config 91)
+>>> processing ACL acl_9_9_9 "accept" (TESTSUITE/test-config 91)
 >>> check hosts = +ok9_hosts
 >>> check hosts = +ok9_hosts
->>> host in "9.9.9.9"? no (end of list)
+>>> host in "+ok9_hosts"?
+>>>  list element: +ok9_hosts
+>>>   start sublist ok9_hosts
+>>>    host in "9.9.9.9"?
+>>>    ╎list element: 9.9.9.9
+>>>    host in "9.9.9.9"? no (end of list)
+>>>   end sublist ok9_hosts
 >>> host in "+ok9_hosts"? no (end of list)
 >>> host in "+ok9_hosts"? no (end of list)
->>> accept: condition test failed in ACL "acl_9_9_9"
->>> processing "deny" (TESTSUITE/test-config 92)
+>>> accept: condition test failed in ACL acl_9_9_9
+>>> processing ACL acl_9_9_9 "deny" (TESTSUITE/test-config 92)
 >>>   message: don't like this host
 >>> check hosts = 9.9.9.0/26
 >>>   message: don't like this host
 >>> check hosts = 9.9.9.0/26
+>>> host in "9.9.9.0/26"?
+>>>  list element: 9.9.9.0/26
 >>> host in "9.9.9.0/26"? no (end of list)
 >>> host in "9.9.9.0/26"? no (end of list)
->>> deny: condition test failed in ACL "acl_9_9_9"
->>> processing "accept" (TESTSUITE/test-config 94)
+>>> deny: condition test failed in ACL acl_9_9_9
+>>> processing ACL acl_9_9_9 "accept" (TESTSUITE/test-config 94)
 >>> check hosts = 9.9.9.0/24
 >>> check hosts = 9.9.9.0/24
->>> host in "9.9.9.0/24"? yes (matched "9.9.9.0/24")
->>> accept: condition test succeeded in ACL "acl_9_9_9"
->>> end of ACL "acl_9_9_9": ACCEPT
+>>> host in "9.9.9.0/24"?
+>>>  list element: 9.9.9.0/24
+>>>  host in "9.9.9.0/24"? yes (matched "9.9.9.0/24")
+>>> accept: condition test succeeded in ACL acl_9_9_9
+>>> end of ACL acl_9_9_9: ACCEPT
 >>> using ACL "acl_9_9_9"
 >>> using ACL "acl_9_9_9"
->>> processing "accept" (TESTSUITE/test-config 91)
+>>> processing ACL acl_9_9_9 "accept" (TESTSUITE/test-config 91)
 >>> check hosts = +ok9_hosts
 >>> check hosts = +ok9_hosts
+>>> host in "+ok9_hosts"?
+>>>  list element: +ok9_hosts
+>>>   start sublist ok9_hosts
+>>>  cached no match for +ok9_hosts
+>>>  cached lookup data = NULL
 >>> host in "+ok9_hosts"? no (end of list)
 >>> host in "+ok9_hosts"? no (end of list)
->>> accept: condition test failed in ACL "acl_9_9_9"
->>> processing "deny" (TESTSUITE/test-config 92)
+>>> accept: condition test failed in ACL acl_9_9_9
+>>> processing ACL acl_9_9_9 "deny" (TESTSUITE/test-config 92)
 >>>   message: don't like this host
 >>> check hosts = 9.9.9.0/26
 >>>   message: don't like this host
 >>> check hosts = 9.9.9.0/26
+>>> host in "9.9.9.0/26"?
+>>>  list element: 9.9.9.0/26
 >>> host in "9.9.9.0/26"? no (end of list)
 >>> host in "9.9.9.0/26"? no (end of list)
->>> deny: condition test failed in ACL "acl_9_9_9"
->>> processing "accept" (TESTSUITE/test-config 94)
+>>> deny: condition test failed in ACL acl_9_9_9
+>>> processing ACL acl_9_9_9 "accept" (TESTSUITE/test-config 94)
 >>> check hosts = 9.9.9.0/24
 >>> check hosts = 9.9.9.0/24
->>> host in "9.9.9.0/24"? yes (matched "9.9.9.0/24")
->>> accept: condition test succeeded in ACL "acl_9_9_9"
->>> end of ACL "acl_9_9_9": ACCEPT
+>>> host in "9.9.9.0/24"?
+>>>  list element: 9.9.9.0/24
+>>>  host in "9.9.9.0/24"? yes (matched "9.9.9.0/24")
+>>> accept: condition test succeeded in ACL acl_9_9_9
+>>> end of ACL acl_9_9_9: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -354,65 +543,132 @@ LOG: H=(test) [9.9.9.8] F=<x@y> rejected RCPT <a@b>: don't like this host
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_8"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_8"
->>> processing "accept" (TESTSUITE/test-config 68)
+>>> processing ACL acl_5_6_8 "accept" (TESTSUITE/test-config 68)
 >>> check senders = user1@domain1 : domain2 : +ok_senders
 >>> check senders = user1@domain1 : domain2 : +ok_senders
->>> y in "domain2"? no (end of list)
->>> x@y in "ok@ok.ok"? no (end of list)
+>>> x@y in "user1@domain1 : domain2 : +ok_senders"?
+>>>  list element: user1@domain1
+>>>  list element: domain2
+>>>  y in "domain2"?
+>>>   list element: domain2
+>>>  y in "domain2"? no (end of list)
+>>>  list element: +ok_senders
+>>>   start sublist ok_senders
+>>>    x@y in "ok@ok.ok"?
+>>>    ╎list element: ok@ok.ok
+>>>    x@y in "ok@ok.ok"? no (end of list)
+>>>   end sublist ok_senders
 >>> x@y in "user1@domain1 : domain2 : +ok_senders"? no (end of list)
 >>> x@y in "user1@domain1 : domain2 : +ok_senders"? no (end of list)
->>> accept: condition test failed in ACL "acl_5_6_8"
->>> end of ACL "acl_5_6_8": implicit DENY
+>>> accept: condition test failed in ACL acl_5_6_8
+>>> end of ACL acl_5_6_8: implicit DENY
 LOG: H=(test) [5.6.8.1] F=<x@y> rejected RCPT <x@y>
 >>> using ACL "acl_5_6_8"
 LOG: H=(test) [5.6.8.1] F=<x@y> rejected RCPT <x@y>
 >>> using ACL "acl_5_6_8"
->>> processing "accept" (TESTSUITE/test-config 68)
+>>> processing ACL acl_5_6_8 "accept" (TESTSUITE/test-config 68)
 >>> check senders = user1@domain1 : domain2 : +ok_senders
 >>> check senders = user1@domain1 : domain2 : +ok_senders
->>> y in "domain2"? no (end of list)
+>>> x@y in "user1@domain1 : domain2 : +ok_senders"?
+>>>  list element: user1@domain1
+>>>  list element: domain2
+>>>  y in "domain2"?
+>>>   list element: domain2
+>>>  y in "domain2"? no (end of list)
+>>>  list element: +ok_senders
+>>>   start sublist ok_senders
+>>>  cached no match for +ok_senders
+>>>  cached lookup data = NULL
 >>> x@y in "user1@domain1 : domain2 : +ok_senders"? no (end of list)
 >>> x@y in "user1@domain1 : domain2 : +ok_senders"? no (end of list)
->>> accept: condition test failed in ACL "acl_5_6_8"
->>> end of ACL "acl_5_6_8": implicit DENY
+>>> accept: condition test failed in ACL acl_5_6_8
+>>> end of ACL acl_5_6_8: implicit DENY
 LOG: H=(test) [5.6.8.1] F=<x@y> rejected RCPT <y@x>
 >>> using ACL "acl_5_6_8"
 LOG: H=(test) [5.6.8.1] F=<x@y> rejected RCPT <y@x>
 >>> using ACL "acl_5_6_8"
->>> processing "accept" (TESTSUITE/test-config 68)
+>>> processing ACL acl_5_6_8 "accept" (TESTSUITE/test-config 68)
 >>> check senders = user1@domain1 : domain2 : +ok_senders
 >>> check senders = user1@domain1 : domain2 : +ok_senders
->>> domain1 in "domain1"? yes (matched "domain1")
->>> user1@domain1 in "user1@domain1 : domain2 : +ok_senders"? yes (matched "user1@domain1")
->>> accept: condition test succeeded in ACL "acl_5_6_8"
->>> end of ACL "acl_5_6_8": ACCEPT
->>> host in smtp_accept_max_nonmail_hosts? yes (matched "*")
+>>> user1@domain1 in "user1@domain1 : domain2 : +ok_senders"?
+>>>  list element: user1@domain1
+>>>  domain1 in "domain1"?
+>>>   list element: domain1
+>>>   domain1 in "domain1"? yes (matched "domain1")
+>>>  user1@domain1 in "user1@domain1 : domain2 : +ok_senders"? yes (matched "user1@domain1")
+>>> accept: condition test succeeded in ACL acl_5_6_8
+>>> end of ACL acl_5_6_8: ACCEPT
+>>> host in smtp_accept_max_nonmail_hosts?
+>>>  list element: *
+>>>  host in smtp_accept_max_nonmail_hosts? yes (matched "*")
 >>> using ACL "acl_5_6_8"
 >>> using ACL "acl_5_6_8"
->>> processing "accept" (TESTSUITE/test-config 68)
+>>> processing ACL acl_5_6_8 "accept" (TESTSUITE/test-config 68)
 >>> check senders = user1@domain1 : domain2 : +ok_senders
 >>> check senders = user1@domain1 : domain2 : +ok_senders
->>> domain1 in "domain2"? no (end of list)
->>> user2@domain1 in "ok@ok.ok"? no (end of list)
+>>> user2@domain1 in "user1@domain1 : domain2 : +ok_senders"?
+>>>  list element: user1@domain1
+>>>  list element: domain2
+>>>  domain1 in "domain2"?
+>>>   list element: domain2
+>>>  domain1 in "domain2"? no (end of list)
+>>>  list element: +ok_senders
+>>>   start sublist ok_senders
+>>>    user2@domain1 in "ok@ok.ok"?
+>>>    ╎list element: ok@ok.ok
+>>>    user2@domain1 in "ok@ok.ok"? no (end of list)
+>>>   end sublist ok_senders
 >>> user2@domain1 in "user1@domain1 : domain2 : +ok_senders"? no (end of list)
 >>> user2@domain1 in "user1@domain1 : domain2 : +ok_senders"? no (end of list)
->>> accept: condition test failed in ACL "acl_5_6_8"
->>> end of ACL "acl_5_6_8": implicit DENY
+>>> accept: condition test failed in ACL acl_5_6_8
+>>> end of ACL acl_5_6_8: implicit DENY
 LOG: H=(test) [5.6.8.1] F=<user2@domain1> rejected RCPT <x@y>
 >>> using ACL "acl_5_6_8"
 LOG: H=(test) [5.6.8.1] F=<user2@domain1> rejected RCPT <x@y>
 >>> using ACL "acl_5_6_8"
->>> processing "accept" (TESTSUITE/test-config 68)
+>>> processing ACL acl_5_6_8 "accept" (TESTSUITE/test-config 68)
 >>> check senders = user1@domain1 : domain2 : +ok_senders
 >>> check senders = user1@domain1 : domain2 : +ok_senders
->>> domain2 in "domain1"? no (end of list)
->>> domain2 in "domain2"? yes (matched "domain2")
->>> user1@domain2 in "user1@domain1 : domain2 : +ok_senders"? yes (matched "domain2")
->>> accept: condition test succeeded in ACL "acl_5_6_8"
->>> end of ACL "acl_5_6_8": ACCEPT
+>>> user1@domain2 in "user1@domain1 : domain2 : +ok_senders"?
+>>>  list element: user1@domain1
+>>>  domain2 in "domain1"?
+>>>   list element: domain1
+>>>  domain2 in "domain1"? no (end of list)
+>>>  list element: domain2
+>>>  domain2 in "domain2"?
+>>>   list element: domain2
+>>>   domain2 in "domain2"? yes (matched "domain2")
+>>>  user1@domain2 in "user1@domain1 : domain2 : +ok_senders"? yes (matched "domain2")
+>>> accept: condition test succeeded in ACL acl_5_6_8
+>>> end of ACL acl_5_6_8: ACCEPT
 >>> using ACL "acl_5_6_8"
 >>> using ACL "acl_5_6_8"
->>> processing "accept" (TESTSUITE/test-config 68)
+>>> processing ACL acl_5_6_8 "accept" (TESTSUITE/test-config 68)
 >>> check senders = user1@domain1 : domain2 : +ok_senders
 >>> check senders = user1@domain1 : domain2 : +ok_senders
->>> ok.ok in "domain2"? no (end of list)
->>> ok.ok in "ok.ok"? yes (matched "ok.ok")
->>> ok@ok.ok in "ok@ok.ok"? yes (matched "ok@ok.ok")
->>> ok@ok.ok in "user1@domain1 : domain2 : +ok_senders"? yes (matched "+ok_senders")
->>> accept: condition test succeeded in ACL "acl_5_6_8"
->>> end of ACL "acl_5_6_8": ACCEPT
+>>> ok@ok.ok in "user1@domain1 : domain2 : +ok_senders"?
+>>>  list element: user1@domain1
+>>>  list element: domain2
+>>>  ok.ok in "domain2"?
+>>>   list element: domain2
+>>>  ok.ok in "domain2"? no (end of list)
+>>>  list element: +ok_senders
+>>>   start sublist ok_senders
+>>>    ok@ok.ok in "ok@ok.ok"?
+>>>    ╎list element: ok@ok.ok
+>>>    ╎ok.ok in "ok.ok"?
+>>>    ╎ list element: ok.ok
+>>>    ╎ ok.ok in "ok.ok"? yes (matched "ok.ok")
+>>>    ╎ok@ok.ok in "ok@ok.ok"? yes (matched "ok@ok.ok")
+>>>   end sublist ok_senders
+>>>  data from lookup saved for cache for +ok_senders: key 'ok@ok.ok' value 'ok@ok.ok'
+>>>  ok@ok.ok in "user1@domain1 : domain2 : +ok_senders"? yes (matched "+ok_senders")
+>>> accept: condition test succeeded in ACL acl_5_6_8
+>>> end of ACL acl_5_6_8: ACCEPT
 >>> using ACL "acl_5_6_8"
 >>> using ACL "acl_5_6_8"
->>> processing "accept" (TESTSUITE/test-config 68)
+>>> processing ACL acl_5_6_8 "accept" (TESTSUITE/test-config 68)
 >>> check senders = user1@domain1 : domain2 : +ok_senders
 >>> check senders = user1@domain1 : domain2 : +ok_senders
->>> ok.ok in "domain2"? no (end of list)
->>> ok@ok.ok in "user1@domain1 : domain2 : +ok_senders"? yes (matched "+ok_senders" - cached)
->>> accept: condition test succeeded in ACL "acl_5_6_8"
->>> end of ACL "acl_5_6_8": ACCEPT
+>>> ok@ok.ok in "user1@domain1 : domain2 : +ok_senders"?
+>>>  list element: user1@domain1
+>>>  list element: domain2
+>>>  ok.ok in "domain2"?
+>>>   list element: domain2
+>>>  ok.ok in "domain2"? no (end of list)
+>>>  list element: +ok_senders
+>>>   start sublist ok_senders
+>>>  cached yes match for +ok_senders
+>>>  cached lookup data = ok@ok.ok
+>>>  ok@ok.ok in "user1@domain1 : domain2 : +ok_senders"? yes (matched "+ok_senders" - cached)
+>>> accept: condition test succeeded in ACL acl_5_6_8
+>>> end of ACL acl_5_6_8: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -421,28 +677,31 @@ LOG: H=(test) [5.6.8.1] F=<user2@domain1> rejected RCPT <x@y>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_11"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_11"
->>> processing "accept" (TESTSUITE/test-config 71)
+>>> processing ACL acl_5_6_11 "accept" (TESTSUITE/test-config 71)
 >>> check condition = ${if match{$local_part}{^x}{yes}{no}}
 >>>                 = yes
 >>> check condition = ${if match{$local_part}{^x}{yes}{no}}
 >>>                 = yes
->>> accept: condition test succeeded in ACL "acl_5_6_11"
->>> end of ACL "acl_5_6_11": ACCEPT
+>>> accept: condition test succeeded in ACL acl_5_6_11
+>>> end of ACL acl_5_6_11: ACCEPT
 >>> using ACL "acl_5_6_11"
 >>> using ACL "acl_5_6_11"
->>> processing "accept" (TESTSUITE/test-config 71)
+>>> processing ACL acl_5_6_11 "accept" (TESTSUITE/test-config 71)
 >>> check condition = ${if match{$local_part}{^x}{yes}{no}}
 >>>                 = yes
 >>> check condition = ${if match{$local_part}{^x}{yes}{no}}
 >>>                 = yes
->>> accept: condition test succeeded in ACL "acl_5_6_11"
->>> end of ACL "acl_5_6_11": ACCEPT
+>>> accept: condition test succeeded in ACL acl_5_6_11
+>>> end of ACL acl_5_6_11: ACCEPT
 >>> using ACL "acl_5_6_11"
 >>> using ACL "acl_5_6_11"
->>> processing "accept" (TESTSUITE/test-config 71)
+>>> processing ACL acl_5_6_11 "accept" (TESTSUITE/test-config 71)
 >>> check condition = ${if match{$local_part}{^x}{yes}{no}}
 >>>                 = no
 >>> check condition = ${if match{$local_part}{^x}{yes}{no}}
 >>>                 = no
->>> accept: condition test failed in ACL "acl_5_6_11"
->>> processing "deny" (TESTSUITE/test-config 72)
+>>> accept: condition test failed in ACL acl_5_6_11
+>>> processing ACL acl_5_6_11 "deny" (TESTSUITE/test-config 72)
 >>>   message: "local part of wrong type\n(quotes are literal)
 >>>   message: "local part of wrong type\n(quotes are literal)
->>> deny: condition test succeeded in ACL "acl_5_6_11"
->>> end of ACL "acl_5_6_11": DENY
+>>> deny: condition test succeeded in ACL acl_5_6_11
+>>> end of ACL acl_5_6_11: DENY
 LOG: H=(test) [5.6.11.1] F=<x@y> rejected RCPT <y2@y>: "local part of wrong type
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [5.6.11.1] F=<x@y> rejected RCPT <y2@y>: "local part of wrong type
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -452,34 +711,45 @@ LOG: H=(test) [5.6.11.1] F=<x@y> rejected RCPT <y2@y>: "local part of wrong type
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_12"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_12"
->>> processing "accept" (TESTSUITE/test-config 75)
+>>> processing ACL acl_5_6_12 "accept" (TESTSUITE/test-config 75)
 >>> check hosts = 5.6.12.1
 >>> check hosts = 5.6.12.1
->>> host in "5.6.12.1"? yes (matched "5.6.12.1")
+>>> host in "5.6.12.1"?
+>>>  list element: 5.6.12.1
+>>>  host in "5.6.12.1"? yes (matched "5.6.12.1")
 >>>   message: failed nested acl
 >>> check acl = acl_5_6_12A
 >>>  using ACL "acl_5_6_12A"
 >>>   message: failed nested acl
 >>> check acl = acl_5_6_12A
 >>>  using ACL "acl_5_6_12A"
->>>  processing "accept" (TESTSUITE/test-config 82)
+>>>  processing ACL acl_5_6_12A "accept" (TESTSUITE/test-config 82)
 >>>  check domains = ok
 >>>  check domains = ok
->>>  ok in "ok"? yes (matched "ok")
->>>  accept: condition test succeeded in ACL "acl_5_6_12A"
->>>  end of ACL "acl_5_6_12A": ACCEPT
->>> accept: condition test succeeded in ACL "acl_5_6_12"
->>> end of ACL "acl_5_6_12": ACCEPT
+>>>  ok in "ok"?
+>>>   list element: ok
+>>>   ok in "ok"? yes (matched "ok")
+>>>  accept: condition test succeeded in ACL acl_5_6_12A
+>>>  end of ACL acl_5_6_12A: ACCEPT
+>>> accept: condition test succeeded in ACL acl_5_6_12
+>>> end of ACL acl_5_6_12: ACCEPT
 >>> using ACL "acl_5_6_12"
 >>> using ACL "acl_5_6_12"
->>> processing "accept" (TESTSUITE/test-config 75)
+>>> processing ACL acl_5_6_12 "accept" (TESTSUITE/test-config 75)
 >>> check hosts = 5.6.12.1
 >>> check hosts = 5.6.12.1
->>> host in "5.6.12.1"? yes (matched "5.6.12.1")
+>>> host in "5.6.12.1"?
+>>>  list element: 5.6.12.1
+>>>  host in "5.6.12.1"? yes (matched "5.6.12.1")
 >>>   message: failed nested acl
 >>> check acl = acl_5_6_12A
 >>>  using ACL "acl_5_6_12A"
 >>>   message: failed nested acl
 >>> check acl = acl_5_6_12A
 >>>  using ACL "acl_5_6_12A"
->>>  processing "accept" (TESTSUITE/test-config 82)
+>>>  processing ACL acl_5_6_12A "accept" (TESTSUITE/test-config 82)
 >>>  check domains = ok
 >>>  check domains = ok
+>>>  y in "ok"?
+>>>   list element: ok
 >>>  y in "ok"? no (end of list)
 >>>  y in "ok"? no (end of list)
->>>  accept: condition test failed in ACL "acl_5_6_12A"
->>>  end of ACL "acl_5_6_12A": implicit DENY
->>> accept: condition test failed in ACL "acl_5_6_12"
+>>>  accept: condition test failed in ACL acl_5_6_12A
+>>>  end of ACL acl_5_6_12A: implicit DENY
+>>> accept: condition test failed in ACL acl_5_6_12
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [5.6.12.1] F=<x@y> rejected RCPT <x@y>: failed nested acl
 >>> host in hosts_connection_nolog? no (option unset)
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [5.6.12.1] F=<x@y> rejected RCPT <x@y>: failed nested acl
 >>> host in hosts_connection_nolog? no (option unset)
@@ -490,23 +760,30 @@ LOG: H=(test) [5.6.12.1] F=<x@y> rejected RCPT <x@y>: failed nested acl
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_12"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_12"
->>> processing "accept" (TESTSUITE/test-config 75)
+>>> processing ACL acl_5_6_12 "accept" (TESTSUITE/test-config 75)
 >>> check hosts = 5.6.12.1
 >>> check hosts = 5.6.12.1
+>>> host in "5.6.12.1"?
+>>>  list element: 5.6.12.1
 >>> host in "5.6.12.1"? no (end of list)
 >>> host in "5.6.12.1"? no (end of list)
->>> accept: condition test failed in ACL "acl_5_6_12"
->>> processing "accept" (TESTSUITE/test-config 79)
->>> accept: condition test succeeded in ACL "acl_5_6_12"
->>> end of ACL "acl_5_6_12": ACCEPT
+>>> accept: condition test failed in ACL acl_5_6_12
+>>> processing ACL acl_5_6_12 "accept" (TESTSUITE/test-config 79)
+>>> accept: condition test succeeded in ACL acl_5_6_12
+>>> end of ACL acl_5_6_12: ACCEPT
 >>> using ACL "acl_5_6_12"
 >>> using ACL "acl_5_6_12"
->>> processing "accept" (TESTSUITE/test-config 75)
+>>> processing ACL acl_5_6_12 "accept" (TESTSUITE/test-config 75)
 >>> check hosts = 5.6.12.1
 >>> check hosts = 5.6.12.1
+>>> host in "5.6.12.1"?
+>>>  list element: 5.6.12.1
 >>> host in "5.6.12.1"? no (end of list)
 >>> host in "5.6.12.1"? no (end of list)
->>> accept: condition test failed in ACL "acl_5_6_12"
->>> processing "accept" (TESTSUITE/test-config 79)
->>> accept: condition test succeeded in ACL "acl_5_6_12"
->>> end of ACL "acl_5_6_12": ACCEPT
+>>> accept: condition test failed in ACL acl_5_6_12
+>>> processing ACL acl_5_6_12 "accept" (TESTSUITE/test-config 79)
+>>> accept: condition test succeeded in ACL acl_5_6_12
+>>> end of ACL acl_5_6_12: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -515,91 +792,94 @@ LOG: H=(test) [5.6.12.1] F=<x@y> rejected RCPT <x@y>: failed nested acl
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_8_8_8"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_8_8_8"
->>> processing "accept" (TESTSUITE/test-config 88)
+>>> processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>> check acl = acl_8_8_8
 >>>  using ACL "acl_8_8_8"
 >>> check acl = acl_8_8_8
 >>>  using ACL "acl_8_8_8"
->>>  processing "accept" (TESTSUITE/test-config 88)
+>>>  processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>  check acl = acl_8_8_8
 >>>   using ACL "acl_8_8_8"
 >>>  check acl = acl_8_8_8
 >>>   using ACL "acl_8_8_8"
->>>   processing "accept" (TESTSUITE/test-config 88)
+>>>   processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>   check acl = acl_8_8_8
 >>>    using ACL "acl_8_8_8"
 >>>   check acl = acl_8_8_8
 >>>    using ACL "acl_8_8_8"
->>>    processing "accept" (TESTSUITE/test-config 88)
+>>>    processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    check acl = acl_8_8_8
 >>>    ╎using ACL "acl_8_8_8"
 >>>    check acl = acl_8_8_8
 >>>    ╎using ACL "acl_8_8_8"
->>>    ╎processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎check acl = acl_8_8_8
 >>>    ╎ using ACL "acl_8_8_8"
 >>>    ╎check acl = acl_8_8_8
 >>>    ╎ using ACL "acl_8_8_8"
->>>    ╎ processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎ processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎ check acl = acl_8_8_8
 >>>    ╎  using ACL "acl_8_8_8"
 >>>    ╎ check acl = acl_8_8_8
 >>>    ╎  using ACL "acl_8_8_8"
->>>    ╎  processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎  processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎  check acl = acl_8_8_8
 >>>    ╎   using ACL "acl_8_8_8"
 >>>    ╎  check acl = acl_8_8_8
 >>>    ╎   using ACL "acl_8_8_8"
->>>    ╎   processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   check acl = acl_8_8_8
 >>>    ╎   ╎using ACL "acl_8_8_8"
 >>>    ╎   check acl = acl_8_8_8
 >>>    ╎   ╎using ACL "acl_8_8_8"
->>>    ╎   ╎processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎check acl = acl_8_8_8
 >>>    ╎   ╎ using ACL "acl_8_8_8"
 >>>    ╎   ╎check acl = acl_8_8_8
 >>>    ╎   ╎ using ACL "acl_8_8_8"
->>>    ╎   ╎ processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎ processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎ check acl = acl_8_8_8
 >>>    ╎   ╎  using ACL "acl_8_8_8"
 >>>    ╎   ╎ check acl = acl_8_8_8
 >>>    ╎   ╎  using ACL "acl_8_8_8"
->>>    ╎   ╎  processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎  processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎  check acl = acl_8_8_8
 >>>    ╎   ╎   using ACL "acl_8_8_8"
 >>>    ╎   ╎  check acl = acl_8_8_8
 >>>    ╎   ╎   using ACL "acl_8_8_8"
->>>    ╎   ╎   processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   check acl = acl_8_8_8
 >>>    ╎   ╎   ╎using ACL "acl_8_8_8"
 >>>    ╎   ╎   check acl = acl_8_8_8
 >>>    ╎   ╎   ╎using ACL "acl_8_8_8"
->>>    ╎   ╎   ╎processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   ╎processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   ╎check acl = acl_8_8_8
 >>>    ╎   ╎   ╎ using ACL "acl_8_8_8"
 >>>    ╎   ╎   ╎check acl = acl_8_8_8
 >>>    ╎   ╎   ╎ using ACL "acl_8_8_8"
->>>    ╎   ╎   ╎ processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   ╎ processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   ╎ check acl = acl_8_8_8
 >>>    ╎   ╎   ╎  using ACL "acl_8_8_8"
 >>>    ╎   ╎   ╎ check acl = acl_8_8_8
 >>>    ╎   ╎   ╎  using ACL "acl_8_8_8"
->>>    ╎   ╎   ╎  processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   ╎  processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   ╎  check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   using ACL "acl_8_8_8"
 >>>    ╎   ╎   ╎  check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   using ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   ╎   processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   ╎   check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎using ACL "acl_8_8_8"
 >>>    ╎   ╎   ╎   check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎using ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   ╎processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   ╎   ╎processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   ╎   ╎check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎ using ACL "acl_8_8_8"
 >>>    ╎   ╎   ╎   ╎check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎ using ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   ╎ processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   ╎   ╎ processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   ╎   ╎ check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎  using ACL "acl_8_8_8"
 >>>    ╎   ╎   ╎   ╎ check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎  using ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   ╎  processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   ╎   ╎  processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   ╎   ╎  check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎   using ACL "acl_8_8_8"
 >>>    ╎   ╎   ╎   ╎  check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎   using ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   ╎   processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   ╎   ╎   processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   ╎   ╎   check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎   ╎using ACL "acl_8_8_8"
 >>>    ╎   ╎   ╎   ╎   check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎   ╎using ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   ╎   ╎processing "accept" (TESTSUITE/test-config 88)
+>>>    ╎   ╎   ╎   ╎   ╎processing ACL acl_8_8_8 "accept" (TESTSUITE/test-config 88)
 >>>    ╎   ╎   ╎   ╎   ╎check acl = acl_8_8_8
 >>>    ╎   ╎   ╎   ╎   ╎check acl = acl_8_8_8
->>>    ╎   ╎   ╎   ╎   ╎accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   ╎   accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   ╎  accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   ╎ accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   ╎accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎   ╎   accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎   ╎  accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎   ╎ accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎   ╎accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎   accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎  accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎ accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   ╎accept: condition test error in ACL "acl_8_8_8"
->>>    ╎   accept: condition test error in ACL "acl_8_8_8"
->>>    ╎  accept: condition test error in ACL "acl_8_8_8"
->>>    ╎ accept: condition test error in ACL "acl_8_8_8"
->>>    ╎accept: condition test error in ACL "acl_8_8_8"
->>>    accept: condition test error in ACL "acl_8_8_8"
->>>   accept: condition test error in ACL "acl_8_8_8"
->>>  accept: condition test error in ACL "acl_8_8_8"
->>> accept: condition test error in ACL "acl_8_8_8"
+>>>    ╎   ╎   ╎   ╎   ╎accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎   ╎   ╎   accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎   ╎   ╎  accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎   ╎   ╎ accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎   ╎   ╎accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎   ╎   accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎   ╎  accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎   ╎ accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎   ╎accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎   accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎  accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎ accept: condition test error in ACL acl_8_8_8
+>>>    ╎   ╎accept: condition test error in ACL acl_8_8_8
+>>>    ╎   accept: condition test error in ACL acl_8_8_8
+>>>    ╎  accept: condition test error in ACL acl_8_8_8
+>>>    ╎ accept: condition test error in ACL acl_8_8_8
+>>>    ╎accept: condition test error in ACL acl_8_8_8
+>>>    accept: condition test error in ACL acl_8_8_8
+>>>   accept: condition test error in ACL acl_8_8_8
+>>>  accept: condition test error in ACL acl_8_8_8
+>>> accept: condition test error in ACL acl_8_8_8
 LOG: H=(test) [8.8.8.8] F=<x@y> temporarily rejected RCPT <x@y>: ACL nested too deep: possible loop
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [8.8.8.8] F=<x@y> temporarily rejected RCPT <x@y>: ACL nested too deep: possible loop
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -609,47 +889,62 @@ LOG: H=(test) [8.8.8.8] F=<x@y> temporarily rejected RCPT <x@y>: ACL nested too
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_13"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_5_6_13"
->>> processing "accept" (TESTSUITE/test-config 85)
+>>> processing ACL acl_5_6_13 "accept" (TESTSUITE/test-config 85)
 >>> check acl = TESTSUITE/aux-fixed/0023.acl1
 >>>  read ACL from file TESTSUITE/aux-fixed/0023.acl1
 >>> check acl = TESTSUITE/aux-fixed/0023.acl1
 >>>  read ACL from file TESTSUITE/aux-fixed/0023.acl1
->>>  processing "accept" (TESTSUITE/test-config 272)
+>>>  processing ACL TESTSUITE/aux-fixed/0023.acl1 "accept" (TESTSUITE/test-config 85)
 >>>  check domains = y
 >>>  check domains = y
->>>  y in "y"? yes (matched "y")
+>>>  y in "y"?
+>>>   list element: y
+>>>   y in "y"? yes (matched "y")
 >>>  check local_parts = x
 >>>  check local_parts = x
->>>  x in "x"? yes (matched "x")
->>>  accept: condition test succeeded in ACL "TESTSUITE/aux-fixed/0023.acl1"
->>>  end of ACL "TESTSUITE/aux-fixed/0023.acl1": ACCEPT
->>> accept: condition test succeeded in ACL "acl_5_6_13"
->>> end of ACL "acl_5_6_13": ACCEPT
+>>>  x in "x"?
+>>>   list element: x
+>>>   x in "x"? yes (matched "x")
+>>>  accept: condition test succeeded in ACL TESTSUITE/aux-fixed/0023.acl1
+>>>  end of ACL TESTSUITE/aux-fixed/0023.acl1: ACCEPT
+>>> accept: condition test succeeded in ACL acl_5_6_13
+>>> end of ACL acl_5_6_13: ACCEPT
 >>> using ACL "acl_5_6_13"
 >>> using ACL "acl_5_6_13"
->>> processing "accept" (TESTSUITE/test-config 85)
+>>> processing ACL acl_5_6_13 "accept" (TESTSUITE/test-config 85)
 >>> check acl = TESTSUITE/aux-fixed/0023.acl1
 >>>  using ACL "TESTSUITE/aux-fixed/0023.acl1"
 >>> check acl = TESTSUITE/aux-fixed/0023.acl1
 >>>  using ACL "TESTSUITE/aux-fixed/0023.acl1"
->>>  processing "accept" (TESTSUITE/test-config 272)
+>>>  processing ACL TESTSUITE/aux-fixed/0023.acl1 "accept" (TESTSUITE/test-config 85)
 >>>  check domains = y
 >>>  check domains = y
->>>  y in "y"? yes (matched "y")
+>>>  y in "y"?
+>>>   list element: y
+>>>   y in "y"? yes (matched "y")
 >>>  check local_parts = x
 >>>  check local_parts = x
+>>>  x1 in "x"?
+>>>   list element: x
 >>>  x1 in "x"? no (end of list)
 >>>  x1 in "x"? no (end of list)
->>>  accept: condition test failed in ACL "TESTSUITE/aux-fixed/0023.acl1"
->>>  end of ACL "TESTSUITE/aux-fixed/0023.acl1": implicit DENY
->>> accept: condition test failed in ACL "acl_5_6_13"
->>> end of ACL "acl_5_6_13": implicit DENY
+>>>  accept: condition test failed in ACL TESTSUITE/aux-fixed/0023.acl1
+>>>  end of ACL TESTSUITE/aux-fixed/0023.acl1: implicit DENY
+>>> accept: condition test failed in ACL acl_5_6_13
+>>> end of ACL acl_5_6_13: implicit DENY
 LOG: H=(test) [5.6.13.1] F=<x@y> rejected RCPT <x1@y>
 >>> using ACL "acl_5_6_13"
 LOG: H=(test) [5.6.13.1] F=<x@y> rejected RCPT <x1@y>
 >>> using ACL "acl_5_6_13"
->>> processing "accept" (TESTSUITE/test-config 85)
+>>> processing ACL acl_5_6_13 "accept" (TESTSUITE/test-config 85)
 >>> check acl = TESTSUITE/aux-fixed/0023.acl1
 >>>  using ACL "TESTSUITE/aux-fixed/0023.acl1"
 >>> check acl = TESTSUITE/aux-fixed/0023.acl1
 >>>  using ACL "TESTSUITE/aux-fixed/0023.acl1"
->>>  processing "accept" (TESTSUITE/test-config 272)
+>>>  processing ACL TESTSUITE/aux-fixed/0023.acl1 "accept" (TESTSUITE/test-config 85)
 >>>  check domains = y
 >>>  check domains = y
->>>  y in "y"? yes (matched "y")
+>>>  y in "y"?
+>>>   list element: y
+>>>   y in "y"? yes (matched "y")
 >>>  check local_parts = x
 >>>  check local_parts = x
+>>>  x2 in "x"?
+>>>   list element: x
 >>>  x2 in "x"? no (end of list)
 >>>  x2 in "x"? no (end of list)
->>>  accept: condition test failed in ACL "TESTSUITE/aux-fixed/0023.acl1"
->>>  end of ACL "TESTSUITE/aux-fixed/0023.acl1": implicit DENY
->>> accept: condition test failed in ACL "acl_5_6_13"
->>> end of ACL "acl_5_6_13": implicit DENY
+>>>  accept: condition test failed in ACL TESTSUITE/aux-fixed/0023.acl1
+>>>  end of ACL TESTSUITE/aux-fixed/0023.acl1: implicit DENY
+>>> accept: condition test failed in ACL acl_5_6_13
+>>> end of ACL acl_5_6_13: implicit DENY
 LOG: H=(test) [5.6.13.1] F=<x@y> rejected RCPT <x2@y>
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [5.6.13.1] F=<x@y> rejected RCPT <x2@y>
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -659,9 +954,12 @@ LOG: H=(test) [5.6.13.1] F=<x@y> rejected RCPT <x2@y>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_11_12"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_11_12"
->>> processing "deny" (TESTSUITE/test-config 105)
+>>> processing ACL acl_V4NET_11_12 "deny" (TESTSUITE/test-config 105)
 >>>   message: host in DNS list $dnslist_domain: $dnslist_text
 >>> l_message: DNSLIST ($dnslist_domain: $dnslist_text)
 >>> check dnslists = rbl.test.ex
 >>>   message: host in DNS list $dnslist_domain: $dnslist_text
 >>> l_message: DNSLIST ($dnslist_domain: $dnslist_text)
 >>> check dnslists = rbl.test.ex
@@ -670,11 +968,11 @@ LOG: H=(test) [5.6.13.1] F=<x@y> rejected RCPT <x2@y>
 >>> dnslists: wrote cache entry, ttl=3
 >>> DNS lookup for 13.12.11.V4NET.rbl.test.ex succeeded (yielding 127.0.0.2)
 >>> => that means V4NET.11.12.13 is listed at rbl.test.ex
 >>> dnslists: wrote cache entry, ttl=3
 >>> DNS lookup for 13.12.11.V4NET.rbl.test.ex succeeded (yielding 127.0.0.2)
 >>> => that means V4NET.11.12.13 is listed at rbl.test.ex
->>> deny: condition test succeeded in ACL "acl_V4NET_11_12"
->>> end of ACL "acl_V4NET_11_12": DENY
+>>> deny: condition test succeeded in ACL acl_V4NET_11_12
+>>> end of ACL acl_V4NET_11_12: DENY
 LOG: H=(test) [V4NET.11.12.13] F=<x@y> rejected RCPT <x@y>: DNSLIST (rbl.test.ex: This is a test blacklisting message)
 >>> using ACL "acl_V4NET_11_12"
 LOG: H=(test) [V4NET.11.12.13] F=<x@y> rejected RCPT <x@y>: DNSLIST (rbl.test.ex: This is a test blacklisting message)
 >>> using ACL "acl_V4NET_11_12"
->>> processing "deny" (TESTSUITE/test-config 105)
+>>> processing ACL acl_V4NET_11_12 "deny" (TESTSUITE/test-config 105)
 >>>   message: host in DNS list $dnslist_domain: $dnslist_text
 >>> l_message: DNSLIST ($dnslist_domain: $dnslist_text)
 >>> check dnslists = rbl.test.ex
 >>>   message: host in DNS list $dnslist_domain: $dnslist_text
 >>> l_message: DNSLIST ($dnslist_domain: $dnslist_text)
 >>> check dnslists = rbl.test.ex
@@ -682,8 +980,8 @@ LOG: H=(test) [V4NET.11.12.13] F=<x@y> rejected RCPT <x@y>: DNSLIST (rbl.test.ex
 >>> dnslists: using result of previous lookup
 >>> DNS lookup for 13.12.11.V4NET.rbl.test.ex succeeded (yielding 127.0.0.2)
 >>> => that means V4NET.11.12.13 is listed at rbl.test.ex
 >>> dnslists: using result of previous lookup
 >>> DNS lookup for 13.12.11.V4NET.rbl.test.ex succeeded (yielding 127.0.0.2)
 >>> => that means V4NET.11.12.13 is listed at rbl.test.ex
->>> deny: condition test succeeded in ACL "acl_V4NET_11_12"
->>> end of ACL "acl_V4NET_11_12": DENY
+>>> deny: condition test succeeded in ACL acl_V4NET_11_12
+>>> end of ACL acl_V4NET_11_12: DENY
 LOG: H=(test) [V4NET.11.12.13] F=<x@y> rejected RCPT <x1@y>: DNSLIST (rbl.test.ex: This is a test blacklisting message)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [V4NET.11.12.13] F=<x@y> rejected RCPT <x1@y>: DNSLIST (rbl.test.ex: This is a test blacklisting message)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -693,9 +991,12 @@ LOG: H=(test) [V4NET.11.12.13] F=<x@y> rejected RCPT <x1@y>: DNSLIST (rbl.test.e
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_11_12"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_11_12"
->>> processing "deny" (TESTSUITE/test-config 105)
+>>> processing ACL acl_V4NET_11_12 "deny" (TESTSUITE/test-config 105)
 >>>   message: host in DNS list $dnslist_domain: $dnslist_text
 >>> l_message: DNSLIST ($dnslist_domain: $dnslist_text)
 >>> check dnslists = rbl.test.ex
 >>>   message: host in DNS list $dnslist_domain: $dnslist_text
 >>> l_message: DNSLIST ($dnslist_domain: $dnslist_text)
 >>> check dnslists = rbl.test.ex
@@ -704,12 +1005,12 @@ LOG: H=(test) [V4NET.11.12.13] F=<x@y> rejected RCPT <x1@y>: DNSLIST (rbl.test.e
 >>> dnslists: wrote cache entry, ttl=3000
 >>> DNS lookup for 12.12.11.V4NET.rbl.test.ex failed
 >>> => that means V4NET.11.12.12 is not listed at rbl.test.ex
 >>> dnslists: wrote cache entry, ttl=3000
 >>> DNS lookup for 12.12.11.V4NET.rbl.test.ex failed
 >>> => that means V4NET.11.12.12 is not listed at rbl.test.ex
->>> deny: condition test failed in ACL "acl_V4NET_11_12"
->>> processing "accept" (TESTSUITE/test-config 108)
->>> accept: condition test succeeded in ACL "acl_V4NET_11_12"
->>> end of ACL "acl_V4NET_11_12": ACCEPT
+>>> deny: condition test failed in ACL acl_V4NET_11_12
+>>> processing ACL acl_V4NET_11_12 "accept" (TESTSUITE/test-config 108)
+>>> accept: condition test succeeded in ACL acl_V4NET_11_12
+>>> end of ACL acl_V4NET_11_12: ACCEPT
 >>> using ACL "acl_V4NET_11_12"
 >>> using ACL "acl_V4NET_11_12"
->>> processing "deny" (TESTSUITE/test-config 105)
+>>> processing ACL acl_V4NET_11_12 "deny" (TESTSUITE/test-config 105)
 >>>   message: host in DNS list $dnslist_domain: $dnslist_text
 >>> l_message: DNSLIST ($dnslist_domain: $dnslist_text)
 >>> check dnslists = rbl.test.ex
 >>>   message: host in DNS list $dnslist_domain: $dnslist_text
 >>> l_message: DNSLIST ($dnslist_domain: $dnslist_text)
 >>> check dnslists = rbl.test.ex
@@ -717,10 +1018,10 @@ LOG: H=(test) [V4NET.11.12.13] F=<x@y> rejected RCPT <x1@y>: DNSLIST (rbl.test.e
 >>> dnslists: using result of previous lookup
 >>> DNS lookup for 12.12.11.V4NET.rbl.test.ex failed
 >>> => that means V4NET.11.12.12 is not listed at rbl.test.ex
 >>> dnslists: using result of previous lookup
 >>> DNS lookup for 12.12.11.V4NET.rbl.test.ex failed
 >>> => that means V4NET.11.12.12 is not listed at rbl.test.ex
->>> deny: condition test failed in ACL "acl_V4NET_11_12"
->>> processing "accept" (TESTSUITE/test-config 108)
->>> accept: condition test succeeded in ACL "acl_V4NET_11_12"
->>> end of ACL "acl_V4NET_11_12": ACCEPT
+>>> deny: condition test failed in ACL acl_V4NET_11_12
+>>> processing ACL acl_V4NET_11_12 "accept" (TESTSUITE/test-config 108)
+>>> accept: condition test succeeded in ACL acl_V4NET_11_12
+>>> end of ACL acl_V4NET_11_12: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -729,28 +1030,38 @@ LOG: H=(test) [V4NET.11.12.13] F=<x@y> rejected RCPT <x1@y>: DNSLIST (rbl.test.e
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_20_20_20"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_20_20_20"
->>> processing "accept" (TESTSUITE/test-config 111)
+>>> processing ACL acl_20_20_20 "accept" (TESTSUITE/test-config 111)
 >>>   message: sender verify failure
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x@y
 >>>   message: sender verify failure
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x@y
->>> x in "^ok"? no (end of list)
->>> x in "^userx : ^cond-"? no (end of list)
->>> x in "fail"? no (end of list)
+>>> x in local_parts?
+>>>  list element: ^ok
+>>> x in local_parts? no (end of list)
+>>> x in local_parts?
+>>>  list element: ^userx
+>>>  list element: ^cond-
+>>> x in local_parts? no (end of list)
+>>> x in local_parts?
+>>>  list element: fail
+>>> x in local_parts? no (end of list)
 >>> no more routers
 >>> ----------- end verify ------------
 >>> no more routers
 >>> ----------- end verify ------------
->>> accept: condition test failed in ACL "acl_20_20_20"
+>>> accept: condition test failed in ACL acl_20_20_20
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [20.20.20.20] sender verify fail for <x@y>: Unrouteable address
 LOG: H=(test) [20.20.20.20] F=<x@y> rejected RCPT <x1@y>: Sender verify failed
 >>> using ACL "acl_20_20_20"
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [20.20.20.20] sender verify fail for <x@y>: Unrouteable address
 LOG: H=(test) [20.20.20.20] F=<x@y> rejected RCPT <x1@y>: Sender verify failed
 >>> using ACL "acl_20_20_20"
->>> processing "accept" (TESTSUITE/test-config 111)
+>>> processing ACL acl_20_20_20 "accept" (TESTSUITE/test-config 111)
 >>>   message: sender verify failure
 >>> check verify = sender
 >>> using cached sender verify result
 >>>   message: sender verify failure
 >>> check verify = sender
 >>> using cached sender verify result
->>> accept: condition test failed in ACL "acl_20_20_20"
+>>> accept: condition test failed in ACL acl_20_20_20
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [20.20.20.20] F=<x@y> rejected RCPT <x2@y>: Sender verify failed
 >>> host in hosts_connection_nolog? no (option unset)
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [20.20.20.20] F=<x@y> rejected RCPT <x2@y>: Sender verify failed
 >>> host in hosts_connection_nolog? no (option unset)
@@ -761,15 +1072,22 @@ LOG: H=(test) [20.20.20.20] F=<x@y> rejected RCPT <x2@y>: Sender verify failed
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_20_20_20"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_20_20_20"
->>> processing "accept" (TESTSUITE/test-config 111)
+>>> processing ACL acl_20_20_20 "accept" (TESTSUITE/test-config 111)
 >>>   message: sender verify failure
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
 >>>   message: sender verify failure
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
->>> userx in "^ok"? no (end of list)
->>> userx in "^userx : ^cond-"? yes (matched "^userx")
+>>> userx in local_parts?
+>>>  list element: ^ok
+>>> userx in local_parts? no (end of list)
+>>> userx in local_parts?
+>>>  list element: ^userx
+>>>  userx in local_parts? yes (matched "^userx")
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
@@ -777,16 +1095,23 @@ LOG: H=(test) [20.20.20.20] F=<x@y> rejected RCPT <x2@y>: Sender verify failed
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x1@y
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x1@y
->>> x1 in "^ok"? no (end of list)
->>> x1 in "^userx : ^cond-"? no (end of list)
->>> x1 in "fail"? no (end of list)
+>>> x1 in local_parts?
+>>>  list element: ^ok
+>>> x1 in local_parts? no (end of list)
+>>> x1 in local_parts?
+>>>  list element: ^userx
+>>>  list element: ^cond-
+>>> x1 in local_parts? no (end of list)
+>>> x1 in local_parts?
+>>>  list element: fail
+>>> x1 in local_parts? no (end of list)
 >>> no more routers
 >>> ----------- end verify ------------
 >>> no more routers
 >>> ----------- end verify ------------
->>> accept: condition test failed in ACL "acl_20_20_20"
+>>> accept: condition test failed in ACL acl_20_20_20
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [20.20.20.20] F=<userx@y> rejected RCPT <x1@y>: Unrouteable address
 >>> using ACL "acl_20_20_20"
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [20.20.20.20] F=<userx@y> rejected RCPT <x1@y>: Unrouteable address
 >>> using ACL "acl_20_20_20"
->>> processing "accept" (TESTSUITE/test-config 111)
+>>> processing ACL acl_20_20_20 "accept" (TESTSUITE/test-config 111)
 >>>   message: sender verify failure
 >>> check verify = sender
 >>> using cached sender verify result
 >>>   message: sender verify failure
 >>> check verify = sender
 >>> using cached sender verify result
@@ -794,13 +1119,17 @@ LOG: H=(test) [20.20.20.20] F=<userx@y> rejected RCPT <x1@y>: Unrouteable addres
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
->>> userx in "^ok"? no (end of list)
->>> userx in "^userx : ^cond-"? yes (matched "^userx")
+>>> userx in local_parts?
+>>>  list element: ^ok
+>>> userx in local_parts? no (end of list)
+>>> userx in local_parts?
+>>>  list element: ^userx
+>>>  userx in local_parts? yes (matched "^userx")
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
->>> accept: condition test succeeded in ACL "acl_20_20_20"
->>> end of ACL "acl_20_20_20": ACCEPT
+>>> accept: condition test succeeded in ACL acl_20_20_20
+>>> end of ACL acl_20_20_20: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -809,93 +1138,134 @@ LOG: H=(test) [20.20.20.20] F=<userx@y> rejected RCPT <x1@y>: Unrouteable addres
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_21_21_21"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_21_21_21"
->>> processing "accept" (TESTSUITE/test-config 118)
+>>> processing ACL acl_21_21_21 "accept" (TESTSUITE/test-config 118)
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
->>> userx in "^ok"? no (end of list)
->>> userx in "^userx : ^cond-"? yes (matched "^userx")
+>>> userx in local_parts?
+>>>  list element: ^ok
+>>> userx in local_parts? no (end of list)
+>>> userx in local_parts?
+>>>  list element: ^userx
+>>>  userx in local_parts? yes (matched "^userx")
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x1@y
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x1@y
->>> x1 in "^ok"? no (end of list)
->>> x1 in "^userx : ^cond-"? no (end of list)
->>> x1 in "fail"? no (end of list)
+>>> x1 in local_parts?
+>>>  list element: ^ok
+>>> x1 in local_parts? no (end of list)
+>>> x1 in local_parts?
+>>>  list element: ^userx
+>>>  list element: ^cond-
+>>> x1 in local_parts? no (end of list)
+>>> x1 in local_parts?
+>>>  list element: fail
+>>> x1 in local_parts? no (end of list)
 >>> no more routers
 >>> ----------- end verify ------------
 >>> no more routers
 >>> ----------- end verify ------------
->>> accept: condition test failed in ACL "acl_21_21_21"
->>> end of ACL "acl_21_21_21": implicit DENY
+>>> accept: condition test failed in ACL acl_21_21_21
+>>> end of ACL acl_21_21_21: implicit DENY
 LOG: H=(test) [21.21.21.21] F=<userx@y> rejected RCPT <x1@y>: Unrouteable address
 >>> using ACL "acl_21_21_21"
 LOG: H=(test) [21.21.21.21] F=<userx@y> rejected RCPT <x1@y>: Unrouteable address
 >>> using ACL "acl_21_21_21"
->>> processing "accept" (TESTSUITE/test-config 118)
+>>> processing ACL acl_21_21_21 "accept" (TESTSUITE/test-config 118)
 >>> check verify = sender
 >>> using cached sender verify result
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
 >>> check verify = sender
 >>> using cached sender verify result
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
->>> userx in "^ok"? no (end of list)
->>> userx in "^userx : ^cond-"? yes (matched "^userx")
+>>> userx in local_parts?
+>>>  list element: ^ok
+>>> userx in local_parts? no (end of list)
+>>> userx in local_parts?
+>>>  list element: ^userx
+>>>  userx in local_parts? yes (matched "^userx")
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
->>> accept: condition test succeeded in ACL "acl_21_21_21"
->>> end of ACL "acl_21_21_21": ACCEPT
+>>> accept: condition test succeeded in ACL acl_21_21_21
+>>> end of ACL acl_21_21_21: ACCEPT
 >>> using ACL "acl_21_21_21"
 >>> using ACL "acl_21_21_21"
->>> processing "accept" (TESTSUITE/test-config 118)
+>>> processing ACL acl_21_21_21 "accept" (TESTSUITE/test-config 118)
 >>> check verify = sender
 >>> using cached sender verify result
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing fail@y
 >>> check verify = sender
 >>> using cached sender verify result
 >>> check verify = recipient
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing fail@y
->>> fail in "^ok"? no (end of list)
->>> fail in "^userx : ^cond-"? no (end of list)
->>> fail in "fail"? yes (matched "fail")
+>>> fail in local_parts?
+>>>  list element: ^ok
+>>> fail in local_parts? no (end of list)
+>>> fail in local_parts?
+>>>  list element: ^userx
+>>>  list element: ^cond-
+>>> fail in local_parts? no (end of list)
+>>> fail in local_parts?
+>>>  list element: fail
+>>>  fail in local_parts? yes (matched "fail")
 >>> calling r2 router
 >>> r2 router forced address failure
 >>> ----------- end verify ------------
 >>> calling r2 router
 >>> r2 router forced address failure
 >>> ----------- end verify ------------
->>> accept: condition test failed in ACL "acl_21_21_21"
->>> end of ACL "acl_21_21_21": implicit DENY
+>>> accept: condition test failed in ACL acl_21_21_21
+>>> end of ACL acl_21_21_21: implicit DENY
 LOG: H=(test) [21.21.21.21] F=<userx@y> rejected RCPT <fail@y>: here is a fail message
 >>> using ACL "acl_21_21_21"
 LOG: H=(test) [21.21.21.21] F=<userx@y> rejected RCPT <fail@y>: here is a fail message
 >>> using ACL "acl_21_21_21"
->>> processing "accept" (TESTSUITE/test-config 118)
+>>> processing ACL acl_21_21_21 "accept" (TESTSUITE/test-config 118)
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x@y
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x@y
->>> x in "^ok"? no (end of list)
->>> x in "^userx : ^cond-"? no (end of list)
->>> x in "fail"? no (end of list)
+>>> x in local_parts?
+>>>  list element: ^ok
+>>> x in local_parts? no (end of list)
+>>> x in local_parts?
+>>>  list element: ^userx
+>>>  list element: ^cond-
+>>> x in local_parts? no (end of list)
+>>> x in local_parts?
+>>>  list element: fail
+>>> x in local_parts? no (end of list)
 >>> no more routers
 >>> ----------- end verify ------------
 >>> no more routers
 >>> ----------- end verify ------------
->>> accept: condition test failed in ACL "acl_21_21_21"
->>> end of ACL "acl_21_21_21": implicit DENY
+>>> accept: condition test failed in ACL acl_21_21_21
+>>> end of ACL acl_21_21_21: implicit DENY
 LOG: H=(test) [21.21.21.21] sender verify fail for <x@y>: Unrouteable address
 LOG: H=(test) [21.21.21.21] F=<x@y> rejected RCPT <x1@y>: Sender verify failed
 >>> using ACL "acl_21_21_21"
 LOG: H=(test) [21.21.21.21] sender verify fail for <x@y>: Unrouteable address
 LOG: H=(test) [21.21.21.21] F=<x@y> rejected RCPT <x1@y>: Sender verify failed
 >>> using ACL "acl_21_21_21"
->>> processing "accept" (TESTSUITE/test-config 118)
+>>> processing ACL acl_21_21_21 "accept" (TESTSUITE/test-config 118)
 >>> check verify = sender
 >>> using cached sender verify result
 >>> check verify = sender
 >>> using cached sender verify result
->>> accept: condition test failed in ACL "acl_21_21_21"
->>> end of ACL "acl_21_21_21": implicit DENY
+>>> accept: condition test failed in ACL acl_21_21_21
+>>> end of ACL acl_21_21_21: implicit DENY
 LOG: H=(test) [21.21.21.21] F=<x@y> rejected RCPT <x2@y>: Sender verify failed
 LOG: H=(test) [21.21.21.21] F=<x@y> rejected RCPT <x2@y>: Sender verify failed
->>> host in smtp_accept_max_nonmail_hosts? yes (matched "*")
+>>> host in smtp_accept_max_nonmail_hosts?
+>>>  list element: *
+>>>  host in smtp_accept_max_nonmail_hosts? yes (matched "*")
 >>> using ACL "acl_21_21_21"
 >>> using ACL "acl_21_21_21"
->>> processing "accept" (TESTSUITE/test-config 118)
+>>> processing ACL acl_21_21_21 "accept" (TESTSUITE/test-config 118)
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing fail@y
 >>> check verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing fail@y
->>> fail in "^ok"? no (end of list)
->>> fail in "^userx : ^cond-"? no (end of list)
->>> fail in "fail"? yes (matched "fail")
+>>> fail in local_parts?
+>>>  list element: ^ok
+>>> fail in local_parts? no (end of list)
+>>> fail in local_parts?
+>>>  list element: ^userx
+>>>  list element: ^cond-
+>>> fail in local_parts? no (end of list)
+>>> fail in local_parts?
+>>>  list element: fail
+>>>  fail in local_parts? yes (matched "fail")
 >>> calling r2 router
 >>> r2 router forced address failure
 >>> ----------- end verify ------------
 >>> calling r2 router
 >>> r2 router forced address failure
 >>> ----------- end verify ------------
->>> accept: condition test failed in ACL "acl_21_21_21"
->>> end of ACL "acl_21_21_21": implicit DENY
+>>> accept: condition test failed in ACL acl_21_21_21
+>>> end of ACL acl_21_21_21: implicit DENY
 LOG: H=(test) [21.21.21.21] sender verify fail for <fail@y>: here is a fail message
 LOG: H=(test) [21.21.21.21] F=<fail@y> rejected RCPT <x@y>: Sender verify failed
 >>> host in hosts_connection_nolog? no (option unset)
 LOG: H=(test) [21.21.21.21] sender verify fail for <fail@y>: here is a fail message
 LOG: H=(test) [21.21.21.21] F=<fail@y> rejected RCPT <x@y>: Sender verify failed
 >>> host in hosts_connection_nolog? no (option unset)
@@ -906,21 +1276,30 @@ LOG: H=(test) [21.21.21.21] F=<fail@y> rejected RCPT <x@y>: Sender verify failed
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_22_22_22"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_22_22_22"
->>> processing "accept" (TESTSUITE/test-config 123)
+>>> processing ACL acl_22_22_22 "accept" (TESTSUITE/test-config 123)
 >>> check recipients = x@y
 >>> check recipients = x@y
+>>> userx@y in "x@y"?
+>>>  list element: x@y
 >>> userx@y in "x@y"? no (end of list)
 >>> userx@y in "x@y"? no (end of list)
->>> accept: condition test failed in ACL "acl_22_22_22"
->>> end of ACL "acl_22_22_22": implicit DENY
+>>> accept: condition test failed in ACL acl_22_22_22
+>>> end of ACL acl_22_22_22: implicit DENY
 LOG: H=(test) [22.22.22.22] F=<userx@y> rejected RCPT <userx@y>
 >>> using ACL "acl_22_22_22"
 LOG: H=(test) [22.22.22.22] F=<userx@y> rejected RCPT <userx@y>
 >>> using ACL "acl_22_22_22"
->>> processing "accept" (TESTSUITE/test-config 123)
+>>> processing ACL acl_22_22_22 "accept" (TESTSUITE/test-config 123)
 >>> check recipients = x@y
 >>> check recipients = x@y
->>> y in "y"? yes (matched "y")
->>> x@y in "x@y"? yes (matched "x@y")
->>> accept: condition test succeeded in ACL "acl_22_22_22"
->>> end of ACL "acl_22_22_22": ACCEPT
+>>> x@y in "x@y"?
+>>>  list element: x@y
+>>>  y in "y"?
+>>>   list element: y
+>>>   y in "y"? yes (matched "y")
+>>>  x@y in "x@y"? yes (matched "x@y")
+>>> accept: condition test succeeded in ACL acl_22_22_22
+>>> end of ACL acl_22_22_22: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -929,41 +1308,59 @@ LOG: H=(test) [22.22.22.22] F=<userx@y> rejected RCPT <userx@y>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_23_23_23"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_23_23_23"
->>> processing "deny" (TESTSUITE/test-config 126)
+>>> processing ACL acl_23_23_23 "deny" (TESTSUITE/test-config 126)
 >>> check hosts = 23.23.23.0
 >>> check hosts = 23.23.23.0
->>> host in "23.23.23.0"? yes (matched "23.23.23.0")
+>>> host in "23.23.23.0"?
+>>>  list element: 23.23.23.0
+>>>  host in "23.23.23.0"? yes (matched "23.23.23.0")
 >>>   message: sender must verify
 >>> check !verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x@y
 >>>   message: sender must verify
 >>> check !verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x@y
->>> x in "^ok"? no (end of list)
->>> x in "^userx : ^cond-"? no (end of list)
->>> x in "fail"? no (end of list)
+>>> x in local_parts?
+>>>  list element: ^ok
+>>> x in local_parts? no (end of list)
+>>> x in local_parts?
+>>>  list element: ^userx
+>>>  list element: ^cond-
+>>> x in local_parts? no (end of list)
+>>> x in local_parts?
+>>>  list element: fail
+>>> x in local_parts? no (end of list)
 >>> no more routers
 >>> ----------- end verify ------------
 >>> no more routers
 >>> ----------- end verify ------------
->>> deny: condition test succeeded in ACL "acl_23_23_23"
->>> end of ACL "acl_23_23_23": DENY
+>>> deny: condition test succeeded in ACL acl_23_23_23
+>>> end of ACL acl_23_23_23: DENY
 LOG: H=(test) [23.23.23.0] sender verify fail for <x@y>: Unrouteable address
 LOG: H=(test) [23.23.23.0] F=<x@y> rejected RCPT <userx@y>: Sender verify failed
 >>> using ACL "acl_23_23_23"
 LOG: H=(test) [23.23.23.0] sender verify fail for <x@y>: Unrouteable address
 LOG: H=(test) [23.23.23.0] F=<x@y> rejected RCPT <userx@y>: Sender verify failed
 >>> using ACL "acl_23_23_23"
->>> processing "deny" (TESTSUITE/test-config 126)
+>>> processing ACL acl_23_23_23 "deny" (TESTSUITE/test-config 126)
 >>> check hosts = 23.23.23.0
 >>> check hosts = 23.23.23.0
->>> host in "23.23.23.0"? yes (matched "23.23.23.0")
+>>> host in "23.23.23.0"?
+>>>  list element: 23.23.23.0
+>>>  host in "23.23.23.0"? yes (matched "23.23.23.0")
 >>>   message: sender must verify
 >>> check !verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
 >>>   message: sender must verify
 >>> check !verify = sender
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing userx@y
->>> userx in "^ok"? no (end of list)
->>> userx in "^userx : ^cond-"? yes (matched "^userx")
+>>> userx in local_parts?
+>>>  list element: ^ok
+>>> userx in local_parts? no (end of list)
+>>> userx in local_parts?
+>>>  list element: ^userx
+>>>  userx in local_parts? yes (matched "^userx")
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
 >>> calling r1 router
 >>> routed by r1 router
 >>> ----------- end verify ------------
->>> deny: condition test failed in ACL "acl_23_23_23"
->>> processing "accept" (TESTSUITE/test-config 129)
->>> accept: condition test succeeded in ACL "acl_23_23_23"
->>> end of ACL "acl_23_23_23": ACCEPT
+>>> deny: condition test failed in ACL acl_23_23_23
+>>> processing ACL acl_23_23_23 "accept" (TESTSUITE/test-config 129)
+>>> accept: condition test succeeded in ACL acl_23_23_23
+>>> end of ACL acl_23_23_23: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -972,15 +1369,20 @@ LOG: H=(test) [23.23.23.0] F=<x@y> rejected RCPT <userx@y>: Sender verify failed
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_23_23_23"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_23_23_23"
->>> processing "deny" (TESTSUITE/test-config 126)
+>>> processing ACL acl_23_23_23 "deny" (TESTSUITE/test-config 126)
 >>> check hosts = 23.23.23.0
 >>> check hosts = 23.23.23.0
+>>> host in "23.23.23.0"?
+>>>  list element: 23.23.23.0
 >>> host in "23.23.23.0"? no (end of list)
 >>> host in "23.23.23.0"? no (end of list)
->>> deny: condition test failed in ACL "acl_23_23_23"
->>> processing "accept" (TESTSUITE/test-config 129)
->>> accept: condition test succeeded in ACL "acl_23_23_23"
->>> end of ACL "acl_23_23_23": ACCEPT
+>>> deny: condition test failed in ACL acl_23_23_23
+>>> processing ACL acl_23_23_23 "accept" (TESTSUITE/test-config 129)
+>>> accept: condition test succeeded in ACL acl_23_23_23
+>>> end of ACL acl_23_23_23: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -989,13 +1391,16 @@ LOG: H=(test) [23.23.23.0] F=<x@y> rejected RCPT <userx@y>: Sender verify failed
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_24_24_24"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_24_24_24"
->>> processing "warn" (TESTSUITE/test-config 132)
+>>> processing ACL acl_24_24_24 "warn" (TESTSUITE/test-config 132)
 >>>   message: X-Warn: sender didn't verify
 >>> check condition = yes
 >>>   message: X-Warn: sender didn't verify
 >>> check condition = yes
->>> warn: condition test succeeded in ACL "acl_24_24_24"
->>> end of ACL "acl_24_24_24": implicit DENY
+>>> warn: condition test succeeded in ACL acl_24_24_24
+>>> end of ACL acl_24_24_24: implicit DENY
 LOG: H=(test) [24.24.24.24] F=<x@y> rejected RCPT <userx@y>
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [24.24.24.24] F=<x@y> rejected RCPT <userx@y>
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -1005,14 +1410,19 @@ LOG: H=(test) [24.24.24.24] F=<x@y> rejected RCPT <userx@y>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_25_25_25"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_25_25_25"
->>> processing "deny" (TESTSUITE/test-config 136)
+>>> processing ACL acl_25_25_25 "deny" (TESTSUITE/test-config 136)
 >>>   message: denying domains=x
 >>> check domains = x
 >>>   message: denying domains=x
 >>> check domains = x
+>>> y in "x"?
+>>>  list element: x
 >>> y in "x"? no (end of list)
 >>> y in "x"? no (end of list)
->>> deny: condition test failed in ACL "acl_25_25_25"
->>> end of ACL "acl_25_25_25": implicit DENY
+>>> deny: condition test failed in ACL acl_25_25_25
+>>> end of ACL acl_25_25_25: implicit DENY
 LOG: H=(test) [25.25.25.25] F=<x@y> rejected RCPT <x@y>
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [25.25.25.25] F=<x@y> rejected RCPT <x@y>
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -1022,37 +1432,46 @@ LOG: H=(test) [25.25.25.25] F=<x@y> rejected RCPT <x@y>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_26_26_26"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_26_26_26"
->>> processing "deny" (TESTSUITE/test-config 140)
+>>> processing ACL acl_26_26_26 "deny" (TESTSUITE/test-config 140)
 >>> check senders = :
 >>> check senders = :
->>>  in ":"? yes (matched "")
+>>>  in ":"?
+>>>  list element: 
+>>>   in ":"? yes (matched "")
 >>>   message: bounce messages can have only one recipient
 >>> check condition = ${if > {$recipients_count}{0}{yes}{no}}
 >>>                 = no
 >>>   message: bounce messages can have only one recipient
 >>> check condition = ${if > {$recipients_count}{0}{yes}{no}}
 >>>                 = no
->>> deny: condition test failed in ACL "acl_26_26_26"
->>> processing "accept" (TESTSUITE/test-config 143)
->>> accept: condition test succeeded in ACL "acl_26_26_26"
->>> end of ACL "acl_26_26_26": ACCEPT
+>>> deny: condition test failed in ACL acl_26_26_26
+>>> processing ACL acl_26_26_26 "accept" (TESTSUITE/test-config 143)
+>>> accept: condition test succeeded in ACL acl_26_26_26
+>>> end of ACL acl_26_26_26: ACCEPT
 >>> using ACL "acl_26_26_26"
 >>> using ACL "acl_26_26_26"
->>> processing "deny" (TESTSUITE/test-config 140)
+>>> processing ACL acl_26_26_26 "deny" (TESTSUITE/test-config 140)
 >>> check senders = :
 >>> check senders = :
->>>  in ":"? yes (matched "")
+>>>  in ":"?
+>>>  list element: 
+>>>   in ":"? yes (matched "")
 >>>   message: bounce messages can have only one recipient
 >>> check condition = ${if > {$recipients_count}{0}{yes}{no}}
 >>>                 = yes
 >>>   message: bounce messages can have only one recipient
 >>> check condition = ${if > {$recipients_count}{0}{yes}{no}}
 >>>                 = yes
->>> deny: condition test succeeded in ACL "acl_26_26_26"
->>> end of ACL "acl_26_26_26": DENY
+>>> deny: condition test succeeded in ACL acl_26_26_26
+>>> end of ACL acl_26_26_26: DENY
 LOG: H=(test) [26.26.26.26] F=<> rejected RCPT <y@y>: bounce messages can have only one recipient
 >>> using ACL "acl_26_26_26"
 LOG: H=(test) [26.26.26.26] F=<> rejected RCPT <y@y>: bounce messages can have only one recipient
 >>> using ACL "acl_26_26_26"
->>> processing "deny" (TESTSUITE/test-config 140)
+>>> processing ACL acl_26_26_26 "deny" (TESTSUITE/test-config 140)
 >>> check senders = :
 >>> check senders = :
->>>  in ":"? yes (matched "")
+>>>  in ":"?
+>>>  list element: 
+>>>   in ":"? yes (matched "")
 >>>   message: bounce messages can have only one recipient
 >>> check condition = ${if > {$recipients_count}{0}{yes}{no}}
 >>>                 = yes
 >>>   message: bounce messages can have only one recipient
 >>> check condition = ${if > {$recipients_count}{0}{yes}{no}}
 >>>                 = yes
->>> deny: condition test succeeded in ACL "acl_26_26_26"
->>> end of ACL "acl_26_26_26": DENY
+>>> deny: condition test succeeded in ACL acl_26_26_26
+>>> end of ACL acl_26_26_26: DENY
 LOG: H=(test) [26.26.26.26] F=<> rejected RCPT <z@y>: bounce messages can have only one recipient
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [26.26.26.26] F=<> rejected RCPT <z@y>: bounce messages can have only one recipient
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -1062,15 +1481,18 @@ LOG: H=(test) [26.26.26.26] F=<> rejected RCPT <z@y>: bounce messages can have o
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_27_27_27"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_27_27_27"
->>> processing "deny" (TESTSUITE/test-config 147)
+>>> processing ACL acl_27_27_27 "deny" (TESTSUITE/test-config 147)
 >>> check hosts = ${if eq {1}{0}{}fail}
 >>> expansion of "${if eq {1}{0}{}fail}" forced failure: assume not in this list
 >>> check hosts = ${if eq {1}{0}{}fail}
 >>> expansion of "${if eq {1}{0}{}fail}" forced failure: assume not in this list
->>> deny: condition test failed in ACL "acl_27_27_27"
->>> processing "accept" (TESTSUITE/test-config 148)
->>> accept: condition test succeeded in ACL "acl_27_27_27"
->>> end of ACL "acl_27_27_27": ACCEPT
+>>> deny: condition test failed in ACL acl_27_27_27
+>>> processing ACL acl_27_27_27 "accept" (TESTSUITE/test-config 148)
+>>> accept: condition test succeeded in ACL acl_27_27_27
+>>> end of ACL acl_27_27_27: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -1079,26 +1501,39 @@ LOG: H=(test) [26.26.26.26] F=<> rejected RCPT <z@y>: bounce messages can have o
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_28_28_28"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_28_28_28"
->>> processing "accept" (TESTSUITE/test-config 151)
+>>> processing ACL acl_28_28_28 "accept" (TESTSUITE/test-config 151)
 >>> check sender_domains = : okdomain
 >>> check sender_domains = : okdomain
->>>  in ": okdomain"? yes (matched "")
->>> accept: condition test succeeded in ACL "acl_28_28_28"
->>> end of ACL "acl_28_28_28": ACCEPT
+>>>  in ": okdomain"?
+>>>  list element: 
+>>>   in ": okdomain"? yes (matched "")
+>>> accept: condition test succeeded in ACL acl_28_28_28
+>>> end of ACL acl_28_28_28: ACCEPT
 >>> using ACL "acl_28_28_28"
 >>> using ACL "acl_28_28_28"
->>> processing "accept" (TESTSUITE/test-config 151)
+>>> processing ACL acl_28_28_28 "accept" (TESTSUITE/test-config 151)
 >>> check sender_domains = : okdomain
 >>> check sender_domains = : okdomain
->>> okdomain in ": okdomain"? yes (matched "okdomain")
->>> accept: condition test succeeded in ACL "acl_28_28_28"
->>> end of ACL "acl_28_28_28": ACCEPT
->>> host in smtp_accept_max_nonmail_hosts? yes (matched "*")
+>>> okdomain in ": okdomain"?
+>>>  list element: 
+>>>  list element: okdomain
+>>>  okdomain in ": okdomain"? yes (matched "okdomain")
+>>> accept: condition test succeeded in ACL acl_28_28_28
+>>> end of ACL acl_28_28_28: ACCEPT
+>>> host in smtp_accept_max_nonmail_hosts?
+>>>  list element: *
+>>>  host in smtp_accept_max_nonmail_hosts? yes (matched "*")
 >>> using ACL "acl_28_28_28"
 >>> using ACL "acl_28_28_28"
->>> processing "accept" (TESTSUITE/test-config 151)
+>>> processing ACL acl_28_28_28 "accept" (TESTSUITE/test-config 151)
 >>> check sender_domains = : okdomain
 >>> check sender_domains = : okdomain
+>>> baddomain in ": okdomain"?
+>>>  list element: 
+>>>  list element: okdomain
 >>> baddomain in ": okdomain"? no (end of list)
 >>> baddomain in ": okdomain"? no (end of list)
->>> accept: condition test failed in ACL "acl_28_28_28"
->>> end of ACL "acl_28_28_28": implicit DENY
+>>> accept: condition test failed in ACL acl_28_28_28
+>>> end of ACL acl_28_28_28: implicit DENY
 LOG: H=(test) [28.28.28.28] F=<a@baddomain> rejected RCPT <x@y>
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [28.28.28.28] F=<a@baddomain> rejected RCPT <x@y>
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -1108,22 +1543,33 @@ LOG: H=(test) [28.28.28.28] F=<a@baddomain> rejected RCPT <x@y>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_0_0"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_0_0"
->>> processing "require" (TESTSUITE/test-config 97)
+>>> processing ACL acl_V4NET_0_0 "require" (TESTSUITE/test-config 97)
 >>> check verify = reverse_host_lookup
 >>> looking up host name to force name/address consistency check
 >>> looking up host name for V4NET.0.0.3
 >>> IP address lookup yielded "ten-3.test.ex"
 >>>   alias "ten-3-alias.test.ex"
 >>> check verify = reverse_host_lookup
 >>> looking up host name to force name/address consistency check
 >>> looking up host name for V4NET.0.0.3
 >>> IP address lookup yielded "ten-3.test.ex"
 >>>   alias "ten-3-alias.test.ex"
+>>>  check dnssec require list
+>>>   ten-3.test.ex not in empty list (option unset? cannot trace name)
+>>>  check dnssec request list
+>>>   ten-3.test.ex not in empty list (option unset? cannot trace name)
 >>> checking addresses for ten-3.test.ex
 >>>   V4NET.0.0.3 OK
 >>> checking addresses for ten-3.test.ex
 >>>   V4NET.0.0.3 OK
+>>>  check dnssec require list
+>>>   ten-3-alias.test.ex not in empty list (option unset? cannot trace name)
+>>>  check dnssec request list
+>>>   ten-3-alias.test.ex not in empty list (option unset? cannot trace name)
 >>> checking addresses for ten-3-alias.test.ex
 >>>   V4NET.0.0.3 OK
 >>> checking addresses for ten-3-alias.test.ex
 >>>   V4NET.0.0.3 OK
->>> require: condition test succeeded in ACL "acl_V4NET_0_0"
->>> processing "accept" (TESTSUITE/test-config 98)
->>> accept: condition test succeeded in ACL "acl_V4NET_0_0"
->>> end of ACL "acl_V4NET_0_0": ACCEPT
+>>> require: condition test succeeded in ACL acl_V4NET_0_0
+>>> processing ACL acl_V4NET_0_0 "accept" (TESTSUITE/test-config 98)
+>>> accept: condition test succeeded in ACL acl_V4NET_0_0
+>>> end of ACL acl_V4NET_0_0: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -1132,15 +1578,18 @@ LOG: H=(test) [28.28.28.28] F=<a@baddomain> rejected RCPT <x@y>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_0_0"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_0_0"
->>> processing "require" (TESTSUITE/test-config 97)
+>>> processing ACL acl_V4NET_0_0 "require" (TESTSUITE/test-config 97)
 >>> check verify = reverse_host_lookup
 >>> looking up host name to force name/address consistency check
 >>> looking up host name for V4NET.0.0.97
 LOG: no host name found for IP address V4NET.0.0.97
 >>> check verify = reverse_host_lookup
 >>> looking up host name to force name/address consistency check
 >>> looking up host name for V4NET.0.0.97
 LOG: no host name found for IP address V4NET.0.0.97
->>> require: condition test failed in ACL "acl_V4NET_0_0"
->>> end of ACL "acl_V4NET_0_0": not OK
+>>> require: condition test failed in ACL acl_V4NET_0_0
+>>> end of ACL acl_V4NET_0_0: not OK
 LOG: H=(test) [V4NET.0.0.97] F=<> rejected RCPT <x@y>: host lookup failed for reverse lookup check (failed to find host name from IP address)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [V4NET.0.0.97] F=<> rejected RCPT <x@y>: host lookup failed for reverse lookup check (failed to find host name from IP address)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -1150,20 +1599,29 @@ LOG: H=(test) [V4NET.0.0.97] F=<> rejected RCPT <x@y>: host lookup failed for re
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_99_99"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_99_99"
->>> processing "accept" (TESTSUITE/test-config 100)
+>>> processing ACL acl_V4NET_99_99 "accept" (TESTSUITE/test-config 100)
 >>> check local_parts = defer_ok
 >>> check local_parts = defer_ok
+>>> x in "defer_ok"?
+>>>  list element: defer_ok
 >>> x in "defer_ok"? no (end of list)
 >>> x in "defer_ok"? no (end of list)
->>> accept: condition test failed in ACL "acl_V4NET_99_99"
->>> processing "accept" (TESTSUITE/test-config 102)
+>>> accept: condition test failed in ACL acl_V4NET_99_99
+>>> processing ACL acl_V4NET_99_99 "accept" (TESTSUITE/test-config 102)
 >>> check verify = reverse_host_lookup
 >>> looking up host name to force name/address consistency check
 >>> looking up host name for V4NET.99.99.96
 >>> IP address lookup yielded "x.test.again.dns"
 >>> check verify = reverse_host_lookup
 >>> looking up host name to force name/address consistency check
 >>> looking up host name for V4NET.99.99.96
 >>> IP address lookup yielded "x.test.again.dns"
->>> x.test.again.dns in dns_again_means_nonexist? no (option unset)
+>>>  check dnssec require list
+>>>   x.test.again.dns not in empty list (option unset? cannot trace name)
+>>>  check dnssec request list
+>>>   x.test.again.dns not in empty list (option unset? cannot trace name)
+>>>  x.test.again.dns in dns_again_means_nonexist? no (option unset)
 >>> temporary error for host name lookup
 >>> temporary error for host name lookup
->>> accept: condition test deferred in ACL "acl_V4NET_99_99"
+>>> accept: condition test deferred in ACL acl_V4NET_99_99
 LOG: H=(test) [V4NET.99.99.96] F=<> temporarily rejected RCPT <x@y>: host lookup deferred for reverse lookup check
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [V4NET.99.99.96] F=<> temporarily rejected RCPT <x@y>: host lookup deferred for reverse lookup check
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -1173,19 +1631,28 @@ LOG: H=(test) [V4NET.99.99.96] F=<> temporarily rejected RCPT <x@y>: host lookup
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_99_99"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_V4NET_99_99"
->>> processing "accept" (TESTSUITE/test-config 100)
+>>> processing ACL acl_V4NET_99_99 "accept" (TESTSUITE/test-config 100)
 >>> check local_parts = defer_ok
 >>> check local_parts = defer_ok
->>> defer_ok in "defer_ok"? yes (matched "defer_ok")
+>>> defer_ok in "defer_ok"?
+>>>  list element: defer_ok
+>>>  defer_ok in "defer_ok"? yes (matched "defer_ok")
 >>> check verify = reverse_host_lookup/defer_ok
 >>> looking up host name to force name/address consistency check
 >>> looking up host name for V4NET.99.99.96
 >>> IP address lookup yielded "x.test.again.dns"
 >>> check verify = reverse_host_lookup/defer_ok
 >>> looking up host name to force name/address consistency check
 >>> looking up host name for V4NET.99.99.96
 >>> IP address lookup yielded "x.test.again.dns"
->>> x.test.again.dns in dns_again_means_nonexist? no (option unset)
+>>>  check dnssec require list
+>>>   x.test.again.dns not in empty list (option unset? cannot trace name)
+>>>  check dnssec request list
+>>>   x.test.again.dns not in empty list (option unset? cannot trace name)
+>>>  x.test.again.dns in dns_again_means_nonexist? no (option unset)
 >>> temporary error for host name lookup
 >>> temporary error for host name lookup
->>> accept: condition test succeeded in ACL "acl_V4NET_99_99"
->>> end of ACL "acl_V4NET_99_99": ACCEPT
+>>> accept: condition test succeeded in ACL acl_V4NET_99_99
+>>> end of ACL acl_V4NET_99_99: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -1194,9 +1661,12 @@ LOG: H=(test) [V4NET.99.99.96] F=<> temporarily rejected RCPT <x@y>: host lookup
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_29_29_29"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_29_29_29"
->>> processing "deny" (TESTSUITE/test-config 154)
+>>> processing ACL acl_29_29_29 "deny" (TESTSUITE/test-config 154)
 >>> check dnslists = test.ex/$sender_address_domain
 >>>                = test.ex/localhost
 >>> dnslists check: test.ex/localhost
 >>> check dnslists = test.ex/$sender_address_domain
 >>>                = test.ex/localhost
 >>> dnslists check: test.ex/localhost
@@ -1204,11 +1674,11 @@ LOG: H=(test) [V4NET.99.99.96] F=<> temporarily rejected RCPT <x@y>: host lookup
 >>> dnslists: wrote cache entry, ttl=3600
 >>> DNS lookup for localhost.test.ex succeeded (yielding 127.0.0.1)
 >>> => that means localhost is listed at test.ex
 >>> dnslists: wrote cache entry, ttl=3600
 >>> DNS lookup for localhost.test.ex succeeded (yielding 127.0.0.1)
 >>> => that means localhost is listed at test.ex
->>> deny: condition test succeeded in ACL "acl_29_29_29"
->>> end of ACL "acl_29_29_29": DENY
+>>> deny: condition test succeeded in ACL acl_29_29_29
+>>> end of ACL acl_29_29_29: DENY
 LOG: H=(test) [29.29.29.29] F=<a@localhost> rejected RCPT <x@y>
 >>> using ACL "acl_29_29_29"
 LOG: H=(test) [29.29.29.29] F=<a@localhost> rejected RCPT <x@y>
 >>> using ACL "acl_29_29_29"
->>> processing "deny" (TESTSUITE/test-config 154)
+>>> processing ACL acl_29_29_29 "deny" (TESTSUITE/test-config 154)
 >>> check dnslists = test.ex/$sender_address_domain
 >>>                = test.ex/elsewhere
 >>> dnslists check: test.ex/elsewhere
 >>> check dnslists = test.ex/$sender_address_domain
 >>>                = test.ex/elsewhere
 >>> dnslists check: test.ex/elsewhere
@@ -1216,10 +1686,10 @@ LOG: H=(test) [29.29.29.29] F=<a@localhost> rejected RCPT <x@y>
 >>> dnslists: wrote cache entry, ttl=3000
 >>> DNS lookup for elsewhere.test.ex failed
 >>> => that means elsewhere is not listed at test.ex
 >>> dnslists: wrote cache entry, ttl=3000
 >>> DNS lookup for elsewhere.test.ex failed
 >>> => that means elsewhere is not listed at test.ex
->>> deny: condition test failed in ACL "acl_29_29_29"
->>> processing "accept" (TESTSUITE/test-config 155)
->>> accept: condition test succeeded in ACL "acl_29_29_29"
->>> end of ACL "acl_29_29_29": ACCEPT
+>>> deny: condition test failed in ACL acl_29_29_29
+>>> processing ACL acl_29_29_29 "accept" (TESTSUITE/test-config 155)
+>>> accept: condition test succeeded in ACL acl_29_29_29
+>>> end of ACL acl_29_29_29: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -1228,9 +1698,12 @@ LOG: H=(test) [29.29.29.29] F=<a@localhost> rejected RCPT <x@y>
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_30_30_30"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_30_30_30"
->>> processing "deny" (TESTSUITE/test-config 161)
+>>> processing ACL acl_30_30_30 "deny" (TESTSUITE/test-config 161)
 >>>   message: domain=$dnslist_domain\nvalue=$dnslist_value\nmatched=$dnslist_matched\ntext="$dnslist_text"
 >>> check dnslists = test.ex=V4NET.0.0.1,127.0.0.2/$sender_address_domain
 >>>                = test.ex=V4NET.0.0.1,127.0.0.2/ten-1
 >>>   message: domain=$dnslist_domain\nvalue=$dnslist_value\nmatched=$dnslist_matched\ntext="$dnslist_text"
 >>> check dnslists = test.ex=V4NET.0.0.1,127.0.0.2/$sender_address_domain
 >>>                = test.ex=V4NET.0.0.1,127.0.0.2/ten-1
@@ -1239,11 +1712,11 @@ LOG: H=(test) [29.29.29.29] F=<a@localhost> rejected RCPT <x@y>
 >>> dnslists: wrote cache entry, ttl=3600
 >>> DNS lookup for ten-1.test.ex succeeded (yielding V4NET.0.0.1)
 >>> => that means ten-1 is listed at test.ex
 >>> dnslists: wrote cache entry, ttl=3600
 >>> DNS lookup for ten-1.test.ex succeeded (yielding V4NET.0.0.1)
 >>> => that means ten-1 is listed at test.ex
->>> deny: condition test succeeded in ACL "acl_30_30_30"
->>> end of ACL "acl_30_30_30": DENY
+>>> deny: condition test succeeded in ACL acl_30_30_30
+>>> end of ACL acl_30_30_30: DENY
 LOG: H=(test) [30.30.30.30] F=<a@ten-1> rejected RCPT <x@y>: domain=test.ex
 >>> using ACL "acl_30_30_30"
 LOG: H=(test) [30.30.30.30] F=<a@ten-1> rejected RCPT <x@y>: domain=test.ex
 >>> using ACL "acl_30_30_30"
->>> processing "deny" (TESTSUITE/test-config 161)
+>>> processing ACL acl_30_30_30 "deny" (TESTSUITE/test-config 161)
 >>>   message: domain=$dnslist_domain\nvalue=$dnslist_value\nmatched=$dnslist_matched\ntext="$dnslist_text"
 >>> check dnslists = test.ex=V4NET.0.0.1,127.0.0.2/$sender_address_domain
 >>>                = test.ex=V4NET.0.0.1,127.0.0.2/ten-2
 >>>   message: domain=$dnslist_domain\nvalue=$dnslist_value\nmatched=$dnslist_matched\ntext="$dnslist_text"
 >>> check dnslists = test.ex=V4NET.0.0.1,127.0.0.2/$sender_address_domain
 >>>                = test.ex=V4NET.0.0.1,127.0.0.2/ten-2
@@ -1253,13 +1726,15 @@ LOG: H=(test) [30.30.30.30] F=<a@ten-1> rejected RCPT <x@y>: domain=test.ex
 >>> DNS lookup for ten-2.test.ex succeeded (yielding V4NET.0.0.2)
 >>> => but we are not accepting this block class because
 >>> => there was no match for =V4NET.0.0.1,127.0.0.2
 >>> DNS lookup for ten-2.test.ex succeeded (yielding V4NET.0.0.2)
 >>> => but we are not accepting this block class because
 >>> => there was no match for =V4NET.0.0.1,127.0.0.2
->>> deny: condition test failed in ACL "acl_30_30_30"
->>> processing "accept" (TESTSUITE/test-config 163)
->>> accept: condition test succeeded in ACL "acl_30_30_30"
->>> end of ACL "acl_30_30_30": ACCEPT
->>> host in smtp_accept_max_nonmail_hosts? yes (matched "*")
+>>> deny: condition test failed in ACL acl_30_30_30
+>>> processing ACL acl_30_30_30 "accept" (TESTSUITE/test-config 163)
+>>> accept: condition test succeeded in ACL acl_30_30_30
+>>> end of ACL acl_30_30_30: ACCEPT
+>>> host in smtp_accept_max_nonmail_hosts?
+>>>  list element: *
+>>>  host in smtp_accept_max_nonmail_hosts? yes (matched "*")
 >>> using ACL "acl_30_30_30"
 >>> using ACL "acl_30_30_30"
->>> processing "deny" (TESTSUITE/test-config 161)
+>>> processing ACL acl_30_30_30 "deny" (TESTSUITE/test-config 161)
 >>>   message: domain=$dnslist_domain\nvalue=$dnslist_value\nmatched=$dnslist_matched\ntext="$dnslist_text"
 >>> check dnslists = test.ex=V4NET.0.0.1,127.0.0.2/$sender_address_domain
 >>>                = test.ex=V4NET.0.0.1,127.0.0.2/13.12.11.V4NET.rbl
 >>>   message: domain=$dnslist_domain\nvalue=$dnslist_value\nmatched=$dnslist_matched\ntext="$dnslist_text"
 >>> check dnslists = test.ex=V4NET.0.0.1,127.0.0.2/$sender_address_domain
 >>>                = test.ex=V4NET.0.0.1,127.0.0.2/13.12.11.V4NET.rbl
@@ -1268,8 +1743,8 @@ LOG: H=(test) [30.30.30.30] F=<a@ten-1> rejected RCPT <x@y>: domain=test.ex
 >>> dnslists: wrote cache entry, ttl=3
 >>> DNS lookup for 13.12.11.V4NET.rbl.test.ex succeeded (yielding 127.0.0.2)
 >>> => that means 13.12.11.V4NET.rbl is listed at test.ex
 >>> dnslists: wrote cache entry, ttl=3
 >>> DNS lookup for 13.12.11.V4NET.rbl.test.ex succeeded (yielding 127.0.0.2)
 >>> => that means 13.12.11.V4NET.rbl is listed at test.ex
->>> deny: condition test succeeded in ACL "acl_30_30_30"
->>> end of ACL "acl_30_30_30": DENY
+>>> deny: condition test succeeded in ACL acl_30_30_30
+>>> end of ACL acl_30_30_30: DENY
 LOG: H=(test) [30.30.30.30] F=<a@13.12.11.V4NET.rbl> rejected RCPT <x@y>: domain=test.ex
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 LOG: H=(test) [30.30.30.30] F=<a@13.12.11.V4NET.rbl> rejected RCPT <x@y>: domain=test.ex
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
@@ -1279,17 +1754,20 @@ LOG: H=(test) [30.30.30.30] F=<a@13.12.11.V4NET.rbl> rejected RCPT <x@y>: domain
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_31_31_31"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_31_31_31"
->>> processing "deny" (TESTSUITE/test-config 167)
+>>> processing ACL acl_31_31_31 "deny" (TESTSUITE/test-config 167)
 >>> check dnslists = test.ex/$sender_address_domain+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+END
 >>>                = test.ex/y+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+END
 >>> dnslists check: test.ex/y+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+END
 LOG: dnslist query is too long (ignored): y+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+END.test.ex...
 >>> check dnslists = test.ex/$sender_address_domain+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+END
 >>>                = test.ex/y+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+END
 >>> dnslists check: test.ex/y+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+END
 LOG: dnslist query is too long (ignored): y+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+extra+END.test.ex...
->>> deny: condition test failed in ACL "acl_31_31_31"
->>> processing "accept" (TESTSUITE/test-config 168)
->>> accept: condition test succeeded in ACL "acl_31_31_31"
->>> end of ACL "acl_31_31_31": ACCEPT
+>>> deny: condition test failed in ACL acl_31_31_31
+>>> processing ACL acl_31_31_31 "accept" (TESTSUITE/test-config 168)
+>>> accept: condition test succeeded in ACL acl_31_31_31
+>>> end of ACL acl_31_31_31: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -1298,27 +1776,37 @@ LOG: dnslist query is too long (ignored): y+extra+extra+extra+extra+extra+extra+
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_33_33_33"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_33_33_33"
->>> processing "accept" (TESTSUITE/test-config 184)
+>>> processing ACL acl_33_33_33 "accept" (TESTSUITE/test-config 184)
 >>>   message: sender verify failure
 >>> check verify = sender/no_details
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x@y
 >>>   message: sender verify failure
 >>> check verify = sender/no_details
 >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
 >>> routing x@y
->>> x in "^ok"? no (end of list)
->>> x in "^userx : ^cond-"? no (end of list)
->>> x in "fail"? no (end of list)
+>>> x in local_parts?
+>>>  list element: ^ok
+>>> x in local_parts? no (end of list)
+>>> x in local_parts?
+>>>  list element: ^userx
+>>>  list element: ^cond-
+>>> x in local_parts? no (end of list)
+>>> x in local_parts?
+>>>  list element: fail
+>>> x in local_parts? no (end of list)
 >>> no more routers
 >>> ----------- end verify ------------
 >>> no more routers
 >>> ----------- end verify ------------
->>> accept: condition test failed in ACL "acl_33_33_33"
+>>> accept: condition test failed in ACL acl_33_33_33
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [33.33.33.33] F=<x@y> rejected RCPT <x1@y>: Sender verify failed
 >>> using ACL "acl_33_33_33"
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [33.33.33.33] F=<x@y> rejected RCPT <x1@y>: Sender verify failed
 >>> using ACL "acl_33_33_33"
->>> processing "accept" (TESTSUITE/test-config 184)
+>>> processing ACL acl_33_33_33 "accept" (TESTSUITE/test-config 184)
 >>>   message: sender verify failure
 >>> check verify = sender/no_details
 >>> using cached sender verify result
 >>>   message: sender verify failure
 >>> check verify = sender/no_details
 >>> using cached sender verify result
->>> accept: condition test failed in ACL "acl_33_33_33"
+>>> accept: condition test failed in ACL acl_33_33_33
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [33.33.33.33] F=<x@y> rejected RCPT <x2@y>: Sender verify failed
 >>> host in hosts_connection_nolog? no (option unset)
 >>> accept: endpass encountered - denying access
 LOG: H=(test) [33.33.33.33] F=<x@y> rejected RCPT <x2@y>: Sender verify failed
 >>> host in hosts_connection_nolog? no (option unset)
@@ -1329,42 +1817,45 @@ LOG: H=(test) [33.33.33.33] F=<x@y> rejected RCPT <x2@y>: Sender verify failed
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_44_44_44"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_44_44_44"
->>> processing "warn" (TESTSUITE/test-config 192)
+>>> processing ACL acl_44_44_44 "warn" (TESTSUITE/test-config 192)
 >>> check dnslists = test.again.dns
 >>> dnslists check: test.again.dns
 >>> new DNS lookup for 1.44.44.44.test.again.dns
 >>> 1.44.44.44.test.again.dns in dns_again_means_nonexist? no (option unset)
 >>> dnslists: wrote cache entry, ttl=3600
 LOG: DNS list lookup defer (probably timeout) for 1.44.44.44.test.again.dns: assumed not in list
 >>> check dnslists = test.again.dns
 >>> dnslists check: test.again.dns
 >>> new DNS lookup for 1.44.44.44.test.again.dns
 >>> 1.44.44.44.test.again.dns in dns_again_means_nonexist? no (option unset)
 >>> dnslists: wrote cache entry, ttl=3600
 LOG: DNS list lookup defer (probably timeout) for 1.44.44.44.test.again.dns: assumed not in list
->>> warn: condition test failed in ACL "acl_44_44_44"
->>> processing "warn" (TESTSUITE/test-config 193)
+>>> warn: condition test failed in ACL acl_44_44_44
+>>> processing ACL acl_44_44_44 "warn" (TESTSUITE/test-config 193)
 >>> check dnslists = +include_unknown : test.again.dns
 >>> dnslists check: +include_unknown
 >>> dnslists check: test.again.dns
 >>> dnslists: using result of previous lookup
 LOG: DNS list lookup defer (probably timeout) for 1.44.44.44.test.again.dns: assumed in list
 >>> => that means 44.44.44.1 is listed at test.again.dns
 >>> check dnslists = +include_unknown : test.again.dns
 >>> dnslists check: +include_unknown
 >>> dnslists check: test.again.dns
 >>> dnslists: using result of previous lookup
 LOG: DNS list lookup defer (probably timeout) for 1.44.44.44.test.again.dns: assumed in list
 >>> => that means 44.44.44.1 is listed at test.again.dns
->>> warn: condition test succeeded in ACL "acl_44_44_44"
->>> processing "warn" (TESTSUITE/test-config 194)
+>>> warn: condition test succeeded in ACL acl_44_44_44
+>>> processing ACL acl_44_44_44 "warn" (TESTSUITE/test-config 194)
 >>> check dnslists = +exclude_unknown : test.again.dns
 >>> dnslists check: +exclude_unknown
 >>> dnslists check: test.again.dns
 >>> dnslists: using result of previous lookup
 LOG: DNS list lookup defer (probably timeout) for 1.44.44.44.test.again.dns: assumed not in list
 >>> check dnslists = +exclude_unknown : test.again.dns
 >>> dnslists check: +exclude_unknown
 >>> dnslists check: test.again.dns
 >>> dnslists: using result of previous lookup
 LOG: DNS list lookup defer (probably timeout) for 1.44.44.44.test.again.dns: assumed not in list
->>> warn: condition test failed in ACL "acl_44_44_44"
->>> processing "warn" (TESTSUITE/test-config 195)
+>>> warn: condition test failed in ACL acl_44_44_44
+>>> processing ACL acl_44_44_44 "warn" (TESTSUITE/test-config 195)
 >>> check dnslists = +defer_unknown : test.again.dns
 >>> dnslists check: +defer_unknown
 >>> dnslists check: test.again.dns
 >>> dnslists: using result of previous lookup
 LOG: DNS list lookup defer (probably timeout) for 1.44.44.44.test.again.dns: returned DEFER
 >>> check dnslists = +defer_unknown : test.again.dns
 >>> dnslists check: +defer_unknown
 >>> dnslists check: test.again.dns
 >>> dnslists: using result of previous lookup
 LOG: DNS list lookup defer (probably timeout) for 1.44.44.44.test.again.dns: returned DEFER
->>> warn: condition test deferred in ACL "acl_44_44_44"
+>>> warn: condition test deferred in ACL acl_44_44_44
 LOG: H=(test) [44.44.44.1] Warning: ACL "warn" statement skipped: condition test deferred
 LOG: H=(test) [44.44.44.1] Warning: ACL "warn" statement skipped: condition test deferred
->>> processing "accept" (TESTSUITE/test-config 196)
->>> accept: condition test succeeded in ACL "acl_44_44_44"
->>> end of ACL "acl_44_44_44": ACCEPT
+>>> processing ACL acl_44_44_44 "accept" (TESTSUITE/test-config 196)
+>>> accept: condition test succeeded in ACL acl_44_44_44
+>>> end of ACL acl_44_44_44: ACCEPT
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
 >>> host in hosts_connection_nolog? no (option unset)
 >>> host in host_lookup? no (option unset)
 >>> host in host_reject_connection? no (option unset)
@@ -1373,29 +1864,38 @@ LOG: H=(test) [44.44.44.1] Warning: ACL "warn" statement skipped: condition test
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
 >>> host in helo_verify_hosts? no (option unset)
 >>> host in helo_try_verify_hosts? no (option unset)
 >>> host in helo_accept_junk_hosts? no (option unset)
+>>> test in helo_lookup_domains?
+>>>  list element: @
+>>>  list element: @[]
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_60_60_60"
 >>> test in helo_lookup_domains? no (end of list)
 >>> using ACL "acl_60_60_60"
->>> processing "accept" (TESTSUITE/test-config 226)
+>>> processing ACL acl_60_60_60 "accept" (TESTSUITE/test-config 226)
 >>> check !acl = TESTSUITE/aux-fixed/0023.acl2
 >>>  read ACL from file TESTSUITE/aux-fixed/0023.acl2
 >>> check !acl = TESTSUITE/aux-fixed/0023.acl2
 >>>  read ACL from file TESTSUITE/aux-fixed/0023.acl2
->>>  processing "accept" (TESTSUITE/test-config 272)
+>>>  processing ACL TESTSUITE/aux-fixed/0023.acl2 "accept" (TESTSUITE/test-config 226)
 >>>  check domains = b
 >>>  check domains = b
+>>>  y in "b"?
+>>>   list element: b
 >>>  y in "b"? no (end of list)
 >>>  y in "b"? no (end of list)
->>>  accept: condition test failed in ACL "TESTSUITE/aux-fixed/0023.acl2"
->>>  end of ACL "TESTSUITE/aux-fixed/0023.acl2": implicit DENY
->>> accept: condition test succeeded in ACL "acl_60_60_60"
->>> end of ACL "acl_60_60_60": ACCEPT
+>>>  accept: condition test failed in ACL TESTSUITE/aux-fixed/0023.acl2
+>>>  end of ACL TESTSUITE/aux-fixed/0023.acl2: implicit DENY
+>>> accept: condition test succeeded in ACL acl_60_60_60
+>>> end of ACL acl_60_60_60: ACCEPT
 >>> using ACL "acl_60_60_60"
 >>> using ACL "acl_60_60_60"
->>> processing "accept" (TESTSUITE/test-config 226)
+>>> processing ACL acl_60_60_60 "accept" (TESTSUITE/test-config 226)
 >>> check !acl = TESTSUITE/aux-fixed/0023.acl2
 >>>  using ACL "TESTSUITE/aux-fixed/0023.acl2"
 >>> check !acl = TESTSUITE/aux-fixed/0023.acl2
 >>>  using ACL "TESTSUITE/aux-fixed/0023.acl2"
->>>  processing "accept" (TESTSUITE/test-config 272)
+>>>  processing ACL TESTSUITE/aux-fixed/0023.acl2 "accept" (TESTSUITE/test-config 226)
 >>>  check domains = b
 >>>  check domains = b
->>>  b in "b"? yes (matched "b")
+>>>  b in "b"?
+>>>   list element: b
+>>>   b in "b"? yes (matched "b")
 >>>  check local_parts = a
 >>>  check local_parts = a
->>>  a in "a"? yes (matched "a")
->>>  accept: condition test succeeded in ACL "TESTSUITE/aux-fixed/0023.acl2"
->>>  end of ACL "TESTSUITE/aux-fixed/0023.acl2": ACCEPT
->>> accept: condition test failed in ACL "acl_60_60_60"
->>> end of ACL "acl_60_60_60": implicit DENY
+>>>  a in "a"?
+>>>   list element: a
+>>>   a in "a"? yes (matched "a")
+>>>  accept: condition test succeeded in ACL TESTSUITE/aux-fixed/0023.acl2
+>>>  end of ACL TESTSUITE/aux-fixed/0023.acl2: ACCEPT
+>>> accept: condition test failed in ACL acl_60_60_60
+>>> end of ACL acl_60_60_60: implicit DENY
 LOG: H=(test) [60.60.60.60] F=<x@y> rejected RCPT <a@b>
 LOG: H=(test) [60.60.60.60] F=<x@y> rejected RCPT <a@b>