Skip to content

Commit b1e0d1a

Browse files
committed
[GR-28663] [GR-28474] Backport: Primitive type getter interop regression in 20.3.0.
PullRequest: js/1839
2 parents 39f1514 + a0e42eb commit b1e0d1a

File tree

2 files changed

+109
-2
lines changed
  • graal-js/src

2 files changed

+109
-2
lines changed
Lines changed: 107 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,107 @@
1+
/*
2+
* Copyright (c) 2021, 2021, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* The Universal Permissive License (UPL), Version 1.0
6+
*
7+
* Subject to the condition set forth below, permission is hereby granted to any
8+
* person obtaining a copy of this software, associated documentation and/or
9+
* data (collectively the "Software"), free of charge and under any and all
10+
* copyright rights in the Software, and any and all patent rights owned or
11+
* freely licensable by each licensor hereunder covering either (i) the
12+
* unmodified Software as contributed to or provided by such licensor, or (ii)
13+
* the Larger Works (as defined below), to deal in both
14+
*
15+
* (a) the Software, and
16+
*
17+
* (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if
18+
* one is included with the Software each a "Larger Work" to which the Software
19+
* is contributed by such licensors),
20+
*
21+
* without restriction, including without limitation the rights to copy, create
22+
* derivative works of, display, perform, and distribute the Software and make,
23+
* use, sell, offer for sale, import, export, have made, and have sold the
24+
* Software and the Larger Work(s), and to sublicense the foregoing rights on
25+
* either these or other terms.
26+
*
27+
* This license is subject to the following condition:
28+
*
29+
* The above copyright notice and either this complete permission notice or at a
30+
* minimum a reference to the UPL must be included in all copies or substantial
31+
* portions of the Software.
32+
*
33+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
34+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
35+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
36+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
37+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
38+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
39+
* SOFTWARE.
40+
*/
41+
package com.oracle.truffle.js.test.regress;
42+
43+
import static org.junit.Assert.assertEquals;
44+
45+
import org.graalvm.polyglot.Context;
46+
import org.graalvm.polyglot.HostAccess;
47+
import org.junit.Test;
48+
49+
public class GR28474 {
50+
51+
@Test
52+
public void testGH401() {
53+
try (Context ctx = Context.newBuilder("js").allowHostAccess(HostAccess.ALL).allowExperimentalOptions(true).option("js.nashorn-compat", "true").build()) {
54+
ctx.getBindings("js").putMember("self", new Bug401());
55+
56+
assertEquals(20, ctx.eval("js", "self.longValue;").asLong());
57+
assertEquals(10, ctx.eval("js", "Math.min(self.longValue + 1, 10);").asLong());
58+
assertEquals(20, ctx.eval("js", "self.intValue;").asInt());
59+
assertEquals(10, ctx.eval("js", "Math.min(self.intValue + 1, 10);").asInt());
60+
assertEquals(20.0, ctx.eval("js", "self.doubleValue;").asDouble(), 0.0);
61+
assertEquals(10.0, ctx.eval("js", "Math.min(self.doubleValue + 1, 10);").asDouble(), 0.0);
62+
assertEquals(true, ctx.eval("js", "self.boolValue;").asBoolean());
63+
64+
assertEquals(20f, ctx.eval("js", "self.floatValue;").asFloat(), 0f);
65+
assertEquals(10f, ctx.eval("js", "Math.min(self.floatValue + 1, 10);").asFloat(), 0f);
66+
assertEquals("a", ctx.eval("js", "self.charValue;").asString());
67+
assertEquals(20, ctx.eval("js", "self.shortValue;").asShort());
68+
assertEquals(10, ctx.eval("js", "Math.min(self.shortValue + 1, 10);").asShort());
69+
assertEquals(20, ctx.eval("js", "self.byteValue;").asByte());
70+
assertEquals(10, ctx.eval("js", "Math.min(self.shortValue + 1, 10);").asByte());
71+
}
72+
}
73+
74+
public static class Bug401 {
75+
public long getLongValue() {
76+
return 20;
77+
}
78+
79+
public int getIntValue() {
80+
return 20;
81+
}
82+
83+
public double getDoubleValue() {
84+
return 20;
85+
}
86+
87+
public float getFloatValue() {
88+
return 20;
89+
}
90+
91+
public char getCharValue() {
92+
return 'a';
93+
}
94+
95+
public short getShortValue() {
96+
return 20;
97+
}
98+
99+
public byte getByteValue() {
100+
return 20;
101+
}
102+
103+
public boolean getBoolValue() {
104+
return true;
105+
}
106+
}
107+
}

graal-js/src/com.oracle.truffle.js/src/com/oracle/truffle/js/nodes/access/PropertyGetNode.java

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved.
2+
* Copyright (c) 2018, 2021, Oracle and/or its affiliates. All rights reserved.
33
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
44
*
55
* The Universal Permissive License (UPL), Version 1.0
@@ -958,7 +958,7 @@ private Object foreignGet(Object thisObj, PropertyGetNode root) {
958958
if (context.isOptionNashornCompatibilityMode()) {
959959
Object result = tryGetters(thisObj, root);
960960
if (result != null) {
961-
return result;
961+
return importValueNode.executeWithTarget(result);
962962
}
963963
}
964964
Object foreignResult;

0 commit comments

Comments
 (0)