X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=test%2Fjalview%2Fviewmodel%2Fstyles%2FViewStyleTest.java;h=885cb717f70498b85315edc8706a306cb5164ac3;hb=29538a14c49fcd47f00f1d2fff51f357b8e0388e;hp=fcabb5c74b55f2c8eabbfbb87aef804522bf1c15;hpb=17e77c3f2949a0729322b4a8d907f3f34b6a9914;p=jalview.git diff --git a/test/jalview/viewmodel/styles/ViewStyleTest.java b/test/jalview/viewmodel/styles/ViewStyleTest.java index fcabb5c..885cb71 100644 --- a/test/jalview/viewmodel/styles/ViewStyleTest.java +++ b/test/jalview/viewmodel/styles/ViewStyleTest.java @@ -1,6 +1,6 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.9) - * Copyright (C) 2015 The Jalview Authors + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors * * This file is part of Jalview. * @@ -24,16 +24,26 @@ import static org.testng.AssertJUnit.assertEquals; import static org.testng.AssertJUnit.assertFalse; import static org.testng.AssertJUnit.assertTrue; +import jalview.gui.JvOptionPane; + import java.awt.Color; import java.lang.reflect.Field; import java.util.Random; import org.testng.AssertJUnit; +import org.testng.annotations.BeforeClass; import org.testng.annotations.Test; public class ViewStyleTest { + @BeforeClass(alwaysRun = true) + public void setUpJvOptionPane() + { + JvOptionPane.setInteractiveMode(false); + JvOptionPane.setMockResponse(JvOptionPane.CANCEL_OPTION); + } + Random r = new Random(); /** @@ -58,7 +68,7 @@ public class ViewStyleTest for (Field field : fields) { field.setAccessible(true); - if (!copyConstructorIgnores(field.getName())) + if (!copyConstructorIgnores(field)) { changeValue(vs1, field); } @@ -68,37 +78,49 @@ public class ViewStyleTest for (Field field1 : fields) { - final Object value1 = field1.get(vs1); - final Object value2 = field1.get(vs2); - String msg = "Mismatch in " + field1.getName() + "(" + value1 + "/" + if (!copyConstructorIgnores(field1)) + { + final Object value1 = field1.get(vs1); + final Object value2 = field1.get(vs2); + String msg = "Mismatch in " + field1.getName() + "(" + value1 + "/" + value2 + ") - not set in copy constructor?"; - assertEquals(msg, value1, value2); + assertEquals(msg, value1, value2); + } } assertEquals("Hashcode not equals", vs1.hashCode(), vs2.hashCode()); } /** - * Add any field names in here that we expect to be ignored by the copy - * constructor + * Add tests here for any fields that we expect to be ignored by + * the copy constructor * - * @param name + * @param field * @return */ - private boolean copyConstructorIgnores(String name) + private boolean copyConstructorIgnores(Field field) { /* - * currently none! + * ignore instrumentation added by jacoco for test coverage */ + if (field.isSynthetic()) + { + return true; + } + if (field.getType().toString().contains("com_atlassian_clover")) + { + return true; + } + return false; } - + /** - * Change the value of one field in a ViewStyle object - * - * @param vs - * @param field - * @throws IllegalAccessException - */ + * Change the value of one field in a ViewStyle object + * + * @param vs + * @param field + * @throws IllegalAccessException + */ protected void changeValue(ViewStyle vs, Field field) throws IllegalAccessException { @@ -200,19 +222,22 @@ public class ViewStyleTest Field[] fields = ViewStyle.class.getDeclaredFields(); for (Field field : fields) { - field.setAccessible(true); - Object oldValue = field.get(vs2); - changeValue(vs2, field); - assertFalse("equals method ignores " + field.getName(), + if (!copyConstructorIgnores(field)) + { + field.setAccessible(true); + Object oldValue = field.get(vs2); + changeValue(vs2, field); + assertFalse("equals method ignores " + field.getName(), vs1.equals(vs2)); - if (vs1.hashCode() == vs2.hashCode()) - { - // uncomment next line to see which fields hashCode ignores - // System.out.println("hashCode ignores " + field.getName()); + if (vs1.hashCode() == vs2.hashCode()) + { + // uncomment next line to see which fields hashCode ignores + // System.out.println("hashCode ignores " + field.getName()); + } + // restore original value before testing the next field + field.set(vs2, oldValue); } - // restore original value before testing the next field - field.set(vs2, oldValue); } } }