diff options
| author | Damien George <damien@micropython.org> | 2025-09-18 23:55:36 +1000 | 
|---|---|---|
| committer | Damien George <damien@micropython.org> | 2025-09-30 11:04:05 +1000 | 
| commit | beb4c3188f5c26ede14134db1d34f817793b7e46 (patch) | |
| tree | fa038be682c5fd66e7d3861ce055982606e79b78 /tests/basics/import_instance_method.py | |
| parent | e3ef68215605938c906196ae37120950d0eb6105 (diff) | |
py/runtime: Support importing a method from an instance.
This change follows CPython behaviour, allowing use of:
    from instance import method
to import a bound method from a class instance, eg registered via
setting `sys.modules["instance"] = instance`.
Admittedly this is probably a very rarely used pattern in Python, but it
resolves a long standing comment about whether or not this is actually
possible (it turns out it is possible!).  A test is added to show how it
works.
The main reason for this change is to fix a problem with imports in the
webassembly port: prior to this fix, it was not possible to do `from
js_module import function`, where `js_module` is a JavaScript object
registered to be visible to Python through the webassembly API function
`registerJsModule(js_module)`.  But now with this fix that is possible.
Signed-off-by: Damien George <damien@micropython.org>
Diffstat (limited to 'tests/basics/import_instance_method.py')
| -rw-r--r-- | tests/basics/import_instance_method.py | 38 | 
1 files changed, 38 insertions, 0 deletions
diff --git a/tests/basics/import_instance_method.py b/tests/basics/import_instance_method.py new file mode 100644 index 000000000..d25b70ac5 --- /dev/null +++ b/tests/basics/import_instance_method.py @@ -0,0 +1,38 @@ +# Test importing a method from a class instance. +# This is not a common thing to do, but ensures MicroPython has the same semantics as CPython. + +import sys + +if not hasattr(sys, "modules"): +    print("SKIP") +    raise SystemExit + + +class A: +    def __init__(self, value): +        self.value = value + +    def meth(self): +        return self.value + +    def meth_with_arg(self, a): +        return [self.value, a] + + +# Register a class instance as the module "mod". +sys.modules["mod"] = A(1) + +# Try importing it as a module. +import mod + +print(mod.meth()) +print(mod.meth_with_arg(2)) + +# Change the module. +sys.modules["mod"] = A(3) + +# Try importing it using "from ... import". +from mod import meth, meth_with_arg + +print(meth()) +print(meth_with_arg(4))  | 
