/* * #%~ * The VDM Type Checker * %% * Copyright (C) 2008 - 2014 Overture * %% * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program. If not, see * <http://www.gnu.org/licenses/gpl-3.0.html>. * #~% */ package org.overture.typechecker.tests.utils; import java.io.File; import java.util.Collection; import java.util.List; import java.util.Vector; import org.junit.Assert; import org.overture.ast.analysis.AnalysisException; import org.overture.ast.definitions.SClassDefinition; import org.overture.ast.modules.AModuleModules; import org.overture.ast.node.INode; import org.overture.parser.lex.LexException; import org.overture.parser.messages.VDMMessage; import org.overture.parser.syntax.ParserException; import org.overture.test.framework.results.IMessage; import org.overture.test.framework.results.Message; import org.overture.test.framework.results.Result; import org.overture.typechecker.util.TypeCheckerUtil; import org.overture.typechecker.util.TypeCheckerUtil.TypeCheckResult; public class OvertureTestHelper { @SuppressWarnings("unchecked") private static Result<Boolean> convert( @SuppressWarnings("rawtypes") TypeCheckResult result) { if (result.result == null) { return new Result<Boolean>(false, convert(result.parserResult.warnings), convert(result.parserResult.errors)); } return new Result<Boolean>(true, convert(result.warnings), convert(result.errors)); } public Result<Boolean> typeCheckSl(File file) { TypeCheckResult<List<AModuleModules>> result = TypeCheckerUtil.typeCheckSl(file); checkTypes(result.result); return convert(result); } public Result<Boolean> typeCheckPp(File file) { TypeCheckResult<List<SClassDefinition>> result = TypeCheckerUtil.typeCheckPp(file); checkTypes(result.result); return convert(result); } public Result<Boolean> typeCheckRt(File file) throws ParserException, LexException { TypeCheckResult<List<SClassDefinition>> result = TypeCheckerUtil.typeCheckRt(file); checkTypes(result.result); return convert(result); } public static List<IMessage> convert(List<? extends VDMMessage> messages) { List<IMessage> testMessages = new Vector<IMessage>(); for (VDMMessage msg : messages) { testMessages.add(new Message(msg.location.getFile().getName(), msg.number, msg.location.getStartLine(), msg.location.getStartPos(), msg.message)); } return testMessages; } static boolean enableCompleteTypeFieldCheck = false; public static void checkTypes(Collection<? extends INode> c) { if (!enableCompleteTypeFieldCheck) { return; } try { if (c != null) { for (INode element : c) { if (element != null) { element.apply(new TypeSetAnalysis()); } } } } catch (AnalysisException e) { Assert.fail(e.getMessage()); } } }