/* * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code 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 * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ import java.foreign.Libraries; import java.foreign.Library; import java.foreign.NativeTypes; import java.foreign.Scope; import java.foreign.memory.LayoutType; import java.foreign.memory.Pointer; import java.lang.invoke.MethodHandles; import org.testng.annotations.Test; import test.jextract.struct.struct_h; import static org.testng.Assert.assertEquals; import static org.testng.Assert.fail; import static test.jextract.struct.struct_h.*; /* * @test * @library .. * @run driver JtregJextract -t test.jextract.struct -- struct.h * @run testng LibStructTest */ public class LibStructTest { static final struct_h libStruct; static { Library lib = Libraries.loadLibrary(MethodHandles.lookup(), "Struct"); libStruct = Libraries.bind(struct_h.class, lib); } @Test public void testDerefUndefined() { Pointer ptr = libStruct.allocateUndefinedStruct(); try { UndefinedStruct x = ptr.get(); fail("Should not be able to dereference a Pointer to undefined struct"); } catch (IllegalStateException ex) { // ignore expected } try (Scope scope = Scope.globalScope().fork()) { UndefinedStruct x = scope.allocateStruct(UndefinedStruct.class); fail("Should not be able to allocate an undefined struct"); } catch (UnsupportedOperationException ex) { // ignore expected } } @Test public void testVoidArguments() { libStruct.voidArguments(); assertEquals(Pointer.toString(libStruct.LastCalledMethod$get()), "voidArguments"); } @Test public void testEmptyArguments() { libStruct.emptyArguments(1); assertEquals(Pointer.toString(libStruct.LastCalledMethod$get()), "emptyArguments"); } @Test public void testCastAndAccess() { Pointer ptr = libStruct.allocateUndefinedStruct(); Plain pt = libStruct.fromUndefinedStruct(ptr); assertEquals(pt.x$get(), 0x1234); assertEquals(pt.y$get(), 0x3412); try { Plain tmp = ptr.cast(LayoutType.ofStruct(Plain.class)).get(); fail("Should not be able to cast incompatible layout directly"); } catch (ClassCastException ex) { // ignore expected } // This is working now as an escape, but should it really? Plain tmp = ptr.cast(NativeTypes.VOID).cast(LayoutType.ofStruct(Plain.class)).get(); assertEquals(tmp.x$get(), 0x1234); assertEquals(tmp.y$get(), 0x3412); } }