Skip to content

Commit 1e5fb73

Browse files
committed
[GR-12346] fix getting the class __module__ attr - for cases when the attr is not set
PullRequest: graalpython/262
2 parents 2a9488b + f11af6e commit 1e5fb73

File tree

3 files changed

+81
-2
lines changed

3 files changed

+81
-2
lines changed

graalpython/com.oracle.graal.python.test/src/tests/cpyext/test_object.py

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -38,7 +38,9 @@
3838
# SOFTWARE.
3939

4040
import sys
41+
4142
from . import CPyExtType, CPyExtTestCase, CPyExtFunction
43+
4244
__dir__ = __file__.rpartition("/")[0]
4345

4446

@@ -145,6 +147,15 @@ def test_dict(self):
145147
tester.get_dict()["extra"] = "blah"
146148
assert tester.extra == "blah"
147149

150+
def test_repr(self):
151+
TestRepr = CPyExtType("TestRepr", '')
152+
tester = TestRepr()
153+
try:
154+
repr(tester)
155+
except Exception:
156+
assert False
157+
assert True
158+
148159

149160
class TestObjectFunctions(CPyExtTestCase):
150161
def compile_module(self, name):
Lines changed: 68 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
# Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved.
2+
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
3+
#
4+
# The Universal Permissive License (UPL), Version 1.0
5+
#
6+
# Subject to the condition set forth below, permission is hereby granted to any
7+
# person obtaining a copy of this software, associated documentation and/or
8+
# data (collectively the "Software"), free of charge and under any and all
9+
# copyright rights in the Software, and any and all patent rights owned or
10+
# freely licensable by each licensor hereunder covering either (i) the
11+
# unmodified Software as contributed to or provided by such licensor, or (ii)
12+
# the Larger Works (as defined below), to deal in both
13+
#
14+
# (a) the Software, and
15+
#
16+
# (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if
17+
# one is included with the Software each a "Larger Work" to which the Software
18+
# is contributed by such licensors),
19+
#
20+
# without restriction, including without limitation the rights to copy, create
21+
# derivative works of, display, perform, and distribute the Software and make,
22+
# use, sell, offer for sale, import, export, have made, and have sold the
23+
# Software and the Larger Work(s), and to sublicense the foregoing rights on
24+
# either these or other terms.
25+
#
26+
# This license is subject to the following condition:
27+
#
28+
# The above copyright notice and either this complete permission notice or at a
29+
# minimum a reference to the UPL must be included in all copies or substantial
30+
# portions of the Software.
31+
#
32+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
33+
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
34+
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
35+
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
36+
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
37+
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
38+
# SOFTWARE.
39+
40+
41+
def assert_not_raises(fnc, *args, **kwargs):
42+
try:
43+
fnc(*args, **kwargs)
44+
except Exception:
45+
assert False
46+
assert True
47+
48+
49+
def test_repr_no_failures():
50+
class MyClass(dict):
51+
pass
52+
53+
x = 100
54+
55+
def a_func():
56+
return 20 * x
57+
58+
assert_not_raises(lambda: repr([1, 2, 3]))
59+
assert_not_raises(lambda: repr({1, 2, 3}))
60+
assert_not_raises(lambda: repr(2))
61+
assert_not_raises(lambda: repr(2.0))
62+
assert_not_raises(lambda: repr(range(0, 10)))
63+
assert_not_raises(lambda: repr(MyClass()))
64+
assert_not_raises(lambda: repr(MyClass))
65+
assert_not_raises(lambda: repr(None))
66+
assert_not_raises(lambda: repr(a_func))
67+
assert_not_raises(lambda: repr(object()))
68+
assert_not_raises(lambda: repr(x))

graalpython/com.oracle.graal.python/src/com/oracle/graal/python/builtins/objects/type/TypeBuiltins.java

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -111,9 +111,9 @@ public abstract static class ReprNode extends PythonUnaryBuiltinNode {
111111

112112
@Specialization
113113
public String repr(PythonClass self,
114-
@Cached("create(__GETATTRIBUTE__)") LookupAndCallBinaryNode readModuleNode,
114+
@Cached("create()") ReadAttributeFromObjectNode readModuleNode,
115115
@Cached("create(__GETATTRIBUTE__)") LookupAndCallBinaryNode readQualNameNode) {
116-
Object moduleName = readModuleNode.executeObject(self, __MODULE__);
116+
Object moduleName = readModuleNode.execute(self, __MODULE__);
117117
Object qualName = readQualNameNode.executeObject(self, __QUALNAME__);
118118
return concat(moduleName, qualName);
119119
}

0 commit comments

Comments
 (0)