1 /* 2 * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. Oracle designates this 8 * particular file as subject to the "Classpath" exception as provided 9 * by Oracle in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 22 * or visit www.oracle.com if you need additional information or have any 23 * questions. 24 */ 25 26 package myapp3; 27 28 import java.util.ArrayList; 29 import java.util.List; 30 import java.util.Locale; 31 import java.util.logging.Handler; 32 import java.util.logging.LogRecord; 33 import java.util.logging.Logger; 34 import javafx.animation.KeyFrame; 35 import javafx.animation.Timeline; 36 import javafx.application.Application; 37 import javafx.scene.Scene; 38 import javafx.scene.control.TreeItem; 39 import javafx.scene.control.TreeTableColumn; 40 import javafx.scene.control.TreeTableView; 41 import javafx.scene.control.cell.TreeItemPropertyValueFactory; 42 import javafx.scene.layout.StackPane; 43 import javafx.stage.Stage; 44 import javafx.util.Duration; 45 import myapp3.pkg1.MyData; 46 47 import static myapp3.Constants.*; 48 49 /** 50 * Modular test application for testing JavaFX beans. 51 * This is launched by ModuleLauncherTest. 52 */ 53 public class AppTreeTableViewUnexported extends Application { 54 55 /** 56 * @param args the command line arguments 57 */ 58 public static void main(String[] args) { 59 try { 60 Application.launch(args); 61 } catch (Throwable t) { 62 t.printStackTrace(System.err); 63 System.exit(ERROR_UNEXPECTED_EXCEPTION); 64 } 65 } 66 67 private Logger logger; 68 private Handler logHandler; 69 private final List<Throwable> errs = new ArrayList<>(); 70 71 private void initLogger() { 72 Locale.setDefault(Locale.US); 73 74 // Initialize Logger 75 logHandler = new Handler() { 76 @Override 77 public void publish(LogRecord record) { 78 final Throwable t = record.getThrown(); 79 // detect any Throwable: 80 if (t != null) { 81 errs.add(t); 82 } 83 } 84 85 @Override 86 public void flush() { 87 } 88 89 @Override 90 public void close() { 91 } 92 }; 93 94 logger = Logger.getLogger("javafx.scene.control"); 95 logger.addHandler(logHandler); 96 } 97 98 @Override 99 public void start(Stage stage) throws Exception { 100 initLogger(); 101 102 try { 103 StackPane root = new StackPane(); 104 Scene scene = new Scene(root); 105 TreeTableView<MyData> treeTableView = new TreeTableView<>(); 106 107 // Name column 108 TreeTableColumn<MyData, String> nameCol = new TreeTableColumn<>(); 109 nameCol.setText("Name"); 110 nameCol.setPrefWidth(150); 111 nameCol.setCellValueFactory(new TreeItemPropertyValueFactory<>("name")); 112 113 // Value column 114 TreeTableColumn<MyData, Integer> valueCol = new TreeTableColumn<>(); 115 valueCol.setText("Value"); 116 valueCol.setPrefWidth(100); 117 valueCol.setCellValueFactory(new TreeItemPropertyValueFactory<>("value")); 118 119 treeTableView.getColumns().addAll(nameCol, valueCol); 120 121 TreeItem<MyData> treeRoot = new TreeItem<>(new MyData("Row A", 1)); 122 treeRoot.setExpanded(true); 123 treeTableView.setRoot(treeRoot); 124 125 TreeItem<MyData> item1 = new TreeItem<>(new MyData("Row B", 2)); 126 TreeItem<MyData> item2 = new TreeItem<>(new MyData("Row C", 3)); 127 treeRoot.getChildren().addAll(item1, item2); 128 129 root.getChildren().add(treeTableView); 130 131 stage.setScene(scene); 132 System.err.println("The following two WARNING messages are expected:"); 133 stage.show(); 134 135 // Hide the stage after the specified amount of time 136 KeyFrame kf = new KeyFrame(Duration.millis(SHOWTIME), e -> stage.hide()); 137 Timeline timeline = new Timeline(kf); 138 timeline.play(); 139 } catch (Error | Exception ex) { 140 ex.printStackTrace(System.err); 141 System.exit(ERROR_UNEXPECTED_EXCEPTION); 142 } 143 } 144 145 private void fail(String message, Throwable t) { 146 if (message != null) { 147 System.err.print(message + ": "); 148 } 149 if (t != null) { 150 System.err.println(t); 151 t.printStackTrace(); 152 } else { 153 System.err.println(); 154 } 155 System.exit(ERROR_ASSERTION_FAILURE); 156 } 157 158 @Override public void stop() { 159 final int expectedExceptions = 2; // One for each PropertyValueFactory 160 161 if (errs.isEmpty()) { 162 fail("ERROR: did not get the expected exception", null); 163 } 164 165 if (expectedExceptions != errs.size()) { 166 fail("ERROR: expected " + expectedExceptions + " exceptions, got: " + errs.size(), null); 167 } 168 169 for (Throwable t : errs) { 170 if (! (t instanceof RuntimeException)) { 171 fail("ERROR: unexpeted exception: ", t); 172 } 173 174 RuntimeException ex = (RuntimeException) t; 175 Throwable cause = ex.getCause(); 176 if (! (cause instanceof IllegalAccessException)) { 177 fail("ERROR: unexpeted cause: ", ex); 178 } 179 180 String message = cause.getMessage(); 181 if (message == null) { 182 fail("ERROR: detail message of cause is null", ex); 183 } 184 185 boolean badMessage = false; 186 if (!message.contains(" cannot access class ")) badMessage = true; 187 if (!message.contains(" does not open ")) badMessage = true; 188 if (!message.endsWith(" to javafx.base")) badMessage = true; 189 if (badMessage) { 190 fail("ERROR: detail message not formatted correctly", ex); 191 } 192 } 193 194 // We got the expected exception, exit normally 195 System.exit(ERROR_NONE); 196 } 197 198 }