Skip to content

hosuaby/inject-resources

Repository files navigation

@InjectResources

CI Coverage Status Maven Central User guide Core Javadoc Spring Javadoc JUnit Jupiter Javadoc JUnit 4 Javadoc

Reading content of resource files in Java is harder that it should be. Great libraries like Guava or Spring made it much easier, but it's time to make another step forward. Use @InjectResources is the easiest and most convenient way to load and parse content of resources without boilerplate code that opens/closes streams and handles I/O exceptions. This library made of inject-resources-core, fluid Java DSL, and of extensions for Spring, JUnit5 and JUnit4 that allow to do that with simple annotations.

Examples

Core

var text = resource()
        .onClassLoaderOf(this.getClass())
        .withPath("/io/hosuaby/junit/jupiter", "resource.txt")
        .text();

Check Core user guide for more information and examples.

With Spring

@Component
public class MyBean {

    // Field 'text' is injected with content of '/io/hosuaby/junit/jupiter/resource.txt'
    @TextResource("/io/hosuaby/junit/jupiter/resource.txt")
    private String text;
}

Check Spring extension user guide for more information and examples.

With JUnit

JUnit5

@TestWithResources
class InjectTextResourcesTests {

    @GivenTextResource("/io/hosuaby/junit/jupiter/resource.txt")
    String instanceField;

    @Test
    public void testInjectTextIntoStringInstanceField() {
        assertThat(instanceField)
                .isEqualTo("The quick brown fox jumps over the lazy dog.");
    }
}

Check JUnit5 extension user guide for more information and examples.

JUnit4

class MyTestClass {

    @Rule
    public ResourceRule<String> textResource = givenResource()
            .text("/io/hosuaby/junit/jupiter/resource.txt")
            .withCharset(StandardCharsets.UTF_8);

    @Test
    public void testWithTextResource() {
        assertThat(textResource.get())
                .isEqualTo("The quick brown fox jumps over the lazy dog.");
    }
}

Check JUnit4 extension user guide for more information and examples.

Supported formats

  • Binary
  • Text
  • Java properties
  • JSON & JSON Lines
  • YAML & YAML Documents

News

  • 2024-08-16: Release v1.0.0. Ensure compatibility. Java: up to 22, Spring Boot: up to 3.3, JUnit Jupiter: up to 5.11, Jackson: up to 2.17, Gson: up to 2.11, Snakeyaml: up to 2.2. ⚠️ Major change in package names: com.adelean -> io.hosuaby.
  • 2023-05-28: Release v0.3.3. Removed dependency on deprecated InstantiationAwareBeanPostProcessorAdapter.
  • 2022-04-07: Release v0.3.2. Upgrade org.reflections to 0.10.2.
  • 2022-03-23: Release v0.3.1. Limit classpath search for TestsAdvices.
  • 2021-09-04: Release v0.3.0. Fix source compatibility (Gradle). JUnit (5/4) modules now depends on core. Implementation no longer relies on classpath scan to find annotations of the project.
  • 2021-05-10: Release v0.2.2. Use reflexions.org instead of JUnit ReflectionSupport
  • 2021-04-23: Release v0.2.1. Fix reflexion on annotations on JDK 1.8
  • 2021-03-07: Release v0.2.0. Publish to Maven Central.
  • 2020-08-13: Release v0.1.0. This release includes Spring extension.
  • 2020-07-29: Release v0.1.0-beta. This release contains support of YAML files (Snakeyaml) and JUnit 4 extension.
  • 2020-06-20: Release v0.1.0-alpha. The first ever release. Contains only module core and JUnit 5 extension. Support files in formats: binary, text, java properties and JSON.

Documentation

User guides

Javadoc