/* * Copyright 2019 Volker Berlin (i-net software) * * Licensed 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 de.inetsoftware.jwebassembly.runtime; import java.util.ArrayList; import java.util.Collection; import org.junit.ClassRule; import org.junit.runners.Parameterized.Parameters; import de.inetsoftware.jwebassembly.ScriptEngine; import de.inetsoftware.jwebassembly.WasmRule; import de.inetsoftware.jwebassembly.api.annotation.Export; /** * @author Volker Berlin */ public class MathAPI extends AbstractBaseTest { @ClassRule public static WasmRule rule = new WasmRule( TestClass.class ); public MathAPI( ScriptEngine script, String method, Object[] params ) { super( rule, script, method, params ); } @Parameters(name="{0}-{1}") public static Collection<Object[]> data() { ArrayList<Object[]> list = new ArrayList<>(); for( ScriptEngine[] val : ScriptEngine.testParams() ) { ScriptEngine script = val[0]; addParam( list, script, "sin0" ); addParam( list, script, "sinPI" ); addParam( list, script, "cos0" ); addParam( list, script, "tan0" ); addParam( list, script, "asin1" ); addParam( list, script, "acos1" ); addParam( list, script, "atan1" ); addParam( list, script, "toRadians90" ); addParam( list, script, "toDegrees1" ); addParam( list, script, "exp1" ); addParam( list, script, "log1" ); addParam( list, script, "log10" ); addParam( list, script, "cbrt8" ); addParam( list, script, "IEEEremainder" ); addParam( list, script, "ceil8_5" ); addParam( list, script, "floor8_5" ); addParam( list, script, "rint8_5" ); } rule.setTestParameters( list ); return list; } static class TestClass { @Export static double sin0() { return Math.sin( 0 ); } @Export static double sinPI() { return Math.sin( Math.PI / 2 ); } @Export static double cos0() { return Math.cos( 0 ); } @Export static double tan0() { return Math.tan( 0 ); } @Export static double asin1() { return Math.asin( 1 ); } @Export static double acos1() { return Math.acos( 1 ); } @Export static double atan1() { return Math.atan( 1 ); } @Export static double toRadians90() { return Math.toRadians( 90 ); } @Export static double toDegrees1() { return Math.toDegrees( 1 ); } @Export static double exp1() { return Math.exp( 1 ); } @Export static double log1() { return Math.log( 1 ); } @Export static double log10() { return Math.log10( 1 ); } @Export static double sqrt() { return Math.sqrt( 6.25 ); } @Export static double cbrt8() { return Math.cbrt( 8 ); } @Export static double IEEEremainder() { return Math.IEEEremainder( 11, 3 ); } @Export static double ceil8_5() { return Math.ceil( 8.5 ); } @Export static double floor8_5() { return Math.floor( 8.5 ); } @Export static double rint8_5() { return Math.rint( 8.5 ); } } }