summaryrefslogtreecommitdiff
path: root/test/lit/validation/closed-world-interface.wast
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2024-10-18 16:14:01 -0700
committerGitHub <noreply@github.com>2024-10-18 16:14:01 -0700
commitbc36c02d1a54c91d9fc4bdbffe00608929ec3169 (patch)
treef6a1276d57df68a34f0626ee7290b832ff6d6c8a /test/lit/validation/closed-world-interface.wast
parent679c26faec1a714eb220033254f7147ec12b8282 (diff)
downloadbinaryen-bc36c02d1a54c91d9fc4bdbffe00608929ec3169.tar.gz
binaryen-bc36c02d1a54c91d9fc4bdbffe00608929ec3169.tar.bz2
binaryen-bc36c02d1a54c91d9fc4bdbffe00608929ec3169.zip
Remove closed world validation checks (#7019)
These were added to avoid common problems with closed world mode, but in practice they are causing more harm than good, forcing users to work around them. In the meantime (until #6965), remove this validation to unblock current toolchain makers. Fix GlobalTypeOptimization and AbstractTypeRefining on issues that this uncovers: without this validation, it is possible to run them on more wasm files than before, hence these were not previously detected. They are bundled in this PR because their tests cannot validate before this PR.
Diffstat (limited to 'test/lit/validation/closed-world-interface.wast')
-rw-r--r--test/lit/validation/closed-world-interface.wast79
1 files changed, 0 insertions, 79 deletions
diff --git a/test/lit/validation/closed-world-interface.wast b/test/lit/validation/closed-world-interface.wast
deleted file mode 100644
index b4fe965cf..000000000
--- a/test/lit/validation/closed-world-interface.wast
+++ /dev/null
@@ -1,79 +0,0 @@
-;; Test that we error out on nontrivial public types with --closed-world
-
-;; RUN: not wasm-opt -all --closed-world %s 2>&1 | filecheck %s
-
-
-;; This is pulled in by a global.
-;; CHECK: publicly exposed type disallowed with a closed world: $array, on
-;; CHECK-NEXT: (array (mut i32))
-
-;; This is pulled in only by a global, so it is disallowed even though it is a function type.
-;; CHECK: publicly exposed type disallowed with a closed world: $private, on
-;; CHECK-NEXT: (func (param v128))
-
-;; This is referred to by the type of a function export, but is still not allowed.
-;; CHECK: publicly exposed type disallowed with a closed world: $struct, on
-;; CHECK-NEXT: (struct)
-
-(module
- (type $struct (struct))
- (type $array (array (mut i32)))
-
- (type $void (func))
- (type $abstract (func (param anyref)))
- (type $concrete (func (param (ref null $struct))))
-
- (rec
- (type $exported-pair-0 (func (param (ref $exported-pair-1))))
- (type $exported-pair-1 (func (param (ref $exported-pair-0))))
- )
- (rec
- ;; This is on an exported function.
- (type $partial-pair-0 (func))
- ;; The latter type types are not public, but allowed to be because the
- ;; entire rec group is allowed due to the first.
- (type $partial-pair-1 (func))
- ;; Test a non-function type.
- (type $partial-pair-2 (struct))
- )
-
- (type $private (func (param v128)))
-
- ;; Ok even though it is an import instead of an export.
- (func $1 (import "env" "test5") (type $exported-pair-1))
-
- (func $2 (export "test1") (type $void)
- (unreachable)
- )
-
- ;; Ok because it only refers to basic heap types
- (func $3 (export "test2") (type $abstract)
- (unreachable)
- )
-
- ;; Not ok because it refers to $struct.
- (func $4 (export "test3") (type $concrete)
- (unreachable)
- )
-
- ;; Ok even though it is in a rec group because the rest of the group and the
- ;; types this refers to are on the boundary as well.
- (func $5 (export "test4") (type $exported-pair-0)
- (unreachable)
- )
-
- ;; Ok, and we also allow the other type in the group.
- (func $6 (export "test6") (type $partial-pair-0)
- (unreachable)
- )
-
- ;; Not ok.
- (global $1 (export "g1") (ref null $array) (ref.null none))
-
- ;; Ok because this type is on the boundary anyway.
- (global $2 (export "g2") (ref null $void) (ref.null func))
-
- ;; Not ok even though it is a function type because it is not otherwise on the
- ;; boundary.
- (global $3 (export "g3") (ref null $private) (ref.null func))
-)