Package org.grails.test.event

Source Code of org.grails.test.event.GrailsTestRunNotifier

/*
* Copyright 2011 SpringSource
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*      http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.grails.test.event;

import grails.build.logging.GrailsConsole;

import java.io.PrintWriter;
import java.io.StringWriter;

import org.grails.exceptions.reporting.DefaultStackTraceFilterer;
import org.grails.exceptions.reporting.StackTraceFilterer;
import org.junit.runner.Description;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
import org.junit.runner.notification.RunNotifier;
import org.junit.runner.notification.StoppedByUserException;

/**
* A RunNotifier that logs the the GrailsConsole.
*
* @author Graeme Rocher
* @since 2.0
*/
public class GrailsTestRunNotifier extends RunNotifier {

    int progress = 0;
    int total;
    private GrailsConsole console = GrailsConsole.getInstance();

    public GrailsTestRunNotifier(int total) {
        this.total = total;
    }

    @Override
    public void fireTestRunFinished(Result result) {
        super.fireTestRunFinished(result);
    }

    @Override
    public void fireTestStarted(Description description) throws StoppedByUserException {
        int progress = ++this.progress;
        if(progress>total) {
            total = progress;
        }
        console.indicateProgress(progress, total);
        super.fireTestStarted(description);
    }

    @Override
    public void fireTestFailure(Failure failure) {
        console.error("Failure: ", failure.getDescription().getDisplayName());
        Throwable exception = failure.getException();
        if (exception == null) {
            console.error(failure.getMessage());
        }
        else {
            StackTraceFilterer filterer = new DefaultStackTraceFilterer();
            filterer.setCutOffPackage("org.junit");
            filterer.filter(exception, true);

            StringWriter sw = new StringWriter();
            PrintWriter ps = new PrintWriter(sw);
            exception.printStackTrace(ps);

            console.error("", sw.toString());
        }
        super.fireTestFailure(failure);
    }
}
TOP

Related Classes of org.grails.test.event.GrailsTestRunNotifier

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.