This is an automated email from the ASF dual-hosted git repository. ggregory pushed a commit to branch master in repository https://gitbox.apache.org/repos/asf/commons-bcel.git
The following commit(s) were added to refs/heads/master by this push: new 8c333a7a Test and coverage of InstructionFactory (#190) 8c333a7a is described below commit 8c333a7ac58b58158a536548f12b7f483b504fc6 Author: nbauma109 <nbauma...@users.noreply.github.com> AuthorDate: Sun Dec 18 20:05:27 2022 +0100 Test and coverage of InstructionFactory (#190) * InstructionFactoryTestCase: test array store/load and exceptions * added tests for createNull * test createNull with void Co-authored-by: nbauma109 <nbauma...@github.com> --- .../bcel/generic/InstructionFactoryTestCase.java | 99 ++++++++++++++++++++++ 1 file changed, 99 insertions(+) diff --git a/src/test/java/org/apache/bcel/generic/InstructionFactoryTestCase.java b/src/test/java/org/apache/bcel/generic/InstructionFactoryTestCase.java new file mode 100644 index 00000000..3ade614e --- /dev/null +++ b/src/test/java/org/apache/bcel/generic/InstructionFactoryTestCase.java @@ -0,0 +1,99 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.apache.bcel.generic; + +import org.apache.bcel.AbstractTestCase; +import org.apache.bcel.Const; +import org.apache.bcel.Repository; +import org.junit.jupiter.api.Test; + +import static org.apache.bcel.generic.InstructionFactory.createArrayLoad; +import static org.apache.bcel.generic.InstructionFactory.createArrayStore; +import static org.apache.bcel.generic.InstructionFactory.createBinaryOperation; +import static org.apache.bcel.generic.InstructionFactory.createBranchInstruction; +import static org.apache.bcel.generic.InstructionFactory.createLoad; +import static org.apache.bcel.generic.InstructionFactory.createNull; +import static org.apache.bcel.generic.InstructionFactory.createReturn; +import static org.apache.bcel.generic.InstructionFactory.createStore; +import static org.junit.jupiter.api.Assertions.*; + +public class InstructionFactoryTestCase extends AbstractTestCase { + + @Test + public void testArrayLoad() throws Exception { + assertEquals(InstructionConst.BALOAD, createArrayLoad(Type.BOOLEAN)); + assertEquals(InstructionConst.BALOAD, createArrayLoad(Type.BYTE)); + assertEquals(InstructionConst.CALOAD, createArrayLoad(Type.CHAR)); + assertEquals(InstructionConst.SALOAD, createArrayLoad(Type.SHORT)); + assertEquals(InstructionConst.IALOAD, createArrayLoad(Type.INT)); + assertEquals(InstructionConst.FALOAD, createArrayLoad(Type.FLOAT)); + assertEquals(InstructionConst.DALOAD, createArrayLoad(Type.DOUBLE)); + assertEquals(InstructionConst.LALOAD, createArrayLoad(Type.LONG)); + assertEquals(InstructionConst.AALOAD, createArrayLoad(Type.OBJECT)); + assertEquals(InstructionConst.AALOAD, createArrayLoad(Type.getType("[I"))); + } + + @Test + public void testArrayStore() throws Exception { + assertEquals(InstructionConst.BASTORE, createArrayStore(Type.BOOLEAN)); + assertEquals(InstructionConst.BASTORE, createArrayStore(Type.BYTE)); + assertEquals(InstructionConst.CASTORE, createArrayStore(Type.CHAR)); + assertEquals(InstructionConst.SASTORE, createArrayStore(Type.SHORT)); + assertEquals(InstructionConst.IASTORE, createArrayStore(Type.INT)); + assertEquals(InstructionConst.FASTORE, createArrayStore(Type.FLOAT)); + assertEquals(InstructionConst.DASTORE, createArrayStore(Type.DOUBLE)); + assertEquals(InstructionConst.LASTORE, createArrayStore(Type.LONG)); + assertEquals(InstructionConst.AASTORE, createArrayStore(Type.OBJECT)); + assertEquals(InstructionConst.AASTORE, createArrayStore(Type.getType("[I"))); + } + + @Test + public void testExceptions() throws Exception { + final InstructionFactory factory = new InstructionFactory(new ClassGen(Repository.lookupClass(Object.class))); + assertThrowsExactly(IllegalArgumentException.class, () -> createArrayLoad(Type.UNKNOWN)); + assertThrowsExactly(IllegalArgumentException.class, () -> createArrayStore(Type.UNKNOWN)); + assertThrowsExactly(IllegalArgumentException.class, () -> createBinaryOperation("$", Type.DOUBLE)); + assertThrowsExactly(IllegalArgumentException.class, () -> createBinaryOperation("$", Type.FLOAT)); + assertThrowsExactly(IllegalArgumentException.class, () -> createBinaryOperation("$", Type.INT)); + assertThrowsExactly(IllegalArgumentException.class, () -> createBinaryOperation("$", Type.LONG)); + assertThrowsExactly(IllegalArgumentException.class, () -> createBinaryOperation("*", Type.OBJECT)); + assertThrowsExactly(IllegalArgumentException.class, () -> createBranchInstruction(Short.MIN_VALUE, null)); + assertThrowsExactly(IllegalArgumentException.class, () -> createLoad(Type.UNKNOWN, 0)); + assertThrowsExactly(IllegalArgumentException.class, () -> createNull(Type.UNKNOWN)); + assertThrowsExactly(IllegalArgumentException.class, () -> createReturn(Type.UNKNOWN)); + assertThrowsExactly(IllegalArgumentException.class, () -> createStore(Type.UNKNOWN, 0)); + assertThrowsExactly(IllegalArgumentException.class, () -> factory.createAppend(Type.UNKNOWN)); + assertThrowsExactly(IllegalArgumentException.class, () -> factory.createCast(Type.UNKNOWN, Type.UNKNOWN)); + assertThrowsExactly(IllegalArgumentException.class, () -> factory.createFieldAccess("java.lang.System", "out", new ObjectType("java.io.PrintStream"), Const.NOP)); + assertThrowsExactly(IllegalArgumentException.class, () -> factory.createInvoke("java.io.PrintStream", "println", Type.VOID, new Type[] { Type.STRING }, Const.NOP)); + } + + @Test + public void testNull() throws Exception { + assertEquals(InstructionConst.ICONST_0, createNull(Type.BOOLEAN)); + assertEquals(InstructionConst.ICONST_0, createNull(Type.BYTE)); + assertEquals(InstructionConst.ICONST_0, createNull(Type.CHAR)); + assertEquals(InstructionConst.ICONST_0, createNull(Type.SHORT)); + assertEquals(InstructionConst.ICONST_0, createNull(Type.INT)); + assertEquals(InstructionConst.FCONST_0, createNull(Type.FLOAT)); + assertEquals(InstructionConst.DCONST_0, createNull(Type.DOUBLE)); + assertEquals(InstructionConst.LCONST_0, createNull(Type.LONG)); + assertEquals(InstructionConst.NOP, createNull(Type.VOID)); + assertEquals(InstructionConst.ACONST_NULL, createNull(Type.OBJECT)); + assertEquals(InstructionConst.ACONST_NULL, createNull(Type.getType("[I"))); + } +}