You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

VaadinClasses.java 8.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. package com.vaadin.tests;
  2. import java.io.File;
  3. import java.io.IOException;
  4. import java.lang.reflect.Method;
  5. import java.lang.reflect.Modifier;
  6. import java.net.JarURLConnection;
  7. import java.net.URISyntaxException;
  8. import java.net.URL;
  9. import java.util.ArrayList;
  10. import java.util.Collection;
  11. import java.util.Collections;
  12. import java.util.Comparator;
  13. import java.util.Enumeration;
  14. import java.util.List;
  15. import java.util.jar.JarEntry;
  16. import org.junit.Test;
  17. import com.vaadin.server.VaadinSession;
  18. import com.vaadin.ui.Component;
  19. import com.vaadin.ui.ComponentContainer;
  20. import com.vaadin.ui.CustomComponent;
  21. import com.vaadin.ui.DragAndDropWrapper;
  22. import com.vaadin.ui.HorizontalSplitPanel;
  23. import com.vaadin.ui.LoginForm;
  24. import com.vaadin.ui.PopupView;
  25. import com.vaadin.ui.UI;
  26. import com.vaadin.ui.VerticalSplitPanel;
  27. import com.vaadin.ui.Window;
  28. @SuppressWarnings("deprecation")
  29. public class VaadinClasses {
  30. public static void main(String[] args) {
  31. System.out.println("ComponentContainers");
  32. System.out.println("===================");
  33. for (Class<? extends ComponentContainer> c : getComponentContainers()) {
  34. System.out.println(c.getName());
  35. }
  36. System.out.println();
  37. System.out.println("Components");
  38. System.out.println("==========");
  39. for (Class<? extends Component> c : getComponents()) {
  40. System.out.println(c.getName());
  41. }
  42. System.out.println();
  43. System.out.println("Server side classes");
  44. System.out.println("===================");
  45. for (Class<?> c : getAllServerSideClasses()) {
  46. System.out.println(c.getName());
  47. }
  48. }
  49. public static List<Class<? extends Component>> getComponents() {
  50. try {
  51. return findClasses(Component.class, "com.vaadin.ui");
  52. } catch (IOException e) {
  53. e.printStackTrace();
  54. return null;
  55. }
  56. }
  57. public static List<Class<? extends Object>> getThemeClasses() {
  58. try {
  59. return findClasses(Object.class, "com.vaadin.ui.themes");
  60. } catch (IOException e) {
  61. e.printStackTrace();
  62. return null;
  63. }
  64. }
  65. public static List<Class<? extends Object>> getAllServerSideClasses() {
  66. try {
  67. return findClassesNoTests(Object.class, "com.vaadin",
  68. new String[] { "com.vaadin.tests", "com.vaadin.client" });
  69. } catch (IOException e) {
  70. e.printStackTrace();
  71. return null;
  72. }
  73. }
  74. public static List<Class<? extends ComponentContainer>> getComponentContainers() {
  75. try {
  76. return findClasses(ComponentContainer.class, "com.vaadin.ui");
  77. } catch (IOException e) {
  78. e.printStackTrace();
  79. return null;
  80. }
  81. }
  82. public static List<Class<? extends ComponentContainer>> getComponentContainersSupportingAddRemoveComponent() {
  83. List<Class<? extends ComponentContainer>> classes = getComponentContainers();
  84. classes.remove(PopupView.class);
  85. classes.remove(CustomComponent.class);
  86. classes.remove(DragAndDropWrapper.class);
  87. classes.remove(CustomComponent.class);
  88. classes.remove(LoginForm.class);
  89. classes.remove(UI.class);
  90. return classes;
  91. }
  92. public static List<Class<? extends ComponentContainer>> getComponentContainersSupportingUnlimitedNumberOfComponents() {
  93. List<Class<? extends ComponentContainer>> classes = getComponentContainersSupportingAddRemoveComponent();
  94. classes.remove(VerticalSplitPanel.class);
  95. classes.remove(HorizontalSplitPanel.class);
  96. classes.remove(Window.class);
  97. return classes;
  98. }
  99. @SuppressWarnings({ "unchecked", "rawtypes" })
  100. public static List<Class<?>> getBasicComponentTests() {
  101. try {
  102. // Given as name to avoid dependencies on testbench source folder
  103. return (List) findClasses(
  104. Class.forName(
  105. "com.vaadin.tests.components.AbstractComponentTest"),
  106. "com.vaadin.tests.components");
  107. } catch (Exception e) {
  108. e.printStackTrace();
  109. return null;
  110. }
  111. }
  112. public static <T> List<Class<? extends T>> findClasses(Class<T> baseClass,
  113. String basePackage) throws IOException {
  114. return findClasses(baseClass, basePackage, new String[] {});
  115. }
  116. private static <T> List<Class<? extends T>> findClasses(Class<T> baseClass,
  117. String basePackage, String[] ignoredPackages) throws IOException {
  118. List<Class<? extends T>> classes = new ArrayList<>();
  119. String basePackageDirName = "/" + basePackage.replace('.', '/');
  120. URL location = VaadinSession.class.getResource(basePackageDirName);
  121. if (location.getProtocol().equals("file")) {
  122. try {
  123. File f = new File(location.toURI());
  124. if (!f.exists()) {
  125. throw new IOException(
  126. "Directory " + f.toString() + " does not exist");
  127. }
  128. findPackages(f, basePackage, baseClass, classes,
  129. ignoredPackages);
  130. } catch (URISyntaxException e) {
  131. throw new IOException(e.getMessage());
  132. }
  133. } else if (location.getProtocol().equals("jar")) {
  134. JarURLConnection juc = (JarURLConnection) location.openConnection();
  135. findPackages(juc, basePackage, baseClass, classes);
  136. }
  137. Collections.sort(classes, (Class<? extends T> o1, Class<? extends T> o2) -> o1.getName().compareTo(o2.getName()));
  138. return classes;
  139. }
  140. private static <T> List<Class<? extends T>> findClassesNoTests(
  141. Class<T> baseClass, String basePackage, String[] ignoredPackages)
  142. throws IOException {
  143. List<Class<? extends T>> classes = findClasses(baseClass, basePackage,
  144. ignoredPackages);
  145. List<Class<? extends T>> classesNoTests = new ArrayList<>();
  146. for (Class<? extends T> clazz : classes) {
  147. if (!clazz.getName().contains("Test")) {
  148. boolean testPresent = false;
  149. for (Method method : clazz.getMethods()) {
  150. if (method.isAnnotationPresent(Test.class)) {
  151. testPresent = true;
  152. break;
  153. }
  154. }
  155. if (!testPresent) {
  156. classesNoTests.add(clazz);
  157. }
  158. }
  159. }
  160. return classesNoTests;
  161. }
  162. private static <T> void findPackages(JarURLConnection juc,
  163. String javaPackage, Class<T> baseClass,
  164. Collection<Class<? extends T>> result) throws IOException {
  165. String prefix = "com/vaadin/ui";
  166. Enumeration<JarEntry> ent = juc.getJarFile().entries();
  167. while (ent.hasMoreElements()) {
  168. JarEntry e = ent.nextElement();
  169. if (e.getName().endsWith(".class")
  170. && e.getName().startsWith(prefix)) {
  171. String fullyQualifiedClassName = e.getName().replace('/', '.')
  172. .replace(".class", "");
  173. addClassIfMatches(result, fullyQualifiedClassName, baseClass);
  174. }
  175. }
  176. }
  177. private static <T> void findPackages(File parent, String javaPackage,
  178. Class<T> baseClass, Collection<Class<? extends T>> result,
  179. String[] ignoredPackages) {
  180. for (String ignoredPackage : ignoredPackages) {
  181. if (javaPackage.equals(ignoredPackage)) {
  182. return;
  183. }
  184. }
  185. for (File file : parent.listFiles()) {
  186. if (file.isDirectory()) {
  187. findPackages(file, javaPackage + "." + file.getName(),
  188. baseClass, result, ignoredPackages);
  189. } else if (file.getName().endsWith(".class")) {
  190. String fullyQualifiedClassName = javaPackage + "."
  191. + file.getName().replace(".class", "");
  192. addClassIfMatches(result, fullyQualifiedClassName, baseClass);
  193. }
  194. }
  195. }
  196. @SuppressWarnings("unchecked")
  197. private static <T> void addClassIfMatches(
  198. Collection<Class<? extends T>> result,
  199. String fullyQualifiedClassName, Class<T> baseClass) {
  200. try {
  201. // Try to load the class
  202. Class<?> c = Class.forName(fullyQualifiedClassName);
  203. if (baseClass.isAssignableFrom(c)
  204. && !Modifier.isAbstract(c.getModifiers())
  205. && !c.isAnonymousClass() && !c.isMemberClass()
  206. && !c.isLocalClass()) {
  207. result.add((Class<? extends T>) c);
  208. }
  209. } catch (Exception e) {
  210. // Could ignore that class cannot be loaded
  211. e.printStackTrace();
  212. } catch (LinkageError e) {
  213. // Ignore. Client side classes will at least throw LinkageErrors
  214. }
  215. }
  216. }