Allow (42 : Text & Integer) at the end of function (#11588)

Bypassing failing check.
This commit is contained in:
Jaroslav Tulach 2024-11-20 09:14:38 +01:00 committed by GitHub
parent bab9addeb4
commit ad9d0e5ab5
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 25 additions and 1 deletions

View File

@ -318,7 +318,7 @@ case object TypeSignatures extends IRPass {
case a => Some(resolveExpression(a))
} ::: lastSignature
.map({
case asc @ Type.Ascription(_: Name, sig, comment, _, _) =>
case asc @ Type.Ascription(_, sig, comment, _, _) =>
asc.updateMetadata(
new MetadataPair(this, Signature(sig, comment))
)

View File

@ -1026,6 +1026,30 @@ public class SignatureTest extends ContextTest {
}
}
@Test
public void returnTypeCheckByLastStatementOfMain() throws Exception {
final URI uri = new URI("memory://rts.enso");
final Source src =
Source.newBuilder(
"enso",
"""
from Standard.Base import all
fn =
(42 : Text & Integer)
Text.from (that:Integer) = that.to_text
""",
uri.getAuthority())
.uri(uri)
.buildLiteral();
var module = ctx.eval(src);
var main = module.invokeMember(MethodNames.Module.EVAL_EXPRESSION, "fn");
assertEquals(42, main.asInt());
assertEquals("42", main.asString());
}
/**
* Similar scenario to {@code returnTypeCheckOptInError}, but with the opt out signature the check
* is not currently performed.