org.neo4j.test.extension.SuppressOutputExtension Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of test-utils Show documentation
Show all versions of test-utils Show documentation
A set of utilities used by tests.
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [http://neo4j.com]
*
* This file is part of Neo4j.
*
* Neo4j is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package org.neo4j.test.extension;
import org.junit.jupiter.api.extension.AfterEachCallback;
import org.junit.jupiter.api.extension.BeforeEachCallback;
import org.junit.jupiter.api.extension.ExtensionContext;
import org.junit.jupiter.api.extension.ExtensionContext.Namespace;
import org.junit.jupiter.api.parallel.ResourceLock;
import org.junit.jupiter.api.parallel.Resources;
import org.junit.platform.commons.util.AnnotationUtils;
import java.util.ArrayList;
import java.util.List;
public class SuppressOutputExtension extends StatefulFieldExtension implements BeforeEachCallback, AfterEachCallback
{
static final String SUPPRESS_OUTPUT = "suppressOutput";
static final Namespace SUPPRESS_OUTPUT_NAMESPACE = Namespace.create( SUPPRESS_OUTPUT );
@Override
protected String getFieldKey()
{
return SUPPRESS_OUTPUT;
}
@Override
protected Class getFieldType()
{
return SuppressOutput.class;
}
@Override
protected SuppressOutput createField( ExtensionContext extensionContext )
{
return SuppressOutput.suppressAll();
}
@Override
protected Namespace getNameSpace()
{
return SUPPRESS_OUTPUT_NAMESPACE;
}
@Override
public void afterEach( ExtensionContext context )
{
getStoredValue( context ).releaseVoices( context.getExecutionException().isPresent() );
removeStoredValue( context );
}
@Override
public void beforeEach( ExtensionContext context )
{
assertHasResourceLock( context );
getStoredValue( context ).captureVoices();
}
private void assertHasResourceLock( ExtensionContext context )
{
List resourceLocks = new ArrayList<>();
context.getTestMethod().ifPresent( method -> resourceLocks.addAll( AnnotationUtils.findRepeatableAnnotations( method, ResourceLock.class ) ) );
context.getTestClass().ifPresent( testClass -> {
Class> cls;
Class> host = testClass;
do
{
cls = host;
resourceLocks.addAll( AnnotationUtils.findRepeatableAnnotations( cls, ResourceLock.class ) );
host = cls.getEnclosingClass();
}
while ( host != null );
} );
if ( resourceLocks.stream().noneMatch( resourceLock -> Resources.SYSTEM_OUT.equals( resourceLock.value() ) ) )
{
throw new IllegalStateException( getClass().getSimpleName() + " requires `@ResourceLock( Resources.SYSTEM_OUT )` annotation." );
}
}
}