X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=tests%2Forg.simantics.scl.compiler.tests%2Fsrc%2Forg%2Fsimantics%2Fscl%2Fcompiler%2Ftests%2FTestBase.java;fp=tests%2Forg.simantics.scl.compiler.tests%2Fsrc%2Forg%2Fsimantics%2Fscl%2Fcompiler%2Ftests%2FTestBase.java;h=05ffd759fe19751e977668613d964e150644d94d;hb=0364f8f54b009e9e5de482d5c9d1cb7efb023141;hp=0000000000000000000000000000000000000000;hpb=7ecf07ff9aacab300f1fb900f1f0f97beb1be139;p=simantics%2Fplatform.git diff --git a/tests/org.simantics.scl.compiler.tests/src/org/simantics/scl/compiler/tests/TestBase.java b/tests/org.simantics.scl.compiler.tests/src/org/simantics/scl/compiler/tests/TestBase.java new file mode 100644 index 000000000..05ffd759f --- /dev/null +++ b/tests/org.simantics.scl.compiler.tests/src/org/simantics/scl/compiler/tests/TestBase.java @@ -0,0 +1,138 @@ +package org.simantics.scl.compiler.tests; + +import java.io.IOException; +import java.io.InputStream; +import java.nio.charset.Charset; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.regex.Pattern; + +import org.junit.Assert; +import org.simantics.scl.compiler.errors.Failable; +import org.simantics.scl.compiler.errors.Failure; +import org.simantics.scl.compiler.module.ImportDeclaration; +import org.simantics.scl.compiler.module.Module; +import org.simantics.scl.compiler.module.repository.ModuleRepository; +import org.simantics.scl.compiler.module.repository.UpdateListener; +import org.simantics.scl.compiler.source.ModuleSource; +import org.simantics.scl.compiler.source.StringModuleSource; +import org.simantics.scl.compiler.source.repository.CompositeModuleSourceRepository; +import org.simantics.scl.compiler.source.repository.MapModuleSourceRepository; +import org.simantics.scl.compiler.source.repository.SourceRepositories; +import org.simantics.scl.compiler.top.ValueNotFound; + +public class TestBase { + + public static final ModuleRepository PRELUDE_MODULE_REPOSITORY = InitialRepository.getInitialRepository(); + private static final Pattern TEST_SEPARATOR = Pattern.compile("^--+ *$", Pattern.MULTILINE); + private static final Charset UTF8 = Charset.forName("UTF-8"); + + String path; + + public TestBase(String path) { + this.path = path; + } + + protected void test() { + String testModuleName = Thread.currentThread().getStackTrace()[2].getMethodName(); + String testPath = path + "/" + testModuleName + ".scl"; + + try { + String[] testParts = readTestParts(testPath); + + int j=0; + ArrayList auxModuleNameList = new ArrayList(); + while(j < testParts.length) { + String part = testParts[j]; + if(part.startsWith("// module ")) + auxModuleNameList.add(part.substring(10).split("\\n", 2)[0].trim()); + else + break; + ++j; + } + int mainId = j; + String[] moduleNames = new String[mainId+1]; + String[] moduleTexts = new String[mainId+1]; + for(int i=0;i result = testEnvironment.getModule(moduleNames[lastId]); + if(!result.didSucceed()) + return ((Failure)result).toString(moduleTexts[lastId]); + else { + Object main = testEnvironment.getRuntimeModule(moduleNames[lastId]).getResult().getValue("main"); + return String.valueOf(main); + } + } + + private String[] readTestParts(String testPath) throws IOException { + InputStream stream = getClass().getResourceAsStream(testPath); + try { + byte[] buffer = new byte[1024]; + int pos = 0; + while(true) { + int c = stream.read(buffer, pos, buffer.length-pos); + if(c <= 0) + break; + pos += c; + if(pos < buffer.length) + break; + buffer = Arrays.copyOf(buffer, pos*2); + } + String text = new String(buffer, 0, pos, UTF8); + String[] result = TEST_SEPARATOR.split(text); + for(int i=1;i