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

Run unit tests with truffle-compiler #8467

Merged
merged 50 commits into from
Dec 18, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
af6d619
logging-service-logback is JPMS module
Akirathan Dec 5, 2023
8f6157e
runtime uses truffle-compiler in tests
Akirathan Dec 5, 2023
2f7521e
Revert "logging-service-logback is JPMS module"
Akirathan Dec 5, 2023
308f8e8
Refactor Test/options to a separate task
Akirathan Dec 5, 2023
5dc8572
Provide a default logback-test logging config for tests
Akirathan Dec 5, 2023
b99c4a9
Do not add runtime-with-instruments to --patch-module
Akirathan Dec 5, 2023
9357291
Refactor mutable ListBuffer to List
Akirathan Dec 5, 2023
d3c5048
Introduce runtime-fat-jar project.
Akirathan Dec 6, 2023
3e0c531
compileModuleInfo task does not copy anything unless necessary
Akirathan Dec 7, 2023
ec95060
Merge branch 'develop' into wip/akirathan/8374-compiler-to-tests
Akirathan Dec 7, 2023
1c516be
JPMSUtils.filterModules filters only distinct modules
Akirathan Dec 7, 2023
0dd0056
Make sure that all GraalVM modules (including truffle langs) are in -…
Akirathan Dec 7, 2023
4a9c962
Create new module org.enso.interpreter.test
Akirathan Dec 8, 2023
81ec91e
module-info.java is not compiled every time
Akirathan Dec 8, 2023
ea70d95
Revert "Create new module org.enso.interpreter.test"
Akirathan Dec 11, 2023
1d42a25
Add skeleton of JPMSPlugin auto plugin.
Akirathan Dec 12, 2023
2af02fb
Add runtime-test-instruments project.
Akirathan Dec 12, 2023
95381be
Fix VectorTests in runtime
Akirathan Dec 12, 2023
6997cff
Fix the rest of runtime tests
Akirathan Dec 12, 2023
ffd95c4
runtime-with-instruments/test run with truffle-compiler
Akirathan Dec 12, 2023
acb27fc
fmt
Akirathan Dec 12, 2023
78c40a1
Fix some sbt issues with lazy val settings
Akirathan Dec 12, 2023
b98526e
Use service provider instead of reflection in runtime-test-instruments
Akirathan Dec 13, 2023
07f5fa4
Port NodeCountingTestInstrument into runtime-test-instruments
Akirathan Dec 14, 2023
05b221a
Merge runtime-with-instruments project into runtime/Test
Akirathan Dec 14, 2023
b66b3d7
Merge runtime-with-polyglot project into runtime/Test
Akirathan Dec 14, 2023
c9bf46f
Run runtime/test without -ea
Akirathan Dec 14, 2023
b68412e
fmt
Akirathan Dec 14, 2023
a4a82ab
Merge branch 'develop' into wip/akirathan/8374-compiler-to-tests
Akirathan Dec 14, 2023
111cda6
Include insight tool in runtime/Test
Akirathan Dec 15, 2023
256fb9c
withDebug command has better error message
Akirathan Dec 15, 2023
efa56f8
Remove BigNumberTest.averageOfMixedArrayOverDouble.
Akirathan Dec 15, 2023
b64d2b4
Fix context dispose in MetaObjectTest
Akirathan Dec 15, 2023
c3264d7
project-manager/test runs with truffle-compiler
Akirathan Dec 15, 2023
303d272
language-server/test runs with truffle-compiler
Akirathan Dec 15, 2023
0ac7249
JPMSUtils.compileModuleInfo takes an extraModulePath optional argument
Akirathan Dec 15, 2023
283fecb
Merge branch 'develop' into wip/akirathan/8374-compiler-to-tests
Akirathan Dec 15, 2023
b9e1c3d
Small fixes after merge
Akirathan Dec 15, 2023
9d5071f
langauge-server/test uses enso TestLogProvider
Akirathan Dec 15, 2023
8c90c5e
Add necessary modules on modulePath to language-server/test
Akirathan Dec 15, 2023
1ce3069
Add --patch-module option to language-server/test
Akirathan Dec 18, 2023
a342562
runtime/test uses Enso TestLogProvider
Akirathan Dec 18, 2023
3d097ee
Fix DebuggingEnsoTest.
Akirathan Dec 18, 2023
9ecbd68
Make sure runtime/test is run with -ea
Akirathan Dec 18, 2023
e8846cc
Make sure runtime/test is run with -ea
Akirathan Dec 18, 2023
e580ed9
Remove dependency on com.sandinh.sbt-java-module-info plugin
Akirathan Dec 18, 2023
e7171e9
CLeanup some unused methods
Akirathan Dec 18, 2023
e8ca9a9
fmt
Akirathan Dec 18, 2023
ef71ecf
project-manager/test uses TestLogProvider
Akirathan Dec 18, 2023
9820863
Remove unused logback-test.xml resource
Akirathan Dec 18, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
459 changes: 312 additions & 147 deletions build.sbt

Large diffs are not rendered by default.

12 changes: 12 additions & 0 deletions engine/runtime-test-instruments/src/main/java/module-info.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
module org.enso.runtime.test {
requires org.graalvm.truffle;
requires org.openide.util.lookup.RELEASE180;

exports org.enso.interpreter.test.instruments;
exports org.enso.interpreter.test.instruments.service;

provides com.oracle.truffle.api.instrumentation.provider.TruffleInstrumentProvider with
Copy link
Member

Choose a reason for hiding this comment

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

Separate module & module info for test only instruments is a good idea.

org.enso.interpreter.test.instruments.CodeIdsTestInstrumentProvider,
org.enso.interpreter.test.instruments.CodeLocationsTestInstrumentProvider,
org.enso.interpreter.test.instruments.NodeCountingTestInstrumentProvider;
}
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
package org.enso.interpreter.test;
package org.enso.interpreter.test.instruments;

import com.oracle.truffle.api.frame.VirtualFrame;
import com.oracle.truffle.api.instrumentation.*;
import com.oracle.truffle.api.nodes.Node;
import java.util.LinkedHashMap;
import java.util.Map;

import java.util.UUID;
import org.enso.interpreter.node.ExpressionNode;
import org.enso.interpreter.runtime.control.TailCallException;
import org.enso.interpreter.test.instruments.service.RuntimeTestService;
import org.openide.util.Lookup;

/**
* A debug instrument used to test code locations.
Expand All @@ -20,8 +21,13 @@
services = CodeIdsTestInstrument.class)
public class CodeIdsTestInstrument extends TruffleInstrument {
public static final String INSTRUMENT_ID = "ids-test";
Akirathan marked this conversation as resolved.
Show resolved Hide resolved
private static final RuntimeTestService runtimeTestService;
private Env env;

static {
runtimeTestService = Lookup.getDefault().lookup(RuntimeTestService.class);
}

/**
* Initializes the instrument. Substitute for a constructor, called by the Truffle framework.
*
Expand Down Expand Up @@ -94,7 +100,6 @@ public void onEnter(VirtualFrame frame) {}
/**
* Checks if the node to be executed is the node this listener was created to observe.
*
* @param context current execution context
* @param frame current execution frame
* @param result the result of executing the node
*/
Expand All @@ -104,11 +109,11 @@ public void onReturnValue(VirtualFrame frame, Object result) {
return;
}
Node node = context.getInstrumentedNode();
if (!(node instanceof ExpressionNode)) {
if (!runtimeTestService.isExpressionNode(node)) {
return;
}
nodes.put(this, result);
UUID id = ((ExpressionNode) node).getId();
UUID id = runtimeTestService.getNodeID(node);
if (id == null || !id.equals(expectedId)) {
return;
}
Expand All @@ -120,19 +125,18 @@ public void onReturnValue(VirtualFrame frame, Object result) {
/**
* Checks if the specified was called, if its execution triggered TCO.
*
* @param context current execution context.
* @param frame current execution frame.
* @param exception the exception thrown from this node's execution.
*/
@Override
public void onReturnExceptional(VirtualFrame frame, Throwable exception) {
if (!(exception instanceof TailCallException)) {
if (!runtimeTestService.isTailCallException(exception)) {
return;
}
if (!(context.getInstrumentedNode() instanceof ExpressionNode)) {
if (!runtimeTestService.isExpressionNode(context.getInstrumentedNode())) {
return;
}
UUID id = ((ExpressionNode) context.getInstrumentedNode()).getId();
UUID id = runtimeTestService.getNodeID(context.getInstrumentedNode());
if (expectedResult == null) {
successful = true;
}
Expand All @@ -142,8 +146,9 @@ public void onReturnExceptional(VirtualFrame frame, Throwable exception) {
public String toString() {
var sb = new StringBuilder();
sb.append(context.getInstrumentedNode().getClass().getSimpleName());
if (context.getInstrumentedNode() instanceof ExpressionNode expr) {
sb.append("@").append(expr.getId());
if (runtimeTestService.isExpressionNode(context.getInstrumentedNode())) {
UUID id = runtimeTestService.getNodeID(context.getInstrumentedNode());
sb.append("@").append(id);
}
sb.append(" ");
sb.append(context.getInstrumentedSourceSection());
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package org.enso.interpreter.test;
package org.enso.interpreter.test.instruments;

import com.oracle.truffle.api.frame.VirtualFrame;
import com.oracle.truffle.api.instrumentation.EventBinding;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
package org.enso.interpreter.test;

import static org.junit.Assert.fail;
package org.enso.interpreter.test.instruments;

import com.oracle.truffle.api.frame.VirtualFrame;
import com.oracle.truffle.api.instrumentation.EventContext;
Expand All @@ -9,31 +7,35 @@
import com.oracle.truffle.api.instrumentation.SourceSectionFilter;
import com.oracle.truffle.api.instrumentation.TruffleInstrument;
import com.oracle.truffle.api.nodes.Node;
import com.oracle.truffle.api.nodes.RootNode;
import com.oracle.truffle.api.source.SourceSection;

import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.UUID;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.function.Function;
import org.enso.interpreter.node.MethodRootNode;
import org.enso.interpreter.node.callable.FunctionCallInstrumentationNode;
import org.enso.pkg.QualifiedName;
import org.enso.interpreter.test.instruments.service.FunctionCallInfo;
import org.enso.interpreter.test.instruments.service.RuntimeTestService;
import org.openide.util.Lookup;

/** Testing instrument to control newly created nodes. */
@TruffleInstrument.Registration(
id = NodeCountingTestInstrument.INSTRUMENT_ID,
services = NodeCountingTestInstrument.class)
public class NodeCountingTestInstrument extends TruffleInstrument {
public static final String INSTRUMENT_ID = "node-count-test";
private static final RuntimeTestService runtimeTestService;
private final Map<Node, Node> all = new ConcurrentHashMap<>();
private Map<Class, List<Node>> counter = new ConcurrentHashMap<>();

private final Map<UUID, FunctionCallInfo> calls = new ConcurrentHashMap<>();
private Env env;

static {
runtimeTestService = Lookup.getDefault().lookup(RuntimeTestService.class);
}

@Override
protected void onCreate(Env env) {
env.registerService(this);
Expand Down Expand Up @@ -75,10 +77,10 @@ public Map<Class, List<Node>> assertNewNodes(String msg, int min, int max) {
};

if (value < min) {
fail(dump.apply(msg + ". Minimal size should be " + min + ", but was: " + value + " in"));
throw new AssertionError(dump.apply(msg + ". Minimal size should be " + min + ", but was: " + value + " in"));
}
if (value > max) {
fail(dump.apply(msg + ". Maximal size should be " + max + ", but was: " + value + " in"));
throw new AssertionError(dump.apply(msg + ". Maximal size should be " + max + ", but was: " + value + " in"));
}
counter = new ConcurrentHashMap<>();
return prev;
Expand Down Expand Up @@ -120,73 +122,16 @@ public NodeWrapper(EventContext context, Map<UUID, FunctionCallInfo> calls) {

public void onReturnValue(VirtualFrame frame, Object result) {
Node node = context.getInstrumentedNode();
if (node instanceof FunctionCallInstrumentationNode instrumentableNode
&& result instanceof FunctionCallInstrumentationNode.FunctionCall functionCall) {
onFunctionReturn(instrumentableNode, functionCall);
}
}

private void onFunctionReturn(
FunctionCallInstrumentationNode node, FunctionCallInstrumentationNode.FunctionCall result) {
if (node.getId() != null) {
calls.put(node.getId(), new FunctionCallInfo(result));
}
}
}

public static class FunctionCallInfo {

private final QualifiedName moduleName;
private final QualifiedName typeName;
private final String functionName;

public FunctionCallInfo(FunctionCallInstrumentationNode.FunctionCall call) {
RootNode rootNode = call.getFunction().getCallTarget().getRootNode();
if (rootNode instanceof MethodRootNode methodNode) {
moduleName = methodNode.getModuleScope().getModule().getName();
typeName = methodNode.getType().getQualifiedName();
functionName = methodNode.getMethodName();
} else {
moduleName = null;
typeName = null;
functionName = rootNode.getName();
}
}

@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
if (runtimeTestService.isFunctionCallInstrumentationNode(node)
&& runtimeTestService.isFunctionCall(result)) {
UUID nodeId = runtimeTestService.getNodeID(node);
if (nodeId != null) {
var funcCallInfo = runtimeTestService.extractFunctionCallInfo(result);
calls.put(nodeId, funcCallInfo);
}
}
FunctionCallInfo that = (FunctionCallInfo) o;
return Objects.equals(moduleName, that.moduleName)
&& Objects.equals(typeName, that.typeName)
&& Objects.equals(functionName, that.functionName);
}

@Override
public int hashCode() {
return Objects.hash(moduleName, typeName, functionName);
}

@Override
public String toString() {
return moduleName + "::" + typeName + "::" + functionName;
}

public QualifiedName getModuleName() {
return moduleName;
}

public QualifiedName getTypeName() {
return typeName;
}

public String getFunctionName() {
return functionName;
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package org.enso.interpreter.test.instruments.service;

public record FunctionCallInfo(
String moduleName,
String typeName,
String functionName
) {

@Override
public String toString() {
return moduleName + "::" + typeName + "::" + functionName;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package org.enso.interpreter.test.instruments.service;

import com.oracle.truffle.api.nodes.Node;
import com.oracle.truffle.api.nodes.RootNode;
import java.util.UUID;
import org.enso.interpreter.test.instruments.service.FunctionCallInfo;

/**
* A service that provides information from the `runtime` project to the instruments in this project
* (`runtime-test-instruments`). Note that this project cannot have a compile time dependency on
* `runtime`, thus, we need to use a service provider mechanism.
*/
public interface RuntimeTestService {
UUID getNodeID(Node node);
boolean isExpressionNode(Object node);
boolean isTailCallException(Object obj);
boolean isFunctionCallInstrumentationNode(Object node);
boolean isFunctionCall(Object obj);
FunctionCallInfo extractFunctionCallInfo(Object functionCall);
}

This file was deleted.

Loading
Loading