Skip to content

Commit

Permalink
Document that static member classes are valid test classes
Browse files Browse the repository at this point in the history
  • Loading branch information
marcphilipp authored and Cody Moore committed Sep 15, 2018
1 parent 0e130f2 commit d1cbcfb
Showing 1 changed file with 11 additions and 10 deletions.
21 changes: 11 additions & 10 deletions documentation/src/docs/asciidoc/user-guide/writing-tests.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -60,11 +60,15 @@ named `@Fast` as follows. `@Fast` can then be used as a drop-in replacement for
include::{testDir}/example/Fast.java[tags=user_guide]
----

[[writing-tests-standard]]
=== Standard Test Class
[[writing-tests-classes-and-methods]]
=== Test Classes and Methods

A _test method_ is any instance method that is directly or meta-annotated with `@Test`,
`@RepeatedTest`, `@ParameterizedTest`, `@TestFactory`, or `@TestTemplate`. A _test class_
is any top level or static member class that contains at least one test method.

[source,java,indent=0]
.A standard test case
.A standard test class
----
include::{testDir}/example/StandardTests.java[tags=user_guide]
----
Expand Down Expand Up @@ -331,11 +335,11 @@ include::{testDir}/example/TaggingDemo.java[tags=user_guide]

In order to allow individual test methods to be executed in isolation and to avoid
unexpected side effects due to mutable test instance state, JUnit creates a new instance
of each test class before executing each _test_ method (see note below for what qualifies
as a _test_ method). This "per-method" test instance lifecycle is the default behavior in
JUnit Jupiter and is analogous to all previous versions of JUnit.
of each test class before executing each _test method_ (see
<<writing-tests-classes-and-methods>>). This "per-method" test instance lifecycle is the
default behavior in JUnit Jupiter and is analogous to all previous versions of JUnit.

NOTE: Please note that the test class will still be instantiated if a given _test_ method
NOTE: Please note that the test class will still be instantiated if a given _test method_
is _disabled_ via a <<writing-tests-conditional-execution,condition>> (e.g., `@Disabled`,
`@DisabledOnOs`, etc.) even when the "per-method" test instance lifecycle mode is active.

Expand All @@ -355,9 +359,6 @@ If you are authoring tests using the Kotlin programming language, you may also f
easier to implement `@BeforeAll` and `@AfterAll` methods by switching to the "per-class"
test instance lifecycle mode.

NOTE: In the context of test instance lifecycle a _test_ method is any method annotated
with `@Test`, `@RepeatedTest`, `@ParameterizedTest`, `@TestFactory`, or `@TestTemplate`.

[[writing-tests-test-instance-lifecycle-changing-default]]
==== Changing the Default Test Instance Lifecycle

Expand Down

0 comments on commit d1cbcfb

Please sign in to comment.