Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP fix(gnovm): PoC of inter-realm spec #2958

Draft
wants to merge 51 commits into
base: master
Choose a base branch
from

Conversation

ltzmaxwell
Copy link
Contributor

@ltzmaxwell ltzmaxwell commented Oct 16, 2024

WIP: adding filetest for inter-realm spec, NOT FINAL.
relate: #2743

Contributors' checklist...
  • Added new tests, or not needed, or not feasible
  • Provided an example (e.g. screenshot) to aid review or the PR is self-explanatory
  • Updated the official documentation or not needed
  • No breaking changes were made, or a BREAKING CHANGE: xxx message was included in the description
  • Added references to related issues and PRs
  • Provided any useful hints for running manual tests

@ltzmaxwell ltzmaxwell requested review from jaekwon, moul, piux2, thehowl, mvertes and a team as code owners October 16, 2024 10:22
@github-actions github-actions bot added 🧾 package/realm Tag used for new Realms or Packages. 📦 🤖 gnovm Issues or PRs gnovm related labels Oct 16, 2024
Copy link

codecov bot commented Oct 16, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 60.30%. Comparing base (aae5d49) to head (a604cdc).
Report is 92 commits behind head on master.

Additional details and impacted files
@@            Coverage Diff             @@
##           master    #2958      +/-   ##
==========================================
+ Coverage   60.23%   60.30%   +0.07%     
==========================================
  Files         562      562              
  Lines       75091    75286     +195     
==========================================
+ Hits        45228    45399     +171     
- Misses      26482    26505      +23     
- Partials     3381     3382       +1     
Flag Coverage Δ
contribs/gnodev 61.46% <ø> (+0.06%) ⬆️
contribs/gnofaucet 14.46% <ø> (ø)
misc/genstd 80.54% <ø> (ø)
misc/logos 20.23% <ø> (ø)
tm2 62.06% <ø> (-0.02%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@jefft0 jefft0 added review/triage-pending PRs opened by external contributors that are waiting for the 1st review and removed review/triage-pending PRs opened by external contributors that are waiting for the 1st review labels Oct 16, 2024
@jefft0
Copy link
Contributor

jefft0 commented Oct 17, 2024

(The "review team" label was added by mistake. This PR is opened by a core dev.)

@ltzmaxwell ltzmaxwell added the in focus Core team is prioritizing this work label Oct 19, 2024
@zivkovicmilos zivkovicmilos added this to the 🚀 Mainnet launch milestone Oct 28, 2024
@ltzmaxwell ltzmaxwell changed the title WIP fix(gnovm): add filetest for inter-realm spec WIP fix(gnovm): PoC of inter-realm spec Nov 26, 2024
gnovm/tests/files/zrealm_crossrealm24.gno Outdated Show resolved Hide resolved
gnovm/tests/files/zrealm_crossrealm20.gno Outdated Show resolved Hide resolved

func (foo) Foo() { println("hello " + std.CurrentRealm().PkgPath()) }

var fs []crossrealm.Fooer // panic
Copy link
Contributor Author

@ltzmaxwell ltzmaxwell Nov 26, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should behave same with var f crossream.Fooer, because the underlying array is persisted in the current realm, right?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this should not panic; at initialization, no crossrealm.Fooer is actually created (so it's all good), and then even on execution we can put in values of crossrealm.Fooer which are not attached to this realm, but instead ie. created by crossrealm - because it's an interface.

@Gno2D2
Copy link
Collaborator

Gno2D2 commented Dec 30, 2024

🛠 PR Checks Summary

All Automated Checks passed. ✅

Manual Checks (for Reviewers):
  • IGNORE the bot requirements for this PR (force green CI check)
Read More

🤖 This bot helps streamline PR reviews by verifying automated checks and providing guidance for contributors and reviewers.

✅ Automated Checks (for Contributors):

🟢 Maintainers must be able to edit this pull request (more info)

☑️ Contributor Actions:
  1. Fix any issues flagged by automated checks.
  2. Follow the Contributor Checklist to ensure your PR is ready for review.
    • Add new tests, or document why they are unnecessary.
    • Provide clear examples/screenshots, if necessary.
    • Update documentation, if required.
    • Ensure no breaking changes, or include BREAKING CHANGE notes.
    • Link related issues/PRs, where applicable.
☑️ Reviewer Actions:
  1. Complete manual checks for the PR, including the guidelines and additional checks if applicable.
📚 Resources:
Debug
Automated Checks
Maintainers must be able to edit this pull request (more info)

If

🟢 Condition met
└── 🟢 The pull request was created from a fork (head branch repo: ltzmaxwell/gno)

Then

🟢 Requirement satisfied
└── 🟢 Maintainer can modify this pull request

Manual Checks
**IGNORE** the bot requirements for this PR (force green CI check)

If

🟢 Condition met
└── 🟢 On every pull request

Can be checked by

  • Any user with comment edit permission


func main() {
f := crossrealm_b.Fooer
crossrealm.SetFooerGetter(func() crossrealm.Fooer {
Copy link
Contributor Author

@ltzmaxwell ltzmaxwell Jan 15, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the funcLit is not attached to current realm, nor associated to any real object owned by current realm, so it's potentially valid to be attached to external realm, if it does not contain any objects not belongs to the target external realm.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

in this case, the object attached to other realm is the block using this funcLit as source, rather than its closure.

func main() {
f := crossrealm_b.Fooer
crossrealm.SetFooerGetter(func() crossrealm.Fooer {
f1 := Foo{}
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

f1 is owned by main, then by package. so the funcLit is not permitted to be attached to external realm.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
in focus Core team is prioritizing this work 📦 🤖 gnovm Issues or PRs gnovm related 🧾 package/realm Tag used for new Realms or Packages.
Projects
Status: No status
Status: In Progress
Development

Successfully merging this pull request may close these issues.

6 participants