/* * Copyright (C) 2017 The Android Open Source Project * * 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. */ /** * AOSP JFuzz Tester. * Automatically generated program. * jfuzz -s 3674365851 -d 1 -l 8 -i 2 -n 3 (version 1.3) */ import java.util.Arrays; @SuppressWarnings("deprecation") public class Test { private interface X { int x(); } private class A { public int a() { return (mI--); } } private class B extends A implements X { public int a() { return super.a() + ((235022827 >> mI) & 574409782); } public int x() { return ((mZ) ? mI : ((Math.addExact(852067216, 246625693)) % mI)); } } private static class C implements X { public static int s() { return 1878004320; } public int c() { return -618864356; } public int x() { return -556993081; } } private A mA = new B(); private B mB = new B(); private X mBX = new B(); private C mC = new C(); private X mCX = new C(); private boolean mZ = false; private int mI = 0; private long mJ = 0; private float mF = 0; private double mD = 0; private float[][][][][][][] mArray = new float[2][2][2][2][2][2][2]; private Test() { float a = -774156645.0f; for (int i0 = 0; i0 < 2; i0++) { for (int i1 = 0; i1 < 2; i1++) { for (int i2 = 0; i2 < 2; i2++) { for (int i3 = 0; i3 < 2; i3++) { for (int i4 = 0; i4 < 2; i4++) { for (int i5 = 0; i5 < 2; i5++) { for (int i6 = 0; i6 < 2; i6++) { mArray[i0][i1][i2][i3][i4][i5][i6] = a; a++; } } } } } } } } private float testMethod() { { long lJ0 = (Long.MIN_VALUE); if (((boolean) new Boolean(mZ))) { lJ0 |= ((-609721394L | -601487228L) + (--mJ)); for (int i0 = mArray.length - 1; i0 >= 0; i0--) { mF = ((float) new Float(921021787.0f)); mZ ^= ((mZ ? (mZ) : (Boolean.logicalXor((Boolean.logicalAnd(mZ, mZ)), mZ))) ^ true); for (int i1 = 2 - 1; i1 >= 0; i1--) { { int i2 = -1; while (++i2 < mArray.length) { mI = ((int) new Integer(((int) mD))); mI <<= (mI++); mZ = ((boolean) new Boolean(true)); mJ >>= (- (~ (lJ0++))); } } } mI >>= (Integer.MIN_VALUE); } mD *= (mC.x()); mI *= (Math.multiplyExact(61363273, (-1448306837 | mI))); } else { mZ = (mZ); for (int i0 = 0; i0 < 2; i0++) { for (int i1 = 2 - 1; i1 >= 0; i1--) { mArray[i0][i1][mArray.length - 1][i0][i1][1][i1] *= ((! mZ) ? -1041059197.0f : (mF / -1370212878.0f)); lJ0 += (~ mJ); for (int i2 = 2 - 1; i2 >= 0; i2--) { { int i3 = -1; while (++i3 < 2) { return ((mZ) ? ((float) new Float((--mF))) : (++mF)); } } mI = (--mI); } mJ &= (--lJ0); } if (((mZ) ^ false)) { mI >>>= (mC.c()); } else { if (((+ (Long.reverseBytes(mJ))) >= 1517367973L)) { mI <<= (mI--); } else { { int i1 = 0; do { mZ |= (true && true); if ((Boolean.logicalAnd(mZ, (! true)))) { mI %= ((mI ^ mI) ^ mI); } else { mI = (mI << mI); } } while (++i1 < 2); } } } } switch (mArray.length - 1) { case 1: { mF *= (-1336843462.0f - ((804606312.0f * 1709271074.0f) - (Float.MIN_NORMAL))); break; } default: { mF /= (mF--); break; } } } lJ0 >>>= (lJ0 | mJ); } mJ %= ( (-1288553765 ^ mI)); return (--mArray[1][0][1][1][0][1][0]); } public static void main(String[] args) { Test t = new Test(); float r = -985685074.0f; try { r = t.testMethod(); } catch (Exception e) { // Arithmetic, null pointer, index out of bounds, etc. System.out.println("An exception was caught."); } System.out.println("r = " + r); System.out.println("mZ = " + t.mZ); System.out.println("mI = " + t.mI); System.out.println("mJ = " + t.mJ); System.out.println("mF = " + t.mF); System.out.println("mD = " + t.mD); System.out.println("mArray = " + Arrays.deepToString(t.mArray)); } }