17ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu/** 27ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * Copyright (c) 2004-2011 QOS.ch 37ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * All rights reserved. 47ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 57ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * Permission is hereby granted, free of charge, to any person obtaining 67ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * a copy of this software and associated documentation files (the 77ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * "Software"), to deal in the Software without restriction, including 87ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * without limitation the rights to use, copy, modify, merge, publish, 97ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * distribute, sublicense, and/or sell copies of the Software, and to 107ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * permit persons to whom the Software is furnished to do so, subject to 117ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * the following conditions: 127ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 137ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * The above copyright notice and this permission notice shall be 147ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * included in all copies or substantial portions of the Software. 157ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 167ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 177ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 187ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 197ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE 207ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 217ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION 227ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 237ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 247ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu */ 2588c4c456766193e012eb890e2208473d99b91f83Ceki Gulcupackage org.slf4j; 2688c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 2788c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport java.io.PrintStream; 2888c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport java.util.Random; 2988c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 3088c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport junit.framework.TestCase; 3188c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 32581b20f8aaa140ce722669a2cf1d8582a963ff4eCeki Gulcupublic class VersionMismatchAssertionTest extends TestCase { 3388c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 3431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu StringPrintStream sps = new StringPrintStream(System.err); 3531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu PrintStream old = System.err; 3631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu int diff = 1024 + new Random().nextInt(10000); 3788c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 3831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public VersionMismatchAssertionTest(String name) { 3931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super(name); 4031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 4188c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 4231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu protected void setUp() throws Exception { 4331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super.setUp(); 4431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu System.setErr(sps); 4531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 4688c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 4731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu protected void tearDown() throws Exception { 4831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super.tearDown(); 4931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu System.setErr(old); 5031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 5188c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 5231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void test() throws Exception { 5331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Logger logger = LoggerFactory.getLogger(this.getClass()); 5431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu String msg = "hello world " + diff; 5531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.info(msg); 5688c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 5731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu String s0 = (String) sps.stringList.get(0); 5831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertTrue(s0.matches("SLF4J: The requested version .* by your slf4j binding is not compatible with.*")); 5988c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 6031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu String s1 = (String) sps.stringList.get(1); 6131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertTrue(s1.contains(LoggerFactory.VERSION_MISMATCH)); 6288c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 6331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu String s2 = (String) sps.stringList.get(2); 6431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertTrue(s2.contains(msg)); 6531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 6631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 6788c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu} 68