Index: test/mjsunit/harmony/module-resolution.js |
diff --git a/test/mjsunit/harmony/module-resolution.js b/test/mjsunit/harmony/module-resolution.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f9f492cffcef5a569201a6b621ec03dbbd924d0e |
--- /dev/null |
+++ b/test/mjsunit/harmony/module-resolution.js |
@@ -0,0 +1,139 @@ |
+// Copyright 2012 the V8 project authors. All rights reserved. |
+// Redistribution and use in source and binary forms, with or without |
+// modification, are permitted provided that the following conditions are |
+// met: |
+// |
+// * Redistributions of source code must retain the above copyright |
+// notice, this list of conditions and the following disclaimer. |
+// * Redistributions in binary form must reproduce the above |
+// copyright notice, this list of conditions and the following |
+// disclaimer in the documentation and/or other materials provided |
+// with the distribution. |
+// * Neither the name of Google Inc. nor the names of its |
+// contributors may be used to endorse or promote products derived |
+// from this software without specific prior written permission. |
+// |
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
+ |
+// Flags: --harmony-modules --harmony-scoping |
+ |
+// Test basic module interface inference. |
+ |
+"use strict"; |
+ |
+print("begin.") |
+ |
+export let x = print("0") |
+ |
+export module B = A.B |
+ |
+export module A { |
+ export let x = print("1") |
+ export let f = function() { return B.x } |
+ export module B { |
+ module BB = B |
+ export BB, x |
+ let x = print("2") |
+ let y = print("3") |
+ let Ax = A.x |
+ let ABx = A.B.x |
+ let Ay = A.y |
+ let BBx = BB.x |
+ let Af = A.f |
+ function f(x,y) { return x } |
+ } |
+ export let y = print("4") |
+ let Ax = A.x |
+ let Bx = B.x |
+ let ABx = A.B.x |
+ module C { |
+ export let z = print("5") |
+ export module D = B |
+ // TODO(rossberg): turn these into proper negative test cases once we have |
+ // suitable error messages. |
+ // import C.z // multiple declarations |
+ import x from B |
+ } |
+ module D { |
+ // TODO(rossberg): Handle import *. |
+ // import A.* // invalid forward import |
+ } |
+ module M {} |
+ // TODO(rossberg): Handle import *. |
+ // import M.* // invalid forward import |
+ let Cz = C.z |
+ let CDx = C.D.x |
+} |
+ |
+export module Imports { |
+ module A1 { |
+ export module A2 {} |
+ } |
+ module B { |
+ // TODO(rossberg): Handle import *. |
+ // import A1.* |
+ // import A2.* // unbound variable A2 |
+ } |
+} |
+ |
+export module E { |
+ export let xx = x |
+ export y, B |
+ let Bx = B.x |
+ // TODO(rossberg): Handle import *. |
+ // import A.* |
+} |
+ |
+export module M1 { |
+ export module A2 = M2 |
+} |
+export module M2 { |
+ export module A1 = M1 |
+} |
+ |
+// TODO(rossberg): turn these into proper negative test cases once we have |
+// suitable error messages. |
+// module W1 = W2.W |
+// module W2 = { export module W = W3 } |
+// module W3 = W1 // cyclic module definition |
+ |
+// module W1 = W2.W3 |
+// module W2 = { |
+// export module W3 = W4 |
+// export module W4 = W1 |
+// } // cyclic module definition |
+ |
+// TODO(rossberg): Handle import *. |
+//module M3B = M3.B |
+//export module M3 { |
+// export module B { export let x = "" } |
+// module C1 = { import M3.* } |
+// module C2 = { import M3.B.* } |
+// module C3 = { import M3B.* } |
+// module C4 = { export x import B.* } |
+//// TODO(rossberg): turn these into proper negative test cases once we have |
+//// suitable error messages. |
+//// export module C5 = { import C5.* } // invalid forward import |
+//// export module C6 = { import M3.C6.* } // invalid forward import |
+//} |
+ |
+export module External at "external.js" |
+export module External1 = External |
+export module ExternalA = External.A |
+export module InnerExternal { |
+ export module E at "external.js" |
+} |
+export module External2 = InnerExternal.E |
+//export let xxx = InnerExternal.E.A.x |
+ |
+print("end.") |