13e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu/** 23e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * Copyright (c) 2004-2011 QOS.ch 33e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * All rights reserved. 43e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * 53e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * Permission is hereby granted, free of charge, to any person obtaining 63e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * a copy of this software and associated documentation files (the 73e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * "Software"), to deal in the Software without restriction, including 83e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * without limitation the rights to use, copy, modify, merge, publish, 93e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * distribute, sublicense, and/or sell copies of the Software, and to 103e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * permit persons to whom the Software is furnished to do so, subject to 113e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * the following conditions: 123e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * 133e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * The above copyright notice and this permission notice shall be 143e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * included in all copies or substantial portions of the Software. 153e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * 163e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 173e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 183e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 193e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE 203e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 213e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION 223e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 233e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu * 243e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu */ 253e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcupackage org.slf4j; 263e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu 273e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcuimport java.io.PrintStream; 283e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcuimport java.util.List; 293e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcuimport java.util.Random; 303e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu 313e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcuimport junit.framework.TestCase; 323e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu 333e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcupublic class IncompatibleMultiBindingAssertionTest extends TestCase { 343e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu 3531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu StringPrintStream sps = new StringPrintStream(System.err); 3631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu PrintStream old = System.err; 3731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu int diff = 1024 + new Random().nextInt(10000); 383e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu 3931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public IncompatibleMultiBindingAssertionTest(String name) { 4031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super(name); 4131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 423e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu 4331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu protected void setUp() throws Exception { 4431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super.setUp(); 4531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu System.setErr(sps); 4631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 473e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu 4831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu protected void tearDown() throws Exception { 4931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super.tearDown(); 5031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu System.setErr(old); 513e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu } 523e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu 5331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void test() throws Exception { 5431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu try { 5531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Logger logger = LoggerFactory.getLogger(this.getClass()); 5631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu String msg = "hello world " + diff; 5731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.info(msg); 5831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu fail("was expecting NoSuchMethodError"); 5931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } catch (NoSuchMethodError e) { 6031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 6131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu List<String> list = sps.stringList; 6231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertMsgContains(list, 0, "Class path contains multiple SLF4J bindings."); 6331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertMsgContains(list, 1, "Found binding in"); 6431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertMsgContains(list, 2, "Found binding in"); 6531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertMsgContains(list, 3, "See http://www.slf4j.org/codes.html"); 6631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertMsgContains(list, 4, "slf4j-api 1.6.x (or later) is incompatible with this binding"); 6731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertMsgContains(list, 5, "Your binding is version 1.5.5 or earlier."); 683e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu 6931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 7031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 7131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu void assertMsgContains(List<String> strList, int index, String msg) { 7231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertTrue(((String) strList.get(index)).contains(msg)); 7331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 743e24a5c715dcd3a8597ba811716152af9aa2a37dCeki Gulcu} 75