/*
* ******************************************************************************
* MontiCore Language Workbench
* Copyright (c) 2015, MontiCore, All rights reserved.
*
* This project is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3.0 of the License, or (at your option) any later version.
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this project. If not, see <http://www.gnu.org/licenses/>.
* ******************************************************************************
*/
package de.monticore.types;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import java.io.IOException;
import java.util.HashMap;
import org.junit.BeforeClass;
import org.junit.Test;
import de.monticore.types.types._ast.ASTArrayType;
import de.monticore.types.types._ast.ASTComplexReferenceType;
import de.monticore.types.types._ast.ASTType;
import de.se_rwth.commons.logging.Log;
import de.se_rwth.commons.logging.Slf4jLog;
/**
* @author Martin Schindler
*/
public class ComplexArrayTypesTest {
@BeforeClass
public static void disableFailQuick() {
Slf4jLog.init();
Log.enableFailQuick(false);
}
@Test
public void testComplexArrayTypes1() {
// SimpleReferenceTypes:
try {
// test-data
HashMap<String, Integer> testdata = new HashMap<String, Integer>();
testdata.put("Collection<?>[]", 1);
testdata.put("L<A>[]", 1);
testdata.put("C<L<A>>[]", 1);
testdata.put("Pair<String,String>[]", 1);
testdata.put("A<B<C,D<E,F<G>>>>[]", 1);
testdata.put("A<B<C,D<E,F<G<H>>>>,I<J>>[]", 1);
// checks
for (String teststring : testdata.keySet()) {
ASTType type = TypesTestHelper.getInstance().parseType(teststring);
assertNotNull(type);
// check typing and dimension:
assertTrue(type instanceof ASTArrayType);
ASTArrayType arrayType = (ASTArrayType) type;
assertEquals(testdata.get(teststring).intValue(), arrayType.getDimensions());
assertTrue(arrayType.getComponentType() instanceof ASTComplexReferenceType);
}
}
catch (IOException e) {
fail(e.getMessage());
}
}
@Test
public void testComplexArrayTypes2() {
// QualifiedTypes:
try {
// test-data
HashMap<String, Integer> testdata = new HashMap<String, Integer>();
testdata.put("A.B<int[][]>.C<int[]>[][][][ ]", 4);
// checks
for (String teststring : testdata.keySet()) {
ASTType type = TypesTestHelper.getInstance().parseType(teststring);
assertNotNull(type);
// check typing and dimension:
assertTrue(type instanceof ASTArrayType);
ASTArrayType arrayType = (ASTArrayType) type;
assertEquals(testdata.get(teststring).intValue(), arrayType.getDimensions());
assertTrue(arrayType.getComponentType() instanceof ASTComplexReferenceType);
}
}
catch (IOException e) {
fail(e.getMessage());
}
}
// copied from JavaDSL
@Test
public void testComplexArrayTypes3() {
try {
// Test for a simple array type with one dimension
assertTrue(TypesTestHelper.getInstance().testType("Type[]"));
// Test for a simple array type with mor than one dimension
assertTrue(TypesTestHelper.getInstance().testType("Type[][][][][]"));
// Test for a parameterized array type
assertTrue(TypesTestHelper.getInstance().testType("Type<?>[]"));
// Test for a parameterized type argument
assertTrue(TypesTestHelper.getInstance().testType("Type<Arg1<Arg2>>[]"));
// Test for a parameterized type argument, which is also an array
assertTrue(TypesTestHelper.getInstance().testType("Type<Arg1<Arg2>[][]>[]"));
// Test for a parameterized type argument. Only the innermost argument
// is an array
assertTrue(TypesTestHelper.getInstance().testType("Type<Arg1<Arg2[]>>"));
// Test for a parameterized type argument. Just a step more
assertTrue(TypesTestHelper.getInstance().testType("Type<Arg1<Arg2<Arg3>>>[]"));
// Test for a parameterized type argument. Just a step more
assertTrue(TypesTestHelper.getInstance().testType("Type<Arg1<Arg2<Arg3<Arg4>>>>[]"));
// Same test as above, but with an array type as Arg2
assertTrue(TypesTestHelper.getInstance().testType("Type<Arg1<Arg2<Arg3<Arg4>>[]>>[]"));
// Same as above, but differnt place for the brackets
assertTrue(TypesTestHelper.getInstance().testType("Type<Arg1<Arg2<Arg3<Arg4>>>[]>[]"));
}
catch (IOException e) {
fail(e.getMessage());
}
}
@Test
public void testNegativeComplexArrayTypes() {
try {
// Negative test for a qualified type, whose qualification is an array type
assertNull(TypesTestHelper.getInstance().parseType("packageName.Type[].Invalid"));
// Test for a parameterized array type with additional ">"
assertNull(TypesTestHelper.getInstance().parseType("Type<?>[]>"));
// Test for a parameterized type argument with missing ">"
assertNull(TypesTestHelper.getInstance().parseType("Type<Arg1<Arg2>[]"));
// Test for a parameterized type argument with missing "]"
assertNull(TypesTestHelper.getInstance().parseType("Type<Arg1<Arg2>[[]>[]"));
// Test for a parameterized type argument with missing ">"
assertNull(TypesTestHelper.getInstance().parseType("Type<Arg1<Arg2<Arg3<Arg4>>>[]"));
// Same test as above, but with an array type as Arg2 and with additional
// ">"
assertNull(TypesTestHelper.getInstance().parseType("Type<Arg1<Arg2<Arg3<Arg4>>[]>>>[]"));
}
catch (IOException e) {
fail(e.getMessage());
}
}
}