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

Code generation changes for verification #21

Merged
merged 22 commits into from
Jun 10, 2024

Conversation

mario-bucev
Copy link
Collaborator

Changes

  • "Inlined ACN code" and optional fields are wrapped in local functions
  • SEQUENCEOF loops are transformed into top-level recursive functions
  • Add further class invariants
  • Add precise size computations for messages

Important note
The PUSCScalaTest for Scala did not System.exit with a non-zero code when a test failed, we therefore use to accept failing tests. This is now fixed. However, this unveils a bug in automatic test case generation: the compiler may generate invalid messages that are rejected while encoding, which cause test to fail even though the encoding/decoding functions are not (presumably) faulty. This bug affects all backends but it is only manifest for the Scala one because the other ones do not always check for message validity. As a temporary "fix", the tests that do not proceed to encode the messages are marked as passing.

@mario-bucev mario-bucev requested a review from fschramka June 6, 2024 12:45
@fschramka fschramka merged commit aa98394 into ateleris:scala-backend Jun 10, 2024
1 check passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants